Update docker configuration.

This commit is contained in:
root 2024-09-27 16:41:21 -03:00
parent 6b544b01ac
commit 241c46754c
7 changed files with 240 additions and 31 deletions

View file

@ -1,6 +1,6 @@
services: services:
inv_sig_helper_cluster: inv_sig_helper_cluster:
image: quay.io/invidious/inv-sig-helper image: git.nadeko.net/fijxu/inv_sig_helper:master-4477ac8
restart: unless-stopped restart: unless-stopped
mem_limit: "512m" mem_limit: "512m"
init: true init: true
@ -8,7 +8,7 @@ services:
environment: environment:
- RUST_LOG=info - RUST_LOG=info
deploy: deploy:
replicas: 8 replicas: 16
networks: networks:
- invidious - invidious
- gluetun_network - gluetun_network

View file

@ -7,9 +7,15 @@ resolvers docker
# using domains # using domains
nameserver dns1 127.0.0.11:53 nameserver dns1 127.0.0.11:53
defaults
timeout client 10s
timeout connect 10s
timeout server 10s
timeout queue 30s
# Prometheus for graphs # Prometheus for graphs
frontend prometheus frontend prometheus
bind *:8404 bind *:8405
mode http mode http
http-request use-service prometheus-exporter if { path /metrics } http-request use-service prometheus-exporter if { path /metrics }
no log no log
@ -22,4 +28,5 @@ frontend sighelper
backend sighelper backend sighelper
mode tcp mode tcp
balance leastconn balance leastconn
server-template inv_sig_helper 16 inv_sig_helper_cluster:12999 check resolvers docker init-addr libc,none option redispatch
server-template inv_sig_helper 16 inv_sig_helper_cluster:12999 check resolvers docker init-addr libc,none inter 1s

View file

@ -20,8 +20,8 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -44,8 +44,8 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -68,22 +68,77 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s
retries: 2
# INVIDIOUS TOR
invidious-tor:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
mem_limit: "${INV_MEM_LIMIT}"
mem_reservation: "${INV_MEM_RESERVATION}"
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_DOMAIN: "inv.nadekonw7plitnjuawu6ytjsl7jlglk2t6pyq6eftptmiv3dvqndwvyd.onion"
INVIDIOUS_PORT: "3010"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on:
- inv_sig_helper
- haproxy
healthcheck:
test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 300s
timeout: 5s
retries: 2
# INVIDIOUS I2P
invidious-i2p:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
mem_limit: "${INV_MEM_LIMIT}"
mem_reservation: "${INV_MEM_RESERVATION}"
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_DOMAIN: "inv.zzls.i2p"
INVIDIOUS_PORT: "3011"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on:
- inv_sig_helper
- haproxy
healthcheck:
test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
# SIGNATURE HELPER # SIGNATURE HELPER
inv_sig_helper: inv_sig_helper:
image: git.nadeko.net/fijxu/inv_sig_helper:latest image: quay.io/invidious/inv-sig-helper
restart: unless-stopped restart: unless-stopped
network_mode: "service:gluetun"
mem_limit: "512m" mem_limit: "512m"
init: true init: true
command: ["--tcp", "0.0.0.0:12999"] command: ["--tcp", "0.0.0.0:12999"]
environment: environment:
- RUST_LOG=info - RUST_LOG=info
networks: depends_on:
gluetun_network_2: - gluetun
http3-proxy: http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest image: git.nadeko.net/fijxu/http3-proxy:latest
@ -91,6 +146,8 @@ services:
network_mode: "service:gluetun" network_mode: "service:gluetun"
environment: environment:
DISABLE_WEBP: 1 DISABLE_WEBP: 1
depends_on:
- gluetun
# Without depends because haproxy is smart # Without depends because haproxy is smart
haproxy: haproxy:
@ -104,7 +161,7 @@ services:
# I2P # I2P
- "127.0.0.1:10083:8003" - "127.0.0.1:10083:8003"
# HTTP3-PROXY # HTTP3-PROXY
- "127.0.0.1:10081:8004" # - "127.0.0.1:10081:8004"
# METRICS # METRICS
- "127.0.0.1:10084:8404" - "127.0.0.1:10084:8404"
volumes: volumes:
@ -117,6 +174,11 @@ services:
gluetun: gluetun:
image: qmcgaw/gluetun image: qmcgaw/gluetun
restart: unless-stopped restart: unless-stopped
ports:
# THIS IS ACTUALLY THE PORT OF HTTP3-PROXY
# SINCE THE HTTP3-PTOXY SERVICE IS RUNNING
# UNDER GLUETUN NETWORK.
- "127.0.0.1:10081:8080"
env_file: env_file:
- .env - .env
cap_add: cap_add:

