1
0
mirror of https://github.com/tiyn/wiki.git synced 2025-04-06 08:37:45 +02:00
wiki/wiki/docker/bbilly1_-_tubearchivist.md
2024-11-26 06:15:03 +01:00

4.8 KiB

bbilly1 - tubearchivist

This is a Docker container for a TubeArchivist server. The Server consists of 3 Docker containers, one is the TubeArchivist main server, another is a TubeArchivist specific version of Elasticsearch and one a redis instance.

Set-up

Create the files rebuild.sh and docker-compose.yml at the same place. Change the settings according to your needs and run ./rebuild.sh afterwards.

Environment-variables

Set the following environment-variables in the environment: section of the docker-compose file.

The following table lists the environment variables for the image bbilly1/tubearchivist.

Name Usage Default
ES_URL Network address for elastic search instance ``
REDIS_HOST Redis broker URL ``
HOST_UID User ID of Host ``
HOST_GID Group ID of Host ``
TA_HOST Domain name for TubeArchivist ``
TA_USERNAME User name for TubeArchivist ``
TA_PASSWORD Password for TubeArchivist ``
ELASTIC_PASSWORD Password for Elasticsearch ``
TZ Timezone ``

The following table lists the environment variables for the image bbilly1/tubearchivist-es.

Name Usage Default
ELASTIC_PASSWORD Password for Elasticsearch ``
ES_JAVA_OPTS Additional Java options ``

Volumes

Set the following volumes in the volumes: section of the docker-compose file.

The following table lists the environment variables for the image bbilly1/tubearchivist.

Outside mount/volume name Container mount Description
media /youtube storage for media
cache /cache storage for cache

The following table lists the environment variables for the image bbilly1/tubearchivist-es.

Outside mount/volume name Container mount Description
es /usr/share/elasticsearch/data storage for elasticsearch

Ports

Set the following ports in the ports: section.

Container Port Recommended outside port Protocol Description
8000 8881 TCP WebUI

rebuild.sh

#!/bin/sh
docker-compose down
docker-compose up -d

docker-compose.yml

version: '3.3'

services:
  ta:
    restart: unless-stopped
    image: bbilly1/tubearchivist
    ports:
      - 8881:8000
    volumes:
      - media:/youtube
      - cache:/cache
    environment:
      - ES_URL=http://es:9200     # needs protocol e.g. http and port
      - REDIS_HOST=redis          # don't add protocol
      - HOST_UID=1000
      - HOST_GID=1000
      - TA_HOST=subdomain.domain.tld        # set your host name
      - TA_USERNAME=admin                   # your initial TA credentials
      - TA_PASSWORD=admin                   # your initial TA credentials
      - ELASTIC_PASSWORD=verysecret         # set password for Elasticsearch
      - TZ=Europe/Berlin                    # set your time zone
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
      interval: 2m
      timeout: 10s
      retries: 3
    depends_on:
      - es
      - redis
  redis:
    image: redis/redis-stack-server
    restart: unless-stopped
    volumes:
      - redis:/data
    depends_on:
      - es
  es:
    image: bbilly1/tubearchivist-es         # only for amd64, or use official es 8.9.0
    restart: unless-stopped
    environment:
      - "ELASTIC_PASSWORD=verysecret"       # matching Elasticsearch password
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
      - "xpack.security.enabled=true"
      - "discovery.type=single-node"
      - "path.repo=/usr/share/elasticsearch/data/snapshot"
    ulimits:
      memlock:
        soft: -1
        hard: -1
    volumes:
      - es:/usr/share/elasticsearch/data    # check for permission error when using bind mount, see readme

volumes:
  media:
  cache:
  redis:
  es: