11.Nas_1


docker 이용 tvheadend backup 백업 복원하기


  • 링크

  • 첨부

  • 컨텐츠 정보

    • 16,802 조회
    • 4 댓글
    • 0 추천
    • 목록

    본문

    ■ docker 이용 tvheadend backup 백업 복원하기 입니다 링크1은 처음 설치방법이 자세히 설명 사이트 참조 바랍니다.

    초기 설치후 tvheadend 파일및 도커의 현재버전을 백업 복원 하는 방법 입니다

    시놀로지 도커이용  tvh설치는

    https://github.com/wiserain/docker-tvheadend/blob/epgkr/assets/how-to-run-on-synology.md

    관련정보 참조는

    https://hub.docker.com/r/wiserain/tvheadend/

    사용조건에

    백업하고자  하먼

    1) 폴더를 압측 백업/복원

    2) 도커의 비디오형식 설정 내보내기/가져오기

    3232235521_1520062678.7531.png

    3232235521_1520062544.5915.png

    3232235521_1520062526.8425.png

    3232235521_1520063021.4313.png

    3232235521_1520063057.9457.png

    3232235521_1520063253.8153.png

    3232235521_1520064238.7297.png

    3232235521_1520064280.3094.png

    http://192.168.0.6/epg2xml/xmltv.xml

    을 실행을 위하여 web폴더에 epg2xml폴더 카피 합니다.

    3232235521_1520064362.2272.png

    설치 정보

    https://github.com/wiserain/docker-tvheadend/tree/epgkr#%ED%99%98%EA%B2%BD%EB%B3%80%EC%88%98

    docker-tvheadend

    다음의 특징을 가지는 docker-tvheadend 이미지

    1. linuxserver/tvheadend 기반: 다양한 docker용 앱 이미지를 제작/배포하고 있는 linuxserver.io의 소스를 기반으로 한다. 차이점은 tvheadend 빌드 옵션 중 --disable-*_static을 제거하여 좀 더 나은 transcoding이 가능하게 한다. 또한 본 이미지는 x86_64 기반이다.

    2. 대한민국 IPTV를 위한 EPG grabber 탑재: 이 기능은 wonipapa/epg2xml과 내장 tv_grab_file을 이용하였다.

    실행 방법

    아래 세가지 방법 중 자신에게 맞는 하나를 선택하여 컨테이너를 생성/실행한다.

    docker 명령어 사용시:

    docker run -d \
        --name=<container name> \
        --network=host \
        -v <path to recordings>:/recordings \
        -v <path to config>:/config \
        -v <path to epg2xml>:/epg2xml \
        -e PUID=<UID for user> \
        -e PGID=<GID for user> \
        wiserain/tvheadend:stable

    docker-compose 사용시:

    version: '2'
    
    services:
      <service name>:
        container_name: <container name>
        image: wiserain/tvheadend:stable
        restart: always
        network_mode: "host"
        volumes:
          - <path to config>:/config
          - <path to recordings>:/recordings
          - <path to epg2xml>:/epg2xml
        environment:
          - PUID=<UID for user>
          - PGID=<GID for user>

    Synology DSM 사용시: 별도 문서 참조

    작성 시점이 오래 되어 상세 내용은 조금 다를 수 있으니 지금 보고 있는 문서의 내용을 우선으로 한다.

    EPG 사용법

    컨테이너를 실행 후 http://localhost:9981/를 통해 WEBUI로 접속한 다음, Configuration > Channel / EPG > EPG Grabber Modules로 이동하면 아래 이미지와 같이 3개의 IPTV 서비스를 위한 internal XMLTV grabber가 마련되어 있으니 Enable 시켜서 사용하면 된다.

    이미지 태그 기준 4.1-2493 버전부터 epg2xml의 옵션을 전달 받아 실행하는 모듈을 추가하였다. 왼쪽에서 Korea (epg2xml)을 선택하고 오른쪽 옵션 창에서 epg2xml 이후의 arguments를 주면 된다. 예외 처리가 되어 있지 않기 때문에 출력에 관련된 -o -s -d는 extra arguments로 입력하면 안된다.

    처음 EPG 설정 시 유의사항

    Socket으로 직접 밀어 넣는 external grabber와 달리 내부적으로 cron을 실행한다. 아래 그림과 같이 EPG Grabber 탭에 보면 기본 설정으로 매일 12시 24시 4분에 실행해서 epg를 가져온다. 하지만 버그가 있는지 기본 설정을 무시하고 끊임없이 실행되는 문제가 초반에 있다. 그러므로 설정을 바꿔서 저장해주고 Re-run Internal EPG Grabbers을 눌러서 실행해준다. 어떤 값으로든 변경 후에는 문제없이 정상적으로 동작하는 것을 확인하였다. Cron 설정 방법에 대해서는 링크를 참고바람.

    관련 설정들

    이미지 태그 네이밍 규칙

    • latest: 최신 이미지 버전. 대부분의 유저에게 권장 됨. 새로운 기능을 체험할 수 있는 개발 버전으로 약간 불안정할 수 있다. 비유를 들자면 Firefox나 LineageOS의 Nightly 빌드, 아니면 iOS의 Public Beta와 유사하다.
    • ver-build과거 이미지 버전으로 tvheadend 버전을 따른다. 예를 들어 4.1-2533.
    • stable: 최신 tvheadend release 버전 참고
    • vaapilatest 빌드에서 vaapi 관련 옵션을 활성화 한 버전 (실험적) 4.3-1102 부터 latest 태그에서 vaapi를 지원하게 됨에 따라 더 이상 유효하지 않다.
    • testing: docker 이미지 테스트 버전 (개발용)

    네트워크 모드

    docker는 멀티캐스트 패킷 라우팅이 안되기 때문에 tvheadend를 이용해 IPTV를 보기 위해서는 무조건 hosted network를 사용해야 한다. 일부 낮은 docker engine 버전(예를 들어 Synology DSM 5.2)에서는 지원하지 않으니 참고. hosted network란 포트 포워딩이나 매핑을 하지 않고 호스트의 네트워크에 그대로 붙인다는 의미이므로 tvheadend가 사용하는 포트를 바꾸고 싶다면 앱 실행 시 옵션을 주어서 변경해야 한다. docker에서는 다음과 같이 환경 변수를 추가해주면 된다. RUN_OPTS=--http_port <port number> --htsp_port <port number>

    환경변수

    docker-tvheadend의 동작을 제어하는 환경변수와 가능한 옵션을 설명한다. 참고로 환경변수는 컨테이너 생성 시점에 그 값이 고정 되므로 변경을 원한다면 컨테이너를 삭제/재생성 해야한다. 먼저 필수로 지정해야하는 환경변수=기본값는 다음과 같다.

    • PUIDPGUI: 컨테이너 내부의 앱이 외부의 볼륨에 접근할 수 있도록 하는 권한에 대한 것이다. 여기를 참고하여 설정한다. 적절하게 설정하지 않으면, EPG 관련 스크립트가 동작하지 않거나 녹화가 안될 수 있다.
    • TZ="Asia/Seoul": docker-tvheadend에 적용되는 timezone 설정이다. 이게 제대로 안되면 EPG에 시간차가 발생한다.
    • EPG2XML_VER="latest": 이 값을 활용해서 epg2xml (latest release)을 다운로드 받는다. 만약 과거 버전에 머무르고 싶다면 값을 지정해 준다. 예를 들어 EPG2XML_VER=1.2.1 더이상 epg2xml 폴더의 내용이 변경되지 않기를 원한다면 값을 비워둔다. EPG2XML_VER=.

    추가로 사용 가능한 환경변수는 다음과 같다.

    • UPDATE_CHANNEL: epg2xml의 채널 정보를 담고 있는 Channel.json 파일을 업데이트 한다. 더이상 업데이트 하지 않기를 원하면 false를 입력한다.
    • RUN_OPTS=--http_port <port number> --htsp_port <port number>: tvheadend 바이너리에 직접 전달되는 실행옵션. 대표적으로 tvheadend의 동작 포트를 바꿀때 쓸 수 있다.
    • TVH_URL=http://username:password@localhost:9981tvhProxy는 tvheadend의 영상 스트림을 Plex의 DVR (녹화)에서 활용할 수 있도록 도와주는 프록시이다. tvheadend와 같이 내장했으므로 localhost가 맞고 그 외 username, password, port는 자신의 환경에 맞게 수정해서 사용한다.

    어쩌면 도움이 될지도 모르는 정보

    1. 컨테이너를 시작할 때마다 /etc/cont-init.d/와 /etc/services.d/ 안의 스크립트를 이용해서 초기화를 진행하고 프로그램을 실행한다. 무슨 일이 일어났는지 궁금하거나 생각대로 되지 않으면 로그를 확인하자.
    2. epg2xml 동작 언어는 php이다. 성능은 python이 약간 좋지만 그 차이가 미미한 반면, docker로 deploy할 때 php가 꽤 유용한 기능을 제공한다.
    3. epg2xml.json은 경로에 파일이 없는 경우에만 다운로드하여 설치하고 경로에 있으면 원래 것을 보존한다. 따라서 같이 업데이트하고 싶으면 파일들을 지우고 컨테이너 삭제/생성/실행하면 된다. 그것도 싫으면 그냥 수동으로 받아서 복사/붙여넣기 하면 된다.
    4. 예전에는 내부적으로 epg2xml를 실행할 때 다음의 arguments -i {KT/SK/LG} -d를 썼으나 이제는 -i {KT/SK/LG} -o /epg2xml/xmltv.xml로 실행한 다음 cat /epg2xml/xmltv.xml로 불러온다. 중간에 파일로 저장하는 과정이 추가된 것이다.
    5. EPG를 /epg2xml/xmltv.xml에 한 번 저장하는 이유는 이 경로를 웹서버로 노출시켜 다른 앱에서도 가져다 쓰기 쉽게 하기 위함이다. php 내장 기능을 이용해 /epg2xml 폴더의 내용이 http://<tvheadend ip>:9983/으로 서비스 되므로, tvheadend가 실행되면서 주기적으로 파일로 저장해 놓은 EPG 정보를 http://<<tvheadend ip>:9983/xmltv.xml로 접속하여 쓸 수 있다. 원래는 tvhProxy를 위해 짜낸 기능이지만 여러모로 유용하게 사용할 수 있을 것이다.

    자주 묻는 질문

    문제가 발생하면 읽어보세요.

    ▶ ☞ ♠ 정보찾아 공유 드리며 출처는 링크 참조 바랍니다. https://11q.kr ♠ #정보, #웹에디터,#그누보드,#시노롤지,#홈페이지,#아미나빌드

    ,#pvr,#헤놀로지,#xpenology,#nas,#나스,#서버,#썸머노트,#댓글에디터,#u5pvr,#kodi,#배추스킨,#pdfviewer,#iptv,#서버,#홈씨어터,

    #토랜토,#torrent,#amina,#아니마빌드,#에디터,#나스,#nas

    뷰PDF add1,add2



    관련자료

    댓글 4

    shimss11q님의 댓글

    EPG Grabber 탭 아래 > General configuration 항목 >

    Update Channel Name, Number, Icon 이 체크 되어있는지 확인해 보시고 체크되어 있으면 해제하세요.

    아마도 그것이 체크되어 있는 것 같습니다만⋯.

    이 항목은 EPG 업데이트 시, EPG 내용에 따라 채널명, 채널번호, 아이콘을 변경하는 옵션입니다.


    전체 1,767 / 1 페이지
    게시물이 없습니다.(다음페이지로 이동 하세요)
    전체 1,767 / 1 페이지



    ♥간단_메모글♥


    최근글


    새댓글



    PHP 안에 HTML ☞ 홈페이지 화면갱신 시간은 ♨
    ▶ 2024-11-26 01:40:10

    오늘의 홈 현황


    • 현재 접속자♨ 290 명
    • 오늘 가입자※ 0 명
    • 어제 가입자※ 5 명
    • 주간 가입자※ 10 명
    • 오늘 방문자 1,164 명
    • 어제 방문자 3,486 명
    • 최대 방문자 13,042 명
    • 전체 방문자 4,814,564 명
    • 전체 게시물※ 8,862 개
    • 전체 댓글수※ 25,239 개
    • 전체 회원수 11,331 명

    QR코드


    ☞ QR코드 스캔은 kakao앱 자체 QR코드

    알림 0








    최신글↑