View file

@ -69,6 +69,16 @@ frontend invidious
bind *:8001 bind *:8001
default_backend invidious default_backend invidious
frontend invidious-tor
http-request set-var(txn.ipath) path
bind *:8002
default_backend invidious-tor
frontend invidious-i2p
http-request set-var(txn.ipath) path
bind *:8003
default_backend invidious-i2p
frontend http3-proxy frontend http3-proxy
http-request set-var(txn.hpath) path http-request set-var(txn.hpath) path
bind *:8004 bind *:8004
@ -94,6 +104,32 @@ backend invidious
server invidious-5-vpn gluetun:3004 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 server invidious-6-vpn gluetun:3005 check init-addr libc,none
backend invidious-tor
# Caches video storyboards
http-request cache-use invidious-sb-cache if { path_beg /sb/ }
http-response cache-store invidious-sb-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl sb var(txn.ipath) -m beg /sb/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } sb
http-response set-header X-Cache-Status MISS if { srv_id -m found } sb
server invidious-tor-vpn gluetun:3010 check init-addr libc,none
backend invidious-i2p
# Caches video storyboards
http-request cache-use invidious-sb-cache if { path_beg /sb/ }
http-response cache-store invidious-sb-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl sb var(txn.ipath) -m beg /sb/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } sb
http-response set-header X-Cache-Status MISS if { srv_id -m found } sb
server invidious-i2p-vpn gluetun:3011 check init-addr libc,none
backend http3-proxy backend http3-proxy
# Caches video thumbnails, profile pictures and others # Caches video thumbnails, profile pictures and others
http-request cache-use invidious-thumbnail-cache if { path_beg /vi/ } http-request cache-use invidious-thumbnail-cache if { path_beg /vi/ }

View file

@ -16,12 +16,13 @@ services:
environment: environment:
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml" INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
INVIDIOUS_PORT: "3000" INVIDIOUS_PORT: "3000"
depends_on: depends_on:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -44,8 +45,8 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -68,14 +69,68 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s
retries: 2
# INVIDIOUS TOR
invidious-tor:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
mem_limit: "${INV_MEM_LIMIT}"
mem_reservation: "${INV_MEM_RESERVATION}"
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_DOMAIN: "inv.nadekonw7plitnjuawu6ytjsl7jlglk2t6pyq6eftptmiv3dvqndwvyd.onion"
INVIDIOUS_PORT: "3010"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on:
- inv_sig_helper
- haproxy
healthcheck:
test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 300s
timeout: 5s
retries: 2
# INVIDIOUS I2P
invidious-i2p:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
mem_limit: "${INV_MEM_LIMIT}"
mem_reservation: "${INV_MEM_RESERVATION}"
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_DOMAIN: "inv.zzls.i2p"
INVIDIOUS_PORT: "3011"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on:
- inv_sig_helper
- haproxy
healthcheck:
test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
# SIGNATURE HELPER # SIGNATURE HELPER
inv_sig_helper: inv_sig_helper:
image: git.nadeko.net/fijxu/inv_sig_helper:latest image: quay.io/invidious/inv-sig-helper
restart: unless-stopped restart: unless-stopped
network_mode: "service:gluetun" network_mode: "service:gluetun"
mem_limit: "512m" mem_limit: "512m"
@ -83,6 +138,8 @@ services:
command: ["--tcp", "0.0.0.0:12999"] command: ["--tcp", "0.0.0.0:12999"]
environment: environment:
- RUST_LOG=info - RUST_LOG=info
depends_on:
- gluetun
http3-proxy: http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest image: git.nadeko.net/fijxu/http3-proxy:latest
@ -90,6 +147,8 @@ services:
network_mode: "service:gluetun" network_mode: "service:gluetun"
environment: environment:
DISABLE_WEBP: 1 DISABLE_WEBP: 1
depends_on:
- gluetun
# Without depends because haproxy is smart # Without depends because haproxy is smart
haproxy: haproxy:
@ -103,7 +162,7 @@ services:
# I2P # I2P
- "127.0.0.1:10073:8003" - "127.0.0.1:10073:8003"
# HTTP3-PROXY # HTTP3-PROXY
- "127.0.0.1:10071:8004" # - "127.0.0.1:10071:8004"
# METRICS # METRICS
- "127.0.0.1:10074:8404" - "127.0.0.1:10074:8404"
volumes: volumes:
@ -116,6 +175,11 @@ services:
gluetun: gluetun:
image: qmcgaw/gluetun image: qmcgaw/gluetun
restart: unless-stopped restart: unless-stopped
ports:
# THIS IS ACTUALLY THE PORT OF HTTP3-PROXY
# SINCE THE HTTP3-PTOXY SERVICE IS RUNNING
# UNDER GLUETUN NETWORK.
- "127.0.0.1:10071:8080"
env_file: env_file:
- .env - .env
cap_add: cap_add:

