docker 이용 tvheadend backup 백업 복원하기
♨ 카랜더 일정 :
본문
■ 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) 도커의 비디오형식 설정 내보내기/가져오기
http://192.168.0.6/epg2xml/xmltv.xml
을 실행을 위하여 web폴더에 epg2xml폴더 카피 합니다.
설치 정보
https://github.com/wiserain/docker-tvheadend/tree/epgkr#%ED%99%98%EA%B2%BD%EB%B3%80%EC%88%98
docker-tvheadend
다음의 특징을 가지는 docker-tvheadend 이미지
linuxserver/tvheadend 기반: 다양한 docker용 앱 이미지를 제작/배포하고 있는 linuxserver.io의 소스를 기반으로 한다. 차이점은 tvheadend 빌드 옵션 중
--disable-*_static
을 제거하여 좀 더 나은 transcoding이 가능하게 한다. 또한 본 이미지는x86_64
기반이다.대한민국 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 버전 참고
- vaapi:
latest 빌드에서 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의 동작을 제어하는 환경변수와 가능한 옵션을 설명한다. 참고로 환경변수는 컨테이너 생성 시점에 그 값이 고정 되므로 변경을 원한다면 컨테이너를 삭제/재생성 해야한다. 먼저 필수로 지정해야하는 환경변수=기본값
는 다음과 같다.
PUID
,PGUI
: 컨테이너 내부의 앱이 외부의 볼륨에 접근할 수 있도록 하는 권한에 대한 것이다. 여기를 참고하여 설정한다. 적절하게 설정하지 않으면, 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:9981
: tvhProxy는 tvheadend의 영상 스트림을 Plex의 DVR (녹화)에서 활용할 수 있도록 도와주는 프록시이다. tvheadend와 같이 내장했으므로 localhost가 맞고 그 외 username, password, port는 자신의 환경에 맞게 수정해서 사용한다.
어쩌면 도움이 될지도 모르는 정보
- 컨테이너를 시작할 때마다
/etc/cont-init.d/
와/etc/services.d/
안의 스크립트를 이용해서 초기화를 진행하고 프로그램을 실행한다. 무슨 일이 일어났는지 궁금하거나 생각대로 되지 않으면 로그를 확인하자. - epg2xml 동작 언어는 php이다. 성능은 python이 약간 좋지만 그 차이가 미미한 반면, docker로 deploy할 때 php가 꽤 유용한 기능을 제공한다.
epg2xml.json
은 경로에 파일이 없는 경우에만 다운로드하여 설치하고 경로에 있으면 원래 것을 보존한다. 따라서 같이 업데이트하고 싶으면 파일들을 지우고 컨테이너 삭제/생성/실행하면 된다. 그것도 싫으면 그냥 수동으로 받아서 복사/붙여넣기 하면 된다.- 예전에는 내부적으로 epg2xml를 실행할 때 다음의 arguments
-i {KT/SK/LG} -d
를 썼으나 이제는-i {KT/SK/LG} -o /epg2xml/xmltv.xml
로 실행한 다음cat /epg2xml/xmltv.xml
로 불러온다. 중간에 파일로 저장하는 과정이 추가된 것이다. - 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 1,2
office view
관련자료
-
링크
-
첨부
댓글목록
shimss11q님의 댓글
shimss11q 쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 아이피 (192.♡.0.1) 작성일
EPG Grabber 탭 아래 > General configuration 항목 >
Update Channel Name, Number, Icon 이 체크 되어있는지 확인해 보시고 체크되어 있으면 해제하세요.
아마도 그것이 체크되어 있는 것 같습니다만⋯.
이 항목은 EPG 업데이트 시, EPG 내용에 따라 채널명, 채널번호, 아이콘을 변경하는 옵션입니다.
돌돌이아빠님의 댓글
돌돌이아빠 쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 아이피 (112.♡.5.46) 작성일
감사합니다.^^
도레미님의 댓글
도레미 쪽지보내기 자기소개 아이디로 검색 전체게시물 아이피 (211.♡.70.113) 작성일
감사합니다.
♥간단_메모글♥
-
등록일 04.15가입 인사드립니다.댓글 6
-
등록일 04.09가입인사.댓글 4
-
등록일 03.03안녕하세여댓글 1
-
등록일 02.13
최근글
-
등록일 12:53
새댓글
-
등록자 작은꼬마hw 등록일 22:52
-
등록자 진수수 등록일 11.24
-
등록자 개치토 등록일 11.24
-
등록자 알린이알리바바 등록일 11.24
오늘의 홈 현황
QR코드
☞ QR코드 스캔은 kakao앱 자체 QR코드