update invidious config
This commit is contained in:
parent
d6cd60fed2
commit
7d2d61a121
12 changed files with 122 additions and 645 deletions
|
@ -1,45 +0,0 @@
|
||||||
# Docker compose file for Backend 2 of inv.nadeko.net
|
|
||||||
|
|
||||||
x-labels: &labels
|
|
||||||
labels: [ "com.centurylinklabs.watchtower.scope=invidious" ]
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
deploy:
|
|
||||||
replicas: 4
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
environment:
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
INVIDIOUS_REDIS_URL: "tcp://valkey:6379"
|
|
||||||
depends_on:
|
|
||||||
- haproxy
|
|
||||||
<<: *labels
|
|
||||||
|
|
||||||
# Without depends because haproxy is smart
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:10070:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:10074:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious-2
|
|
|
@ -1,108 +0,0 @@
|
||||||
# Docker compose file for Backend 2 of inv.nadeko.net
|
|
||||||
|
|
||||||
#https://docs.docker.com/reference/compose-file/fragments/
|
|
||||||
x-common-config: &common-config
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
network_mode: "service:gluetun"
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
depends_on:
|
|
||||||
gluetun:
|
|
||||||
condition: service_healthy
|
|
||||||
# ptgen:
|
|
||||||
# condition: service_started
|
|
||||||
haproxy:
|
|
||||||
condition: service_started
|
|
||||||
environment: &env
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
# INVIDIOUS_TOKENS_SERVER: http://gluetun:7070
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3000"
|
|
||||||
|
|
||||||
invidious2:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3001"
|
|
||||||
|
|
||||||
invidious3:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3002"
|
|
||||||
|
|
||||||
invidious4:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3003"
|
|
||||||
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: unless-stopped
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:10070:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:10074:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
networks:
|
|
||||||
gluetun_network:
|
|
||||||
depends_on:
|
|
||||||
- gluetun
|
|
||||||
|
|
||||||
gluetun:
|
|
||||||
image: qmcgaw/gluetun
|
|
||||||
restart: unless-stopped
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
cap_add:
|
|
||||||
- NET_ADMIN
|
|
||||||
devices:
|
|
||||||
- /dev/net/tun:/dev/net/tun
|
|
||||||
volumes:
|
|
||||||
- ./gluetun:/gluetun
|
|
||||||
environment:
|
|
||||||
- VPN_SERVICE_PROVIDER=mullvad
|
|
||||||
- VPN_TYPE=wireguard
|
|
||||||
- WIREGUARD_PRIVATE_KEY="${WIREGUARD_KEY}"
|
|
||||||
- WIREGUARD_ADDRESSES="${WIREGUARD_ADDRESSES}"
|
|
||||||
- SERVER_HOSTNAMES="${SERVER_HOSTNAMES}"
|
|
||||||
- DNS_KEEP_NAMESERVER=on
|
|
||||||
networks:
|
|
||||||
gluetun_network:
|
|
||||||
|
|
||||||
# ptgen:
|
|
||||||
# image: git.nadeko.net/fijxu/youtube-po-token-generator:latest
|
|
||||||
# cpus: 0.1
|
|
||||||
# restart: unless-stopped
|
|
||||||
# network_mode: "service:gluetun"
|
|
||||||
# environment:
|
|
||||||
# - PORT=7070
|
|
||||||
# depends_on:
|
|
||||||
# - gluetun
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious-vpn
|
|
||||||
gluetun_network:
|
|
||||||
external: true
|
|
||||||
|
|
||||||
|
|
|
@ -1,44 +0,0 @@
|
||||||
global
|
|
||||||
# This because haproxy is dumb and likes to use the maxconnection from the kernel and that is super mega huge making haproxy oom
|
|
||||||
maxconn 8192
|
|
||||||
# 777 perms for all sockets
|
|
||||||
unix-bind mode 777
|
|
||||||
stats socket ipv4@0.0.0.0:8405 level admin
|
|
||||||
|
|
||||||
resolvers docker
|
|
||||||
# To be able to use multiple replicas of invidious
|
|
||||||
# using domains
|
|
||||||
nameserver dns1 127.0.0.11:53
|
|
||||||
|
|
||||||
defaults
|
|
||||||
mode http
|
|
||||||
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
|
|
||||||
# Use another server if one takes too long to reply
|
|
||||||
retries 2
|
|
||||||
option redispatch
|
|
||||||
timeout client 30s
|
|
||||||
timeout connect 30s
|
|
||||||
timeout server 120s
|
|
||||||
timeout queue 10s
|
|
||||||
http-reuse always
|
|
||||||
|
|
||||||
# Prometheus for graphs
|
|
||||||
frontend prometheus
|
|
||||||
bind *:8404
|
|
||||||
mode http
|
|
||||||
http-request use-service prometheus-exporter if { path /metrics }
|
|
||||||
no log
|
|
||||||
|
|
||||||
frontend invidious
|
|
||||||
bind *:8001
|
|
||||||
default_backend invidious
|
|
||||||
|
|
||||||
backend invidious
|
|
||||||
balance roundrobin
|
|
||||||
server-template invidious 8 invidious:3000 check resolvers docker init-addr libc,none
|
|
||||||
# server invidious-1-vpn gluetun:3000 check init-addr libc,none
|
|
||||||
# server invidious-2-vpn gluetun:3001 check init-addr libc,none
|
|
||||||
# server invidious-3-vpn gluetun:3002 check init-addr libc,none
|
|
||||||
# server invidious-4-vpn gluetun:3003 check init-addr libc,none
|
|
||||||
# server invidious-5-vpn gluetun:3004 check init-addr libc,none
|
|
||||||
# server invidious-6-vpn gluetun:3005 check init-addr libc,none
|
|
|
@ -1,45 +0,0 @@
|
||||||
# Docker compose file for Backend 3 of inv.nadeko.net
|
|
||||||
|
|
||||||
x-labels: &labels
|
|
||||||
labels: [ "com.centurylinklabs.watchtower.scope=invidious" ]
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
deploy:
|
|
||||||
replicas: 4
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
environment:
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
INVIDIOUS_REDIS_URL: "tcp://valkey:6379"
|
|
||||||
depends_on:
|
|
||||||
- haproxy
|
|
||||||
<<: *labels
|
|
||||||
|
|
||||||
# Without depends because haproxy is smart
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:10080:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:10084:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious-3
|
|
|
@ -1,107 +0,0 @@
|
||||||
# Docker compose file for Backend 3 of inv.nadeko.net
|
|
||||||
|
|
||||||
#https://docs.docker.com/reference/compose-file/fragments/
|
|
||||||
x-common-config: &common-config
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
network_mode: "service:gluetun"
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
depends_on:
|
|
||||||
gluetun:
|
|
||||||
condition: service_healthy
|
|
||||||
# ptgen:
|
|
||||||
# condition: service_started
|
|
||||||
haproxy:
|
|
||||||
condition: service_started
|
|
||||||
environment: &env
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
# INVIDIOUS_TOKENS_SERVER: http://gluetun:7070
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3000"
|
|
||||||
|
|
||||||
invidious2:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3001"
|
|
||||||
|
|
||||||
invidious3:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3002"
|
|
||||||
|
|
||||||
invidious4:
|
|
||||||
<<: *common-config
|
|
||||||
environment:
|
|
||||||
<<: *env
|
|
||||||
INVIDIOUS_PORT: "3003"
|
|
||||||
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: unless-stopped
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:10080:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:10084:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
networks:
|
|
||||||
gluetun_network_2:
|
|
||||||
depends_on:
|
|
||||||
- gluetun
|
|
||||||
|
|
||||||
gluetun:
|
|
||||||
image: qmcgaw/gluetun
|
|
||||||
restart: unless-stopped
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
cap_add:
|
|
||||||
- NET_ADMIN
|
|
||||||
devices:
|
|
||||||
- /dev/net/tun:/dev/net/tun
|
|
||||||
volumes:
|
|
||||||
- ./gluetun:/gluetun
|
|
||||||
environment:
|
|
||||||
- VPN_SERVICE_PROVIDER=mullvad
|
|
||||||
- VPN_TYPE=wireguard
|
|
||||||
- WIREGUARD_PRIVATE_KEY="${WIREGUARD_KEY}"
|
|
||||||
- WIREGUARD_ADDRESSES="${WIREGUARD_ADDRESSES}"
|
|
||||||
- SERVER_HOSTNAMES="${SERVER_HOSTNAMES}"
|
|
||||||
- DNS_KEEP_NAMESERVER=on
|
|
||||||
networks:
|
|
||||||
gluetun_network_2:
|
|
||||||
|
|
||||||
# ptgen:
|
|
||||||
# image: git.nadeko.net/fijxu/youtube-po-token-generator:latest
|
|
||||||
# cpus: 0.1
|
|
||||||
# restart: unless-stopped
|
|
||||||
# network_mode: "service:gluetun"
|
|
||||||
# environment:
|
|
||||||
# - PORT=7070
|
|
||||||
# depends_on:
|
|
||||||
# - gluetun
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious-vpn-2
|
|
||||||
gluetun_network_2:
|
|
||||||
external: true
|
|
||||||
|
|
|
@ -1,45 +0,0 @@
|
||||||
global
|
|
||||||
# This because haproxy is dumb and likes to use the maxconnection from the kernel and that is super mega huge making haproxy oom
|
|
||||||
maxconn 8192
|
|
||||||
# 777 perms for all sockets
|
|
||||||
unix-bind mode 777
|
|
||||||
stats socket ipv4@0.0.0.0:8405 level admin
|
|
||||||
|
|
||||||
resolvers docker
|
|
||||||
# To be able to use multiple replicas of invidious
|
|
||||||
# using domains
|
|
||||||
nameserver dns1 127.0.0.11:53
|
|
||||||
|
|
||||||
defaults
|
|
||||||
mode http
|
|
||||||
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
|
|
||||||
# Use another server if one takes too long to reply
|
|
||||||
retries 2
|
|
||||||
option redispatch
|
|
||||||
timeout client 30s
|
|
||||||
timeout connect 30s
|
|
||||||
timeout server 120s
|
|
||||||
timeout queue 10s
|
|
||||||
http-reuse always
|
|
||||||
|
|
||||||
# Prometheus for graphs
|
|
||||||
frontend prometheus
|
|
||||||
bind *:8404
|
|
||||||
mode http
|
|
||||||
http-request use-service prometheus-exporter if { path /metrics }
|
|
||||||
no log
|
|
||||||
|
|
||||||
frontend invidious
|
|
||||||
bind *:8001
|
|
||||||
default_backend invidious
|
|
||||||
|
|
||||||
backend invidious
|
|
||||||
balance roundrobin
|
|
||||||
server-template invidious 8 invidious:3000 check resolvers docker init-addr libc,none
|
|
||||||
# server invidious-1-vpn gluetun:3000 check init-addr libc,none
|
|
||||||
# server invidious-2-vpn gluetun:3001 check init-addr libc,none
|
|
||||||
# server invidious-3-vpn gluetun:3002 check init-addr libc,none
|
|
||||||
# server invidious-4-vpn gluetun:3003 check init-addr libc,none
|
|
||||||
# server invidious-5-vpn gluetun:3004 check init-addr libc,none
|
|
||||||
# server invidious-6-vpn gluetun:3005 check init-addr libc,none
|
|
||||||
|
|
|
@ -1,45 +0,0 @@
|
||||||
# Docker compose file for Backend 4 of inv.nadeko.net
|
|
||||||
|
|
||||||
x-labels: &labels
|
|
||||||
labels: [ "com.centurylinklabs.watchtower.scope=invidious" ]
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
deploy:
|
|
||||||
replicas: 4
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
environment:
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
INVIDIOUS_REDIS_URL: "tcp://valkey:6379"
|
|
||||||
depends_on:
|
|
||||||
- haproxy
|
|
||||||
<<: *labels
|
|
||||||
|
|
||||||
# Without depends because haproxy is smart
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:20100:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:20104:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious-4
|
|
110
invidious/invidious-all/docker-compose.yml
Normal file
110
invidious/invidious-all/docker-compose.yml
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
# Docker compose file for Backend 1 of inv.nadeko.net
|
||||||
|
|
||||||
|
# https://docs.docker.com/reference/compose-file/extension/
|
||||||
|
|
||||||
|
include:
|
||||||
|
- ../valkey-invidious/docker-compose.yml
|
||||||
|
|
||||||
|
x-common-env: &common-env
|
||||||
|
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
||||||
|
INVIDIOUS_REDIS_URL: "tcp://valkey:6379"
|
||||||
|
|
||||||
|
x-common: &common
|
||||||
|
hostname: invidious
|
||||||
|
env_file:
|
||||||
|
# Env file containing INVIDIOUS_* variables
|
||||||
|
- .env
|
||||||
|
image: "git.nadeko.net/fijxu/invidious-with-companion:latest"
|
||||||
|
restart: unless-stopped
|
||||||
|
mem_limit: 512MB
|
||||||
|
cpus: 0.25
|
||||||
|
deploy:
|
||||||
|
replicas: 3
|
||||||
|
volumes:
|
||||||
|
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
||||||
|
- ./config.yml:/etc/invidious/config.yml:ro
|
||||||
|
logging:
|
||||||
|
driver: none
|
||||||
|
labels: [ "com.centurylinklabs.watchtower.scope=invidious" ]
|
||||||
|
|
||||||
|
x-common-haproxy: &common-haproxy
|
||||||
|
hostname: haproxy
|
||||||
|
image: haproxy:lts-alpine
|
||||||
|
restart: always
|
||||||
|
volumes:
|
||||||
|
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
||||||
|
|
||||||
|
services:
|
||||||
|
# INVIDIOUS SECTION #
|
||||||
|
|
||||||
|
invidious:
|
||||||
|
<<: *common
|
||||||
|
environment:
|
||||||
|
<<: *common-env
|
||||||
|
INVIDIOUS_INVIDIOUS_COMPANION: '[{"private_url": "https://inv-cl2.nadeko.net:8448", "public_url": "https://inv-cl2.nadeko.net:8448"}]'
|
||||||
|
networks: ["invidious"]
|
||||||
|
depends_on: ["valkey"]
|
||||||
|
|
||||||
|
invidious2:
|
||||||
|
<<: *common
|
||||||
|
environment:
|
||||||
|
<<: *common-env
|
||||||
|
INVIDIOUS_INVIDIOUS_COMPANION: '[{"private_url": "https://inv-ca1.nadeko.net:8448", "public_url": "https://inv-ca1.nadeko.net:8448"}]'
|
||||||
|
networks: ["invidious2"]
|
||||||
|
depends_on: ["valkey2"]
|
||||||
|
|
||||||
|
invidious3:
|
||||||
|
<<: *common
|
||||||
|
environment:
|
||||||
|
<<: *common-env
|
||||||
|
INVIDIOUS_INVIDIOUS_COMPANION: '[{"private_url": "https://inv-us2.nadeko.net:8448", "public_url": "https://inv-us2.nadeko.net:8448"}]'
|
||||||
|
networks: ["invidious3"]
|
||||||
|
depends_on: ["valkey3"]
|
||||||
|
|
||||||
|
invidious4:
|
||||||
|
<<: *common
|
||||||
|
environment:
|
||||||
|
<<: *common-env
|
||||||
|
INVIDIOUS_INVIDIOUS_COMPANION: '[{"private_url": "https://inv-eu1.nadeko.net:8448", "public_url": "https://inv-eu1.nadeko.net:8448"}]'
|
||||||
|
networks: ["invidious4"]
|
||||||
|
depends_on: ["valkey4"]
|
||||||
|
|
||||||
|
# HAPROXY SECTION #
|
||||||
|
|
||||||
|
haproxy:
|
||||||
|
<<: *common-haproxy
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:11101:8001"
|
||||||
|
- "127.0.0.1:11111:8404"
|
||||||
|
networks: ["invidious"]
|
||||||
|
|
||||||
|
haproxy2:
|
||||||
|
<<: *common-haproxy
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:11102:8001"
|
||||||
|
- "127.0.0.1:11112:8404"
|
||||||
|
networks: ["invidious2"]
|
||||||
|
|
||||||
|
haproxy3:
|
||||||
|
<<: *common-haproxy
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:11103:8001"
|
||||||
|
- "127.0.0.1:11113:8404"
|
||||||
|
networks: ["invidious3"]
|
||||||
|
|
||||||
|
haproxy4:
|
||||||
|
<<: *common-haproxy
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:11104:8001"
|
||||||
|
- "127.0.0.1:11114:8404"
|
||||||
|
networks: ["invidious4"]
|
||||||
|
|
||||||
|
networks:
|
||||||
|
invidious:
|
||||||
|
name: invidious
|
||||||
|
invidious2:
|
||||||
|
name: invidious2
|
||||||
|
invidious3:
|
||||||
|
name: invidious3
|
||||||
|
invidious4:
|
||||||
|
name: invidious4
|
|
@ -1,9 +1,6 @@
|
||||||
global
|
global
|
||||||
# This because haproxy is dumb and likes to use the maxconnection from the kernel and that is super mega huge making haproxy oom
|
# This because haproxy is dumb and likes to use the maxconnection from the kernel and that is super mega huge making haproxy oom
|
||||||
maxconn 8192
|
maxconn 8192
|
||||||
# 777 perms for all sockets
|
|
||||||
unix-bind mode 777
|
|
||||||
stats socket ipv4@0.0.0.0:8405 level admin
|
|
||||||
|
|
||||||
resolvers docker
|
resolvers docker
|
||||||
# To be able to use multiple replicas of invidious
|
# To be able to use multiple replicas of invidious
|
||||||
|
@ -14,12 +11,12 @@ defaults
|
||||||
mode http
|
mode http
|
||||||
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
|
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
|
||||||
# Use another server if one takes too long to reply
|
# Use another server if one takes too long to reply
|
||||||
retries 2
|
retries 4
|
||||||
option redispatch
|
option redispatch
|
||||||
timeout client 30s
|
timeout client 30s
|
||||||
timeout connect 30s
|
timeout connect 30s
|
||||||
timeout server 120s
|
timeout server 120s
|
||||||
timeout queue 10s
|
timeout queue 20s
|
||||||
http-reuse always
|
http-reuse always
|
||||||
|
|
||||||
# Prometheus for graphs
|
# Prometheus for graphs
|
||||||
|
@ -36,3 +33,4 @@ frontend invidious
|
||||||
backend invidious
|
backend invidious
|
||||||
balance roundrobin
|
balance roundrobin
|
||||||
server-template invidious 8 invidious:3000 check resolvers docker init-addr libc,none
|
server-template invidious 8 invidious:3000 check resolvers docker init-addr libc,none
|
||||||
|
|
|
@ -1,54 +0,0 @@
|
||||||
# Docker compose file for Backend 1 of inv.nadeko.net
|
|
||||||
|
|
||||||
x-labels: &labels
|
|
||||||
labels: [ "com.centurylinklabs.watchtower.scope=invidious" ]
|
|
||||||
|
|
||||||
services:
|
|
||||||
# INVIDIOUS CLEARNET
|
|
||||||
invidious:
|
|
||||||
env_file:
|
|
||||||
# Env file containing variables like TAG, INV_MEM_*
|
|
||||||
- .env
|
|
||||||
# Env file containing INVIDIOUS_* variables
|
|
||||||
- ../.env
|
|
||||||
image: "git.nadeko.net/fijxu/invidious-with-companion:${TAG}"
|
|
||||||
restart: unless-stopped
|
|
||||||
mem_limit: ${INV_MEM_LIMIT}
|
|
||||||
mem_reservation: ${INV_MEM_RESERVATION}
|
|
||||||
cpus: ${INV_CPU} # Limit to X% of the CPU
|
|
||||||
deploy:
|
|
||||||
replicas: 4
|
|
||||||
volumes:
|
|
||||||
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
|
|
||||||
- ./config.yml:/etc/invidious/config.yml:ro
|
|
||||||
environment:
|
|
||||||
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
|
|
||||||
INVIDIOUS_REDIS_URL: "tcp://valkey:6379"
|
|
||||||
depends_on:
|
|
||||||
- haproxy
|
|
||||||
<<: *labels
|
|
||||||
|
|
||||||
# Without depends because haproxy is smart
|
|
||||||
haproxy:
|
|
||||||
image: haproxy:lts-alpine
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
# Invidious
|
|
||||||
- "127.0.0.1:10060:8001"
|
|
||||||
# METRICS
|
|
||||||
- "127.0.0.1:10064:8404"
|
|
||||||
volumes:
|
|
||||||
- ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
|
|
||||||
|
|
||||||
# ptgen:
|
|
||||||
# image: git.nadeko.net/fijxu/youtube-po-token-generator:latest
|
|
||||||
# cpus: 0.1
|
|
||||||
# restart: unless-stopped
|
|
||||||
# environment:
|
|
||||||
# - PORT=7070
|
|
||||||
# depends_on:
|
|
||||||
# - haproxy
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: invidious
|
|
|
@ -1,39 +0,0 @@
|
||||||
global
|
|
||||||
# This because haproxy is dumb and likes to use the maxconnection from the kernel and that is super mega huge making haproxy oom
|
|
||||||
maxconn 8192
|
|
||||||
# 777 perms for all sockets
|
|
||||||
unix-bind mode 777
|
|
||||||
# stats socket ipv4@0.0.0.0:8405 level admin
|
|
||||||
|
|
||||||
resolvers docker
|
|
||||||
# To be able to use multiple replicas of invidious
|
|
||||||
# using domains
|
|
||||||
nameserver dns1 127.0.0.11:53
|
|
||||||
|
|
||||||
defaults
|
|
||||||
mode http
|
|
||||||
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
|
|
||||||
# Use another server if one takes too long to reply
|
|
||||||
retries 2
|
|
||||||
option redispatch
|
|
||||||
timeout client 30s
|
|
||||||
timeout connect 30s
|
|
||||||
timeout server 120s
|
|
||||||
timeout queue 10s
|
|
||||||
http-reuse always
|
|
||||||
|
|
||||||
# Prometheus for graphs
|
|
||||||
frontend prometheus
|
|
||||||
bind *:8404
|
|
||||||
mode http
|
|
||||||
http-request use-service prometheus-exporter if { path /metrics }
|
|
||||||
no log
|
|
||||||
|
|
||||||
frontend invidious
|
|
||||||
bind *:8001
|
|
||||||
default_backend invidious
|
|
||||||
|
|
||||||
backend invidious
|
|
||||||
balance roundrobin
|
|
||||||
server-template invidious 8 invidious:3000 check resolvers docker init-addr libc,none
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
#https://docs.docker.com/reference/compose-file/fragments/
|
# https://docs.docker.com/reference/compose-file/extension/
|
||||||
x-common-config: &common-config
|
x-common: &common
|
||||||
image: valkey/valkey:7.2-alpine
|
image: valkey/valkey:7.2-alpine
|
||||||
hostname: valkey
|
hostname: valkey
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
@ -13,121 +13,22 @@ services:
|
||||||
# address of the backend. Is not possible to mix cache between backends.
|
# address of the backend. Is not possible to mix cache between backends.
|
||||||
|
|
||||||
valkey:
|
valkey:
|
||||||
<<: *common-config
|
<<: *common
|
||||||
networks:
|
networks:
|
||||||
- invidious
|
- invidious
|
||||||
|
|
||||||
valkey2:
|
valkey2:
|
||||||
<<: *common-config
|
<<: *common
|
||||||
networks:
|
networks:
|
||||||
- invidious-2
|
- invidious2
|
||||||
|
|
||||||
valkey3:
|
valkey3:
|
||||||
<<: *common-config
|
<<: *common
|
||||||
networks:
|
networks:
|
||||||
- invidious-3
|
- invidious3
|
||||||
|
|
||||||
valkey4:
|
valkey4:
|
||||||
<<: *common-config
|
<<: *common
|
||||||
networks:
|
networks:
|
||||||
- invidious-4
|
- invidious4
|
||||||
|
|
||||||
# valkey-2:
|
|
||||||
# image: valkey/valkey:7.2-alpine
|
|
||||||
# restart: unless-stopped
|
|
||||||
# volumes:
|
|
||||||
# - ./valkey.conf:/usr/local/etc/valkey/valkey.conf
|
|
||||||
# command: "valkey-server /usr/local/etc/valkey/valkey.conf"
|
|
||||||
# networks:
|
|
||||||
# - invidious-2
|
|
||||||
#
|
|
||||||
# valkey-3:
|
|
||||||
# image: valkey/valkey:7.2-alpine
|
|
||||||
# restart: unless-stopped
|
|
||||||
# volumes:
|
|
||||||
# - ./valkey.conf:/usr/local/etc/valkey/valkey.conf
|
|
||||||
# command: "valkey-server /usr/local/etc/valkey/valkey.conf"
|
|
||||||
# networks:
|
|
||||||
# - invidious-3
|
|
||||||
#
|
|
||||||
# valkey-4:
|
|
||||||
# image: valkey/valkey:7.2-alpine
|
|
||||||
# restart: unless-stopped
|
|
||||||
# volumes:
|
|
||||||
# - ./valkey.conf:/usr/local/etc/valkey/valkey.conf
|
|
||||||
# command: "valkey-server /usr/local/etc/valkey/valkey.conf"
|
|
||||||
# networks:
|
|
||||||
# - invidious-4
|
|
||||||
#
|
|
||||||
# valkey-companion:
|
|
||||||
# image: valkey/valkey:7.2-alpine
|
|
||||||
# restart: unless-stopped
|
|
||||||
# volumes:
|
|
||||||
# - ./valkey.conf:/usr/local/etc/valkey/valkey.conf
|
|
||||||
# command: "valkey-server /usr/local/etc/valkey/valkey.conf"
|
|
||||||
# networks:
|
|
||||||
# - invidious-companion
|
|
||||||
#
|
|
||||||
# # INVIDIOUS VALKEY METRICS
|
|
||||||
# invidious-redis-exporter:
|
|
||||||
# image: oliver006/redis_exporter
|
|
||||||
# restart: unless-stopped
|
|
||||||
# ports:
|
|
||||||
# - "127.0.0.1:9121:9121"
|
|
||||||
# command: "--redis.addr=redis://valkey:6379"
|
|
||||||
# networks:
|
|
||||||
# - invidious
|
|
||||||
#
|
|
||||||
# # INVIDIOUS VALKEY METRICS
|
|
||||||
# invidious-redis-exporter-vpn:
|
|
||||||
# image: oliver006/redis_exporter
|
|
||||||
# restart: unless-stopped
|
|
||||||
# ports:
|
|
||||||
# - "127.0.0.1:9122:9121"
|
|
||||||
# command: "--redis.addr=redis://valkey-vpn:6379"
|
|
||||||
# networks:
|
|
||||||
# - gluetun_network
|
|
||||||
#
|
|
||||||
# # INVIDIOUS VALKEY METRICS
|
|
||||||
# invidious-redis-exporter-vpn-2:
|
|
||||||
# image: oliver006/redis_exporter
|
|
||||||
# restart: unless-stopped
|
|
||||||
# ports:
|
|
||||||
# - "127.0.0.1:9123:9121"
|
|
||||||
# command: "--redis.addr=redis://valkey-vpn-2:6379"
|
|
||||||
# networks:
|
|
||||||
# - gluetun_network_2
|
|
||||||
#
|
|
||||||
# # INVIDIOUS VALKEY METRICS
|
|
||||||
# invidious-redis-exporter-external:
|
|
||||||
# image: oliver006/redis_exporter
|
|
||||||
# restart: unless-stopped
|
|
||||||
# ports:
|
|
||||||
# - "127.0.0.1:9124:9121"
|
|
||||||
# command: "--redis.addr=redis://valkey-external:6379"
|
|
||||||
# networks:
|
|
||||||
# - invidious-external
|
|
||||||
|
|
||||||
networks:
|
|
||||||
invidious:
|
|
||||||
external: true
|
|
||||||
invidious-2:
|
|
||||||
external: true
|
|
||||||
invidious-3:
|
|
||||||
external: true
|
|
||||||
invidious-4:
|
|
||||||
external: true
|
|
||||||
# gluetun_network:
|
|
||||||
# external: true
|
|
||||||
# gluetun_network_2:
|
|
||||||
# external: true
|
|
||||||
# invidious-companion:
|
|
||||||
# external: true
|
|
||||||
|
|
||||||
# volumes:
|
|
||||||
# invidious-valkey:
|
|
||||||
# invidious-valkey-vpn:
|
|
||||||
# invidious-valkey-vpn-2:
|
|
||||||
# invidious-external:
|
|
||||||
# invidious-with-companion:
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue