# Jellyfin in docker ###### guide-by-example ![logo](https://i.imgur.com/gSyMEvD.png) # Purpose & Overview Stream movies/tv-shows/music to a browser, or a [large selection of devices and services.](https://jellyfin.org/clients/) * [Official site](https://jellyfin.org/) * [Github](https://github.com/jellyfin/jellyfin) * [DockerHub](https://hub.docker.com/r/jellyfin/jellyfin/) Jellyfin if a free media system, an alternative to proprietary Plex.
The core server side is written in C#, web client in Javascript, and a number of other clients written in various languages and frameworks. Starting point for me was [this viggy96 repo](https://github.com/viggy96/container_config) # Files and directory structure ``` /mnt/ └── bigdisk/ ├── tv/ ├── movies/ └── music/ /home/ └── ~/ └── docker/ └── jellyfin/ ├── jellyfin_cache/ ├── jellyfin_config/ ├── transcodes/ ├── .env └── docker-compose.yml ``` * `/mnt/bigdisk/...` - a mounted media storage share * `jellyfin_cache/` - cache * `jellyfin_config/` - configuration * `transcodes/` - transcoded video storage * `.env` - a file containing environment variables for docker compose * `docker-compose.yml` - a docker compose file, telling docker how to run the containers You only need to provide the two files.
The directories are created by docker compose on the first run. # docker-compose The media are mounted in read only mode. `docker-compose.yml` ```yml services: jellyfin: image: jellyfin/jellyfin:latest container_name: jellyfin hostname: jellyfin restart: unless-stopped env_file: .env devices: - /dev/dri volumes: - ./transcodes/:/transcodes - ./jellyfin_config:/config - ./jellyfin_cache:/cache - /mnt/bigdisk/serialy:/media/video:ro - /mnt/bigdisk/mp3/moje:/media/music:ro ports: - "8096:8096" - "1900:1900/udp" networks: default: name: $DOCKER_MY_NETWORK external: true ``` `.env` ```bash # GENERAL DOCKER_MY_NETWORK=caddy_net TZ=Europe/Bratislava ``` **All containers must be on the same network**.
Which is named in the `.env` file.
If one does not exist yet: `docker network create caddy_net` # Reverse proxy Caddy is used, details [here](https://github.com/DoTheEvo/selfhosted-apps-docker/tree/master/caddy_v2).
`Caddyfile` ``` jellyfin.{$MY_DOMAIN} { reverse_proxy jellyfin:8096 } ``` # First run ![interface-pic](https://i.imgur.com/pZMi6bb.png) # Specifics of my setup * no real long term use * findroid app does not jump subtitles like official one * amd cpu and no gpu, so no experience with hw transcoding * media files are stored and shared on trunas scale VM and mounted directly on the docker host using [systemd mounts](https://forum.manjaro.org/t/root-tip-systemd-mount-unit-samples/1191), instead of fstab or autofs. `/etc/systemd/system/mnt-bigdisk.mount` ```ini [Unit] Description=12TB truenas mount [Mount] What=//10.0.19.19/Dataset-01 Where=/mnt/bigdisk Type=cifs Options=ro,username=ja,password=qq,file_mode=0700,dir_mode=0700,uid=1000 DirectoryMode=0700 [Install] WantedBy=multi-user.target ``` `/etc/systemd/system/mnt-bigdisk.automount` ```ini [Unit] Description=12TB truenas mount [Automount] Where=/mnt/bigdisk [Install] WantedBy=multi-user.target ``` to automount on boot - `sudo systemctl enable mnt-bigdisk.automount` # Troubleshooting ![error-pic](https://i.imgur.com/KQhmZTQ.png) *We're unable to connect to the selected server right now. Please ensure it is running and try again.* If you encounter this, try opening the url in browsers private window.
If it works then clear the cookies in your browser. *No playback at all but GUI works fine* Might be no access to network share, for example if dockerhost boots up faster than NAS. # Update Manual image update: - `docker-compose pull`
- `docker-compose up -d`
- `docker image prune` # Useful * https://www.reddit.com/r/selfhosted/comments/1bit5xr/livetv_on_jellyfin_2024/