View file

@ -69,6 +69,16 @@ frontend invidious
bind *:8001 bind *:8001
default_backend invidious default_backend invidious
frontend invidious-tor
http-request set-var(txn.ipath) path
bind *:8002
default_backend invidious-tor
frontend invidious-i2p
http-request set-var(txn.ipath) path
bind *:8003
default_backend invidious-i2p
frontend http3-proxy frontend http3-proxy
http-request set-var(txn.hpath) path http-request set-var(txn.hpath) path
bind *:8004 bind *:8004
@ -94,6 +104,32 @@ backend invidious
server invidious-5-vpn gluetun:3004 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 server invidious-6-vpn gluetun:3005 check init-addr libc,none
backend invidious-tor
# Caches video storyboards
http-request cache-use invidious-sb-cache if { path_beg /sb/ }
http-response cache-store invidious-sb-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl sb var(txn.ipath) -m beg /sb/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } sb
http-response set-header X-Cache-Status MISS if { srv_id -m found } sb
server invidious-tor-vpn gluetun:3010 check init-addr libc,none
backend invidious-i2p
# Caches video storyboards
http-request cache-use invidious-sb-cache if { path_beg /sb/ }
http-response cache-store invidious-sb-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl sb var(txn.ipath) -m beg /sb/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } sb
http-response set-header X-Cache-Status MISS if { srv_id -m found } sb
server invidious-i2p-vpn gluetun:3011 check init-addr libc,none
backend http3-proxy backend http3-proxy
# Caches video thumbnails, profile pictures and others # Caches video thumbnails, profile pictures and others
http-request cache-use invidious-thumbnail-cache if { path_beg /vi/ } http-request cache-use invidious-thumbnail-cache if { path_beg /vi/ }

View file

@ -20,8 +20,8 @@ services:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -41,12 +41,14 @@ services:
environment: environment:
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml" INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
INVIDIOUS_DOMAIN: "inv.nadekonw7plitnjuawu6ytjsl7jlglk2t6pyq6eftptmiv3dvqndwvyd.onion" INVIDIOUS_DOMAIN: "inv.nadekonw7plitnjuawu6ytjsl7jlglk2t6pyq6eftptmiv3dvqndwvyd.onion"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on: depends_on:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -66,12 +68,14 @@ services:
environment: environment:
INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml" INVIDIOUS_CONFIG_FILE: "/etc/invidious/config.yml"
INVIDIOUS_DOMAIN: "inv.zzls.i2p" INVIDIOUS_DOMAIN: "inv.zzls.i2p"
INVIDIOUS_HTTPS_ONLY: false
INVIDIOUS_HSTS: false
depends_on: depends_on:
- inv_sig_helper - inv_sig_helper
- haproxy - haproxy
healthcheck: healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1 test: wget -nv --tries=1 --spider https://inv.nadeko.net/watch?v=mcYLzu_1cNc || exit 1
interval: 30s interval: 300s
timeout: 5s timeout: 5s
retries: 2 retries: 2
@ -84,12 +88,12 @@ services:
command: ["--tcp", "0.0.0.0:12999"] command: ["--tcp", "0.0.0.0:12999"]
environment: environment:
- RUST_LOG=info - RUST_LOG=info
deploy:
replicas: 2
http3-proxy: http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest image: git.nadeko.net/fijxu/http3-proxy:latest
restart: unless-stopped restart: unless-stopped
ports:
- "127.0.0.1:10061:8080"
environment: environment:
DISABLE_WEBP: 1 DISABLE_WEBP: 1
@ -105,7 +109,7 @@ services:
# I2P # I2P
- "127.0.0.1:10063:8003" - "127.0.0.1:10063:8003"
# HTTP3-PROXY # HTTP3-PROXY
- "127.0.0.1:10061:8004" # - "127.0.0.1:10061:8004"
# METRICS # METRICS
- "127.0.0.1:10064:8404" - "127.0.0.1:10064:8404"
# STATS # STATS