diff --git a/Conversion FLAC vers MP3/flac_to_mp3.sh b/Conversion FLAC vers MP3/flac_to_mp3.sh new file mode 100644 index 0000000..69a9b51 --- /dev/null +++ b/Conversion FLAC vers MP3/flac_to_mp3.sh @@ -0,0 +1,11 @@ +## Discord Plex FR : https://discord.gg/3gtABCH +## Version 2021-08-26 +## +## Pour une aide à l'installation, consulter le README +## +#!/bin/bash + +while read FILE ; do + [[ -e ${FILE%%.*}.mp3 ]] || ffmpeg -i "$FILE" -ab 320k -map_metadata 0 "${FILE%.*}.mp3" + [[ $? -eq 0 ]] && rm $FILE +done < <(find . -name "*.flac") \ No newline at end of file diff --git a/Conversion FLAC vers MP3/readme.md b/Conversion FLAC vers MP3/readme.md new file mode 100644 index 0000000..51aa45e --- /dev/null +++ b/Conversion FLAC vers MP3/readme.md @@ -0,0 +1,6 @@ +Conversion FLAC vers MP3 +======== + +Ce script permet la conversion de vos flacs en MP3 320kbps de manière automatique. + +ATTENTION : Les fichiers flacs sont supprimées quand la conversion à réussie. \ No newline at end of file diff --git a/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/.env b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/.env new file mode 100644 index 0000000..6d805a0 --- /dev/null +++ b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/.env @@ -0,0 +1,9 @@ +PUID=1000 +GUID=100 +TZ=Europe/Paris + +DISPLAY_WIDTH=1280 +DISPLAY_HEIGHT=768 + +RACINE=/volume1/docker/edition-videos +STORAGE=/storage \ No newline at end of file diff --git a/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/docker-compose.yml b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/docker-compose.yml new file mode 100644 index 0000000..a9c201e --- /dev/null +++ b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/docker-compose.yml @@ -0,0 +1,115 @@ +## Discord Plex FR : https://discord.gg/3gtABCH +## Version 2021-08-23 +## +## Pour une aide à l'installation, consulter le README +## +version: '3' + +services: + handbrake: + image: jlesage/handbrake:latest + container_name: edition-video_handbrake +# labels: +# - com.centurylinklabs.watchtower.enable=true + networks: + - edition-videos-network + environment: + - USER_ID=${PUID} + - GROUP_ID=${PGID} + - TZ=${TZ} + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - "6800:5800" + volumes: + - "${RACINE}/handbrake/config:/config:rw" + - "${RACINE}/handbrake/watch:/watch:rw" + - "${RACINE}/handbrake/output:/output:rw" + - "${STORAGE}:/storage:ro" + restart: unless-stopped + + mediainfo: + image: jlesage/mediainfo:latest + container_name: edition-video_mediainfo +# labels: +# - com.centurylinklabs.watchtower.enable=true + networks: + - edition-videos-network + environment: + - USER_ID=${PUID} + - GROUP_ID=${PGID} + - TZ=${TZ} + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - 6801:5800 + volumes: + - "${RACINE}/mediainfo/config:/config:rw" + - "${STORAGE}:/storage:ro" + restart: unless-stopped + + avidemux: + image: jlesage/avidemux:latest + container_name: edition-video_avidemux +# labels: +# - com.centurylinklabs.watchtower.enable=true + networks: + - edition-videos-network + environment: + - USER_ID=${PUID} + - GROUP_ID=${PGID} + - TZ=${TZ} + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - 6802:5800 + volumes: + - "${RACINE}/avidemux/config:/config:rw" + - "${STORAGE}:/storage:rw" + restart: unless-stopped + + makemkv: + image: jlesage/makemkv:latest + container_name: edition-video_makemkv +# labels: +# - com.centurylinklabs.watchtower.enable=true + networks: + - edition-videos-network + environment: + - USER_ID=${PUID} + - GROUP_ID=${PGID} + - TZ=${TZ} + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - 6803:5800 + volumes: + - "${RACINE}/makemkv/config:/config:rw" + - "${RACINE}/makemkv/output:/output:rw" + - "${STORAGE}:/storage:ro" + restart: unless-stopped + + mkvtoolnix: + image: jlesage/mkvtoolnix:latest + container_name: edition-video_mkvtoolnix +# labels: +# - com.centurylinklabs.watchtower.enable=true + networks: + - edition-videos-network + environment: + - USER_ID=${PUID} + - GROUP_ID=${PGID} + - TZ=${TZ} + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - 6804:5800 + volumes: + - "${RACINE}/makemkv/config:/config:rw" + - "${STORAGE}:/storage:ro" + restart: unless-stopped + +networks: + edition-videos-network: + external: + name: edition-videos-network diff --git a/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/readme.md b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/readme.md new file mode 100644 index 0000000..d7ee4d0 --- /dev/null +++ b/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/readme.md @@ -0,0 +1,135 @@ +Installation de la stack "Édition-Vidéos" +============ + +Bienvenue sur mon nouveau tutoriel. Celui-ci, je l'espere va vous apprendre à installer Handbrake, Mediainfo, Avidemux, MakeMKV et MKVToolNix simplement via docker. + +Cette stack docker-compose contient les logiciels suivants : +| Nom du service | Site Officiel | Dépot utilisé* | +| ------ | ------ | ------ | +| Handbrake | [Handbrake.fr](https://handbrake.fr/) | [jlesage](https://github.com/jlesage/docker-handbrake) | +| Mediainfo | [MediaArea](https://mediaarea.net/fr/MediaInfo) | [jlesage](https://github.com/jlesage/docker-mediainfo) | +| Avidemux | [Fixounet](http://fixounet.free.fr/avidemux/) | [jlesage](https://github.com/jlesage/docker-avidemux) | +| MakeMKV | [GuinpinSoft](http://makemkv.com/) | [jlesage](https://github.com/jlesage/docker-makemkv) | +| MKVToolNix | [Moritz Bunkus](https://mkvtoolnix.download/) | [jlesage](https://github.com/jlesage/docker-mkvtoolnix) | + +## Table des matières +- 1. [Prérequis](#1-prérequis) + - 1.a [Création des dossiers](#1-a-création-des-dossiers) + - 1.b [Modifications du .env](#1-b-modifications-du-env) + - 1.c [Transfert des fichiers dans /edition-videos](#1-c-transfert-des-fichiers-dans-edition-videos) +- 2. [Création des conteneurs](#2-création-des-conteneurs) + - 2.a [Création du réseau](#2-a-création-du-réseau) + - 2.b [Création des conteneurs](#2-b-création-des-conteneurs) +- 3. [Les Bases](#3-les-bases) + - 3.a [Commandes de bases ( Docker )](#3-a-commandes-de-bases-docker) + - 3.b [Accès aux interfaces ( WebUI )](#3-b-accès-aux-interfaces-webui) +- 4. Dépannage ( Ce construira au fur et a mesure des questions ) + +## 1. Prérequis + +- Cette stack est concu pour fonctionner dans un dossier `edition-videos`, avec l'architecture suivante : +``` +edition-videos ---- handbrake ------- config + | |_ watch + | |_ output + | + |-- mediainfo ------ config + | + |-- avidemux ------- config + | + |-- makemkv -------- config + | |_ output + | + |-- mkvtoolnix ----- config +``` + +- Dans le paragraphe 1.a nous allons les créer avec une ligne de commande, et dans le paragraphe 1.b nous allons modifier le .env afin qu'il utilise bien ces dossiers ( en fonction de leurs localisation sur votre machine ). + +### 1.a. Création des dossiers + +- Avec `cd` aller dans le dossier de votre choix, par exemple "docker". +Exemple : Si votre dossier "docker" ce trouve dans /volume1, alors la commande sera : +`cd /volume1/docker` + +- Maintenant que nous sommes dans le bon dossier, nous allons executer la commande suivante pour créer d'un coup, toute l'architecture nécessaire : + +`mkdir -p edition-videos/handbrake/{config,watch,output} edition-videos/mediainfo/config edition-videos/avidemux/config edition-videos/makemkv/{config,output} edition-videos/mkvtoolnix/config` + +### 1.b. Modifications des .env +- Récupérer sur votre machine les fichiers [.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/src/branch/master/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/.env) et [docker-compose.yml](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/src/branch/master/docker-compose/handbrake-mediainfo-avidemux-makemkv-mkvtoolnix/docker-compose.yml). + +> Vous pouvez faire un clic droit - Enregistrer sous ... sur les liens ci-dessus pour télécharger les fichiers. + +- Dans le fichier `.env` vous allez devoir modifier plusieurs chose : + +**PUID et PGID** devront correspondre aux ID de votre utilisateurs, plus d'info ici : [Connaitre le PUID / PGID d'un utilisateur](https://www.forum-nas.fr/viewtopic.php?f=56&t=13213) + +**RACINE** correspond au chemin vers le dossier edition-videos créé a l'étape 1.a. +Dans ce cas, c'est : `/volume1/docker/edition-videos` + +**RACINE** correspond au chemin vers votre dossiers de médias. +Dans ce cas, c'est : `/storage` + + +### 1.c Transfert des fichiers dans /edition-videos +- Une fois les modifications effectuées, il faut transfert tous les fichiers ( .env et docker-compose.yml ) dans le dossier `/edition-videos` précédemment créé ! Par exemple, avec FileZilla. + +## 2. Création des conteneurs +### 2.a Création du réseau +- On créé le reseau `edition-videos-network` necesaire au fonctionnement du conteneurs VPN : + +``` +docker network create edition-videos-network +``` + +### 2.b Création des conteneurs +Maintenant que votre "stack" est prete rendez-vous dans le dossier `edition-videos`, dans mon cas `/volume1/docker/edition-videos` : +``` +cd /volume1/docker/edition-videos +``` + +## 3. Les Bases +Il est possible d'utilise n'importe qu'elle interface de gestion de conteneur*, ou SSH. + +Voici quelques commandes de base : + +**[Portainer](https://www.forum-nas.fr/viewtopic.php?f=56&t=14030) par exemple.* + +### 3.a Commandes de bases ( Docker ) +- Arreter un conteneur : `docker stop ` +Exemple pour le conteneur **edition-video_handbrake** : `docker stop edition-video_handbrake` + +- Redémarrer un conteneur : `docker restart ` +Exemple pour le conteneur **edition-video_handbrake** : `docker restart edition-video_handbrake` + +- Démarrer un conteneur : `docker start ` +Exemple pour le conteneur **edition-video_handbrake** : `docker start edition-video_handbrake` + +- Supprimer un conteneur : `docker rm ` +Exemple pour le conteneur **edition-video_handbrake** : `docker rm edition-video_handbrake` + +- Créer / Mettre à jour la "stack" : `docker-compose up -d` +Cette commande permet de créer la stack présent dans le fichier docker-compose.yml, les conteneurs non-existant seront créés, les modifiés seront mis à jour. +> Note : Vous devez etre dans la dossier contenant le fichier docker-compose.yml pour que cette commande fonctionne. + +### 3.b Accès aux interfaces ( WebUI ) + +- L'acces à chaque service se fait via une WebUI ( Interface Web ), sur un port quil lui est propre. +- Pour Handbrake, c'est le port `6800`. Donc l'adresse sera sous la forme : `http://IP_DE_LA_MACHINE:6800` +Exemple : Si l'adresse IP de votre machine est `192.168.1.10`, alors l'adresse d'accès sera : `http://192.168.1.10:6800` + +- Ci-dessus la liste des ports des interfaces de chaque service : +| Service | Port | +| ------ | ------ | +| Handbrake | 6800 | +| Mediainfo | 6801 | +| Avidemux | 6802 | +| MakeMKV | 6803 | +| MKVToolNix | 6804 | + +## 6. Aller plus loin +- Retrouvez ici des astuces pour aller "un peu plus loin" dans la configurations de vos conteneurs, avec par exemple, la méthode pour rajouter des montages ( dossier de votre serveur dans le conteneur ), ou régler la mise à jour automatique de vos conteneurs. + +/!\ Depuis l'interface SSH, les commandes ci-dessous sont à executer en étant à la racine de votre dossier `edition-videos`. + +A VENIR ... diff --git a/docker-compose/jellyfin-embystat/.env b/docker-compose/jellyfin-embystat/.env new file mode 100644 index 0000000..87cd764 --- /dev/null +++ b/docker-compose/jellyfin-embystat/.env @@ -0,0 +1,6 @@ +PUID=1000 +PGID=100 +TZ=Europe/Paris + +RACINE=/volume1/docker +DATA=/volume1/data \ No newline at end of file diff --git a/docker-compose/jellyfin-embystat/docker-compose.yml b/docker-compose/jellyfin-embystat/docker-compose.yml index 81a0cb3..ac52780 100644 --- a/docker-compose/jellyfin-embystat/docker-compose.yml +++ b/docker-compose/jellyfin-embystat/docker-compose.yml @@ -1,56 +1,46 @@ ## Discord Plex FR : https://discord.gg/3gtABCH -## Version 2021-08-23 +## Version 2021-08-29 version: '2.1' services: jellyfin: image: ghcr.io/linuxserver/jellyfin container_name: jellyfin -# Decommenter les 2 lignes suivantes pour que watchtower surveille ce conteneur # labels: # - com.centurylinklabs.watchtower.enable=true environment: - - PUID=1000 # Utiliser la commande (en SSH) : id NOM_UTILISATEUR - - PGID=100 # Utiliser la commande (en SSH) : id NOM_UTILISATEUR - - TZ=Europe/Paris -# Utiliser la commande suivant pour limiter l'usage de la RAM -# mem_limit: 4096M -# Decommenter les 2 lignes suivantes pour activer le transcodage matériel iGPU( si NAS/serveur compatible ) + - PUID=${PUID} + - PGID=${PGID} + - TZ=${TZ} # devices: # - /dev/dri:/dev/dri -# Network conseillé de ne pas utiliser host (pas de redirection de port) ni default_bridge car limité a 16 ip networks: - - 'jellyfin_network' #si modification changer la ligne 45 + - jellyfin_embystat_network ports: - - 8096:8096 # WebUI + - 8096:8096 volumes: - - /volume1/docker/jellyfin/config:/config - - /volume1/media/music:/data/music - - /volume1/media/movies:/data/movies - - /volume1/media/tvshow:/data/tvshow + - ${RACINE}/jellyfin/config:/config + - ${DATA}/jellyfin/config:/data restart: unless-stopped embystat: image: ghcr.io/linuxserver/embystat container_name: embystat -# Decommenter les 2 lignes suivantes pour que watchtower surveille ce conteneur # labels: # - com.centurylinklabs.watchtower.enable=true environment: - - PUID=1000 # Utiliser la commande (en SSH) : id NOM_UTILISATEUR - - PGID=100 # Utiliser la commande (en SSH) : id NOM_UTILISATEUR - - TZ=Europe/Paris -# Network conseillé de ne pas utiliser host (pas de redirection de port) ni default_bridge car limité a 16 ip + - PUID=${PUID} + - PGID=${PGID} + - TZ=${TZ} networks: - - 'jellyfin_network' #si modification de la ligne 23 + - jellyfin_embystat_network volumes: - - /volume1/docker/embystat/config:/config + - ${RACINE}/embystat/config:/config ports: - - 6555:6555 # WebUI + - 6555:6555 restart: unless-stopped networks: - jellyfin_network: + jellyfin_embystat_network: external: -# Network conseillé de ne pas utiliser host (pas de redirection de port) ni default_bridge car limité a 16 ip - name: 'jellyfin_network' #si modification de la ligne 23 et 45 + name: jellyfin_embystat_network \ No newline at end of file diff --git a/docker-compose/jellyfin-embystat/readme.md b/docker-compose/jellyfin-embystat/readme.md new file mode 100644 index 0000000..20275d1 --- /dev/null +++ b/docker-compose/jellyfin-embystat/readme.md @@ -0,0 +1,117 @@ +Installation de la stack "Jellyfin-EmbyStat" +============ + +Bienvenue sur mon nouveau tutoriel. Celui-ci, je l'espere va vous apprendre à installer Jellyfin et EmbyStat simplement via docker. + +Cette stack docker-compose contient les logiciels suivants : +| Nom du service | Site Officiel | Dépot utilisé* | +| ------ | ------ | ------ | +| Jellyfin | [Jellyfin](https://jellyfin.org/) | [Linuxserver](https://github.com/linuxserver/docker-jellyfin) | +| EmbyStat | [EmbyStat](https://github.com/mregni/EmbyStat) | [Linuxserver](https://github.com/linuxserver/docker-embystat) | + +## Table des matières +- 1. [Prérequis](#1-prérequis) + - 1.a [Création des dossiers](#1-a-création-des-dossiers) + - 1.b [Modifications du .env](#1-b-modifications-du-env) + - 1.c [Transfert des fichiers dans /jellyfin_embystat](#1-c-transfert-des-fichiers-dans-jellyfin-embystat) +- 2. [Création des conteneurs](#2-création-des-conteneurs) + - 2.a [Création du réseau](#2-a-création-du-réseau) + - 2.b [Création des conteneurs](#2-b-création-des-conteneurs) +- 3. [Les Bases](#3-les-bases) + - 3.a [Commandes de bases ( Docker )](#3-a-commandes-de-bases-docker) + - 3.b [Accès aux interfaces ( WebUI )](#3-b-accès-aux-interfaces-webui) +- 4. Dépannage ( Ce construira au fur et a mesure des questions ) + +## 1. Prérequis + +- Cette stack est concu pour fonctionner dans un dossier `jellyfin_embystat`, avec l'architecture suivante : +``` +jellyfin_embystat ---- jellyfin ------- config + | + |-- embystat ------- config +``` + +- Dans le paragraphe 1.a nous allons les créer avec une ligne de commande, et dans le paragraphe 1.b nous allons modifier le .env afin qu'il utilise bien ces dossiers ( en fonction de leurs localisation sur votre machine ). + +### 1.a. Création des dossiers + +- Avec `cd` aller dans le dossier de votre choix, par exemple "docker". +Exemple : Si votre dossier "docker" ce trouve dans /volume1, alors la commande sera : +`cd /volume1/docker` + +- Maintenant que nous sommes dans le bon dossier, nous allons executer la commande suivante pour créer d'un coup, toute l'architecture nécessaire : + +`mkdir -p jellyfin_embystat/jellyfin/config jellyfin_embystat/embystat/config` + +### 1.b. Modifications des .env +- Récupérer sur votre machine les fichiers [.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/jellyfin-embystat/.env) et [docker-compose.yml](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/jellyfin-embystat/docker-compose.yml). + +> Vous pouvez faire un clic droit - Enregistrer sous ... sur les liens ci-dessus pour télécharger les fichiers. + +- Dans le fichier `.env` vous allez devoir modifier plusieurs chose : + +**PUID et PGID** devront correspondre aux ID de votre utilisateurs, plus d'info ici : [Connaitre le PUID / PGID d'un utilisateur](https://www.forum-nas.fr/viewtopic.php?f=56&t=13213) + +**RACINE** correspond au chemin vers le dossier jellyfin_embystat créé a l'étape 1.a. +Dans ce cas, c'est : `/volume1/docker/jellyfin_embystat` + +**DATA** correspond au chemin vers votre dossiers de médias. +Dans ce cas, c'est : `/volume1/data` + + +### 1.c Transfert des fichiers dans /jellyfin_embystat +- Une fois les modifications effectuées, il faut transfert tous les fichiers ( .env et docker-compose.yml ) dans le dossier `/jellyfin_embystat` précédemment créé ! Par exemple, avec FileZilla. + +## 2. Création des conteneurs +### 2.a Création du réseau +- On créé le reseau `jellyfin_embystat_network` necesaire au fonctionnement du conteneurs VPN : + +``` +docker network create jellyfin_embystat_network +``` + +### 2.b Création des conteneurs +Maintenant que votre "stack" est prete rendez-vous dans le dossier `jellyfin_embystat`, dans mon cas `/volume1/docker/jellyfin_embystat` : +``` +cd /volume1/docker/jellyfin_embystat +``` + +## 3. Les Bases +Il est possible d'utilise n'importe qu'elle interface de gestion de conteneur*, ou SSH. + +Voici quelques commandes de base : + +**[Portainer](https://www.forum-nas.fr/viewtopic.php?f=56&t=14030) par exemple.* + +### 3.a Commandes de bases ( Docker ) +- Arreter un conteneur : `docker stop ` +Exemple pour le conteneur **jellyfin** : `docker stop jellyfin` + +- Redémarrer un conteneur : `docker restart ` +Exemple pour le conteneur **jellyfin** : `docker restart jellyfin` + +- Démarrer un conteneur : `docker start ` +Exemple pour le conteneur **jellyfin** : `docker start jellyfin` + +- Supprimer un conteneur : `docker rm ` +Exemple pour le conteneur **jellyfin** : `docker rm jellyfin` + +- Créer / Mettre à jour la "stack" : `docker-compose up -d` +Cette commande permet de créer la stack présent dans le fichier docker-compose.yml, les conteneurs non-existant seront créés, les modifiés seront mis à jour. +> Note : Vous devez etre dans la dossier contenant le fichier docker-compose.yml pour que cette commande fonctionne. + +### 3.b Accès aux interfaces ( WebUI ) + +- L'acces à chaque service se fait via une WebUI ( Interface Web ), sur un port quil lui est propre. +- Pour Jellyfin, c'est le port `8096`. Donc l'adresse sera sous la forme : `http://IP_DE_LA_MACHINE:8096` +Exemple : Si l'adresse IP de votre machine est `192.168.1.10`, alors l'adresse d'accès sera : `http://192.168.1.10:8096` + +- Ci-dessus la liste des ports des interfaces de chaque service : +| Service | Port | +| ------ | ------ | +| Jellyfin | 8096 | +| EmbyStat | 6555 | + +## 6. Dépannage +A VENIR ... + diff --git a/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/readme.md b/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/readme.md index 85b402d..b911424 100644 --- a/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/readme.md +++ b/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/readme.md @@ -87,7 +87,7 @@ Exemple : Si votre dossier "docker" ce trouve dans /volume1, alors la commande s `mkdir -p downloads-vpn/vpn/{config,scripts} downloads-vpn/rutorrent/{data,passwd,downloads} downloads-vpn/qbittorrent/{config,downloads} downloads-vpn/prowlarr/config downloads-vpn/sonarr/config downloads-vpn/radarr/config downloads-vpn/jackett/config downloads-vpn/lidarr/{config,music}` ### 1.b. Modifications des .env -- Récupérer sur votre machine les fichiers [.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/evo-stackdl/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/.env), [TUN.sh](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/evo-stackdl/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/TUN.sh), [docker-compose.yml](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/evo-stackdl/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/docker-compose.yml) et [rtorrent-rutorrent.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/evo-stackdl/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/rtorrent-rutorrent.env). +- Récupérer sur votre machine les fichiers [.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/.env), [TUN.sh](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/TUN.sh), [docker-compose.yml](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/docker-compose.yml) et [rtorrent-rutorrent.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/raw/branch/master/docker-compose/openvpn-rutorrent-prowlarr-jackett-flaresolver-radarr-sonarr/rtorrent-rutorrent.env). > Vous pouvez faire un clic droit - Enregistrer sous ... sur les liens ci-dessus pour télécharger les fichiers. diff --git a/docker-compose/plex-tautulli/.env b/docker-compose/plex-tautulli/.env new file mode 100644 index 0000000..87cd764 --- /dev/null +++ b/docker-compose/plex-tautulli/.env @@ -0,0 +1,6 @@ +PUID=1000 +PGID=100 +TZ=Europe/Paris + +RACINE=/volume1/docker +DATA=/volume1/data \ No newline at end of file diff --git a/docker-compose/plex-tautulli/docker-compose.yml b/docker-compose/plex-tautulli/docker-compose.yml new file mode 100644 index 0000000..a7c0ff6 --- /dev/null +++ b/docker-compose/plex-tautulli/docker-compose.yml @@ -0,0 +1,33 @@ +## Discord Plex FR : https://discord.gg/3gtABCH +## Version 2021-08-29 +version: '2.1' + +services: + plex: + image: ghcr.io/linuxserver/plex + container_name: plex +# labels: +# - com.centurylinklabs.watchtower.enable=true + network_mode: host + environment: + - PUID=${PUID} + - PGID=${PGID} + - VERSION=public +# devices: +# - /dev/dri:/dev/dri + volumes: + - ${RACINE}/plex/config:/config + - ${DATA}:/data + restart: unless-stopped + + tautulli: + image: ghcr.io/linuxserver/tautulli + container_name: tautulli + network_mode: host + environment: + - PUID=${PUID} + - PGID=${PGID} + - TZ=${TZ} + volumes: + - ${RACINE}/tautulli/config:/config + restart: unless-stopped \ No newline at end of file diff --git a/docker-compose/plex-tautulli/readme.md b/docker-compose/plex-tautulli/readme.md new file mode 100644 index 0000000..1c426c5 --- /dev/null +++ b/docker-compose/plex-tautulli/readme.md @@ -0,0 +1,117 @@ +Installation de la stack "Plex-Tautulli" +============ + +Bienvenue sur mon nouveau tutoriel. Celui-ci, je l'espere va vous apprendre à installer Plex et Tautulli simplement via docker. + +Cette stack docker-compose contient les logiciels suivants : +| Nom du service | Site Officiel | Dépot utilisé* | +| ------ | ------ | ------ | +| Plex | | [Linuxserver](https://github.com/linuxserver/docker-plex) | +| Tautulli | | [Linuxserver](https://github.com/linuxserver/docker-tautulli) | + +## Table des matières +- 1. [Prérequis](#1-prérequis) + - 1.a [Création des dossiers](#1-a-création-des-dossiers) + - 1.b [Modifications du .env](#1-b-modifications-du-env) + - 1.c [Transfert des fichiers dans /plex_tautulli](#1-c-transfert-des-fichiers-dans-plex-tautulli) +- 2. [Création des conteneurs](#2-création-des-conteneurs) + - 2.a [Création du réseau](#2-a-création-du-réseau) + - 2.b [Création des conteneurs](#2-b-création-des-conteneurs) +- 3. [Les Bases](#3-les-bases) + - 3.a [Commandes de bases ( Docker )](#3-a-commandes-de-bases-docker) + - 3.b [Accès aux interfaces ( WebUI )](#3-b-accès-aux-interfaces-webui) +- 4. Dépannage ( Ce construira au fur et a mesure des questions ) + +## 1. Prérequis + +- Cette stack est concu pour fonctionner dans un dossier `plex_tautulli`, avec l'architecture suivante : +``` +plex_tautulli -------- plex ------- config + | + |-- tautulli --- config +``` + +- Dans le paragraphe 1.a nous allons les créer avec une ligne de commande, et dans le paragraphe 1.b nous allons modifier le .env afin qu'il utilise bien ces dossiers ( en fonction de leurs localisation sur votre machine ). + +### 1.a. Création des dossiers + +- Avec `cd` aller dans le dossier de votre choix, par exemple "docker". +Exemple : Si votre dossier "docker" ce trouve dans /volume1, alors la commande sera : +`cd /volume1/docker` + +- Maintenant que nous sommes dans le bon dossier, nous allons executer la commande suivante pour créer d'un coup, toute l'architecture nécessaire : + +`mkdir -p plex_tautulli/plex/config plex_tautulli/tautulli/config` + +### 1.b. Modifications des .env +- Récupérer sur votre machine les fichiers [.env](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/src/branch/master/docker-compose/plex-tautulli/.env) et [docker-compose.yml](https://gitea.zoz-serv.org/Zoz/plex_fr_discord_repo/src/branch/master/docker-compose/plex-tautulli/docker-compose.yml). + +> Vous pouvez faire un clic droit - Enregistrer sous ... sur les liens ci-dessus pour télécharger les fichiers. + +- Dans le fichier `.env` vous allez devoir modifier plusieurs chose : + +**PUID et PGID** devront correspondre aux ID de votre utilisateurs, plus d'info ici : [Connaitre le PUID / PGID d'un utilisateur](https://www.forum-nas.fr/viewtopic.php?f=56&t=13213) + +**RACINE** correspond au chemin vers le dossier plex_tautulli créé a l'étape 1.a. +Dans ce cas, c'est : `/volume1/docker/plex_tautulli` + +**DATA** correspond au chemin vers votre dossiers de médias. +Dans ce cas, c'est : `/volume1/data` + + +### 1.c Transfert des fichiers dans /plex_tautulli +- Une fois les modifications effectuées, il faut transfert tous les fichiers ( .env et docker-compose.yml ) dans le dossier `/plex_tautulli` précédemment créé ! Par exemple, avec FileZilla. + +## 2. Création des conteneurs +### 2.a Création du réseau +- On créé le reseau `plex_tautulli_network` necesaire au fonctionnement du conteneurs VPN : + +``` +docker network create plex_tautulli_network +``` + +### 2.b Création des conteneurs +Maintenant que votre "stack" est prete rendez-vous dans le dossier `plex_tautulli`, dans mon cas `/volume1/docker/plex_tautulli` : +``` +cd /volume1/docker/plex_tautulli +``` + +## 3. Les Bases +Il est possible d'utilise n'importe qu'elle interface de gestion de conteneur*, ou SSH. + +Voici quelques commandes de base : + +**[Portainer](https://www.forum-nas.fr/viewtopic.php?f=56&t=14030) par exemple.* + +### 3.a Commandes de bases ( Docker ) +- Arreter un conteneur : `docker stop ` +Exemple pour le conteneur **plex** : `docker stop plex` + +- Redémarrer un conteneur : `docker restart ` +Exemple pour le conteneur **plex** : `docker restart plex` + +- Démarrer un conteneur : `docker start ` +Exemple pour le conteneur **plex** : `docker start plex` + +- Supprimer un conteneur : `docker rm ` +Exemple pour le conteneur **plex** : `docker rm plex` + +- Créer / Mettre à jour la "stack" : `docker-compose up -d` +Cette commande permet de créer la stack présent dans le fichier docker-compose.yml, les conteneurs non-existant seront créés, les modifiés seront mis à jour. +> Note : Vous devez etre dans la dossier contenant le fichier docker-compose.yml pour que cette commande fonctionne. + +### 3.b Accès aux interfaces ( WebUI ) + +- L'acces à chaque service se fait via une WebUI ( Interface Web ), sur un port quil lui est propre. +- Pour Plex, c'est le port `32400`. Donc l'adresse sera sous la forme : `http://IP_DE_LA_MACHINE:32400` +Exemple : Si l'adresse IP de votre machine est `192.168.1.10`, alors l'adresse d'accès sera : `http://192.168.1.10:32400` + +- Ci-dessus la liste des ports des interfaces de chaque service : +| Service | Port | +| ------ | ------ | +| Plex | 32400 | +| Tautulli | 8181 | + +## 6. Dépannage +A VENIR ... +