Invidious fuckery...

This commit is contained in:
root 2024-09-12 15:44:34 -03:00
parent 7cd7c1a3f0
commit 66001d93a9
6 changed files with 787 additions and 69 deletions

View file

@ -2,13 +2,17 @@ services:
http3-proxy: http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest image: git.nadeko.net/fijxu/http3-proxy:latest
#container_name: invidious-http3-proxy #container_name: invidious-http3-proxy
network_mode: "container:gluetun"
restart: unless-stopped restart: unless-stopped
environment: environment:
DISABLE_WEBP: 1 DISABLE_WEBP: 1
#volumes: #volumes:
#- http3-socket:/app/socket:rw #- http3-socket:/app/socket:rw
deploy: #deploy:
replicas: 2 #replicas: 1
# networks:
# gluetun_network:
# ipv4_address: 172.80.0.85
# http3-proxy-test: # http3-proxy-test:
# image: git.nadeko.net/fijxu/http3-proxy:latest # image: git.nadeko.net/fijxu/http3-proxy:latest
@ -44,6 +48,8 @@ networks:
default: default:
name: invidious name: invidious
external: true external: true
gluetun_network:
external: true
volumes: volumes:
http3-proxy-socket: http3-proxy-socket:

View file

@ -1,16 +1,18 @@
services: services:
inv_sig_helper: inv_sig_helper:
image: quay.io/invidious/inv-sig-helper image: quay.io/invidious/inv-sig-helper
# container_name: invidious-signature-helper
restart: unless-stopped restart: unless-stopped
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
deploy: deploy:
replicas: 4 replicas: 10
networks: networks:
default: default:
name: invidious name: invidious
external: true external: true
volumes:
inv_sig_helper_socket:

View file

@ -0,0 +1,517 @@
# Docker compose file for ${DOMAIN}
services:
valkey:
image: valkey/valkey:7.2-alpine
container_name: invidious-valkey-vpn
restart: unless-stopped
volumes:
- invidious-valkey-vpn:/data"
networks:
gluetun_network:
ipv4_address: 172.80.0.20
# INVIDIOUS CLEARNET
invidious:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
volumes:
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment:
INVIDIOUS_CONFIG: |
feed_threads: 0
log_level: Warn
# db:
# dbname: "${PGSQL_DBNAME}"
# user: "${PGSQL_USER}"
# password: "${PGSQL_PASS}"
# host: 172.80.0.22
# port: 5432
port: 3000
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://172.80.0.20:6379
donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net"
materialious_domain: "materialious.nadeko.net"
full_refresh: false
https_only: true
hmac_key: "${HMAC_KEY}"
domain: "${DOMAIN}"
use_pubsub_feeds: true
popular_enabled: true
captcha_enabled: true
login_enabled: true
registration_enabled: false
statistics_enabled: true
external_port: 443
default_user_preferences:
annotations: true
disable_proxy: ["downloads"]
annotations_subscribed: true
autoplay: true
captions: ["English", "Spanish", "English (auto-generated)"]
comments: ["youtube", ""]
dark_mode: auto
latest_only: false
listen: false
locale: en-US
watch_history: true
max_results: 60
notifications_only: false
banner: "${BANNER}"
player_style: invidious
quality: "${QUALITY}"
quality_dash: auto
default_home: Popular
feed_menu: ["Popular", "Trending", "Subscriptions", "Playlists"]
automatic_instance_redirect: true
region: CL
sort: published
extend_desc: true
save_player_pos: true
cache_annotations: true
hsts: true
enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4
pool_size: "${POOL_SIZE}"
use_innertube_for_captions: true
jobs:
refresh_channels:
enable: false
subscribe_to_feeds:
enable: false
po_token: "${PO_TOKEN}"
visitor_data: "${VISITOR_DATA}"
signature_server: "172.80.0.30:12999"
depends_on:
- valkey
- inv_sig_helper
- gluetun
healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s
timeout: 5s
retries: 2
# INVIDIOUS CLEARNET
invidious-2:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
volumes:
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment:
INVIDIOUS_CONFIG: |
feed_threads: 0
log_level: Warn
# db:
# dbname: "${PGSQL_DBNAME}"
# user: "${PGSQL_USER}"
# password: "${PGSQL_PASS}"
# host: 172.80.0.22
# port: 5432
port: 3001
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://172.80.0.20:6379
donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net"
materialious_domain: "materialious.nadeko.net"
full_refresh: false
https_only: true
hmac_key: "${HMAC_KEY}"
domain: "${DOMAIN}"
use_pubsub_feeds: true
popular_enabled: true
captcha_enabled: true
login_enabled: true
registration_enabled: false
statistics_enabled: true
external_port: 443
default_user_preferences:
annotations: true
disable_proxy: ["downloads"]
annotations_subscribed: true
autoplay: true
captions: ["English", "Spanish", "English (auto-generated)"]
comments: ["youtube", ""]
dark_mode: auto
latest_only: false
listen: false
locale: en-US
watch_history: true
max_results: 60
notifications_only: false
banner: "${BANNER}"
player_style: invidious
quality: "${QUALITY}"
quality_dash: auto
default_home: Popular
feed_menu: ["Popular", "Trending", "Subscriptions", "Playlists"]
automatic_instance_redirect: true
region: CL
sort: published
extend_desc: true
save_player_pos: true
cache_annotations: true
hsts: true
enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4
pool_size: "${POOL_SIZE}"
use_innertube_for_captions: true
jobs:
refresh_channels:
enable: false
subscribe_to_feeds:
enable: false
po_token: "${PO_TOKEN}"
visitor_data: "${VISITOR_DATA}"
signature_server: "172.80.0.30:12999"
depends_on:
- valkey
- inv_sig_helper
- gluetun
healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s
timeout: 5s
retries: 2
# INVIDIOUS CLEARNET
invidious-3:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
volumes:
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment:
INVIDIOUS_CONFIG: |
feed_threads: 0
log_level: Warn
# db:
# dbname: "${PGSQL_DBNAME}"
# user: "${PGSQL_USER}"
# password: "${PGSQL_PASS}"
# host: 172.80.0.22
# port: 5432
port: 3002
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://172.80.0.20:6379
donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net"
materialious_domain: "materialious.nadeko.net"
full_refresh: false
https_only: true
hmac_key: "${HMAC_KEY}"
domain: "${DOMAIN}"
use_pubsub_feeds: true
popular_enabled: true
captcha_enabled: true
login_enabled: true
registration_enabled: false
statistics_enabled: true
external_port: 443
default_user_preferences:
annotations: true
disable_proxy: ["downloads"]
annotations_subscribed: true
autoplay: true
captions: ["English", "Spanish", "English (auto-generated)"]
comments: ["youtube", ""]
dark_mode: auto
latest_only: false
listen: false
locale: en-US
watch_history: true
max_results: 60
notifications_only: false
banner: "${BANNER}"
player_style: invidious
quality: "${QUALITY}"
quality_dash: auto
default_home: Popular
feed_menu: ["Popular", "Trending", "Subscriptions", "Playlists"]
automatic_instance_redirect: true
region: CL
sort: published
extend_desc: true
save_player_pos: true
cache_annotations: true
hsts: true
enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4
pool_size: "${POOL_SIZE}"
use_innertube_for_captions: true
jobs:
refresh_channels:
enable: false
subscribe_to_feeds:
enable: false
po_token: "${PO_TOKEN}"
visitor_data: "${VISITOR_DATA}"
signature_server: "172.80.0.30:12999"
depends_on:
- valkey
- inv_sig_helper
- gluetun
healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s
timeout: 5s
retries: 2
# INVIDIOUS CLEARNET
invidious-4:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
volumes:
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment:
INVIDIOUS_CONFIG: |
feed_threads: 0
log_level: Warn
# db:
# dbname: "${PGSQL_DBNAME}"
# user: "${PGSQL_USER}"
# password: "${PGSQL_PASS}"
# host: 172.80.0.22
# port: 5432
port: 3003
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://172.80.0.20:6379
donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net"
materialious_domain: "materialious.nadeko.net"
full_refresh: false
https_only: true
hmac_key: "${HMAC_KEY}"
domain: "${DOMAIN}"
use_pubsub_feeds: true
popular_enabled: true
captcha_enabled: true
login_enabled: true
registration_enabled: false
statistics_enabled: true
external_port: 443
default_user_preferences:
annotations: true
disable_proxy: ["downloads"]
annotations_subscribed: true
autoplay: true
captions: ["English", "Spanish", "English (auto-generated)"]
comments: ["youtube", ""]
dark_mode: auto
latest_only: false
listen: false
locale: en-US
watch_history: true
max_results: 60
notifications_only: false
banner: "${BANNER}"
player_style: invidious
quality: "${QUALITY}"
quality_dash: auto
default_home: Popular
feed_menu: ["Popular", "Trending", "Subscriptions", "Playlists"]
automatic_instance_redirect: true
region: CL
sort: published
extend_desc: true
save_player_pos: true
cache_annotations: true
hsts: true
enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4
pool_size: "${POOL_SIZE}"
use_innertube_for_captions: true
jobs:
refresh_channels:
enable: false
subscribe_to_feeds:
enable: false
po_token: "${PO_TOKEN}"
visitor_data: "${VISITOR_DATA}"
signature_server: "172.80.0.30:12999"
depends_on:
- valkey
- inv_sig_helper
- gluetun
healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s
timeout: 5s
retries: 2
# INVIDIOUS CLEARNET
invidious-5:
env_file:
- .env
image: "git.nadeko.net/fijxu/invidious:${TAG}"
network_mode: "service:gluetun"
restart: unless-stopped
volumes:
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment:
INVIDIOUS_CONFIG: |
feed_threads: 0
log_level: Warn
# db:
# dbname: "${PGSQL_DBNAME}"
# user: "${PGSQL_USER}"
# password: "${PGSQL_PASS}"
# host: 172.80.0.22
# port: 5432
port: 3004
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://172.80.0.20:6379
donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net"
materialious_domain: "materialious.nadeko.net"
full_refresh: false
https_only: true
hmac_key: "${HMAC_KEY}"
domain: "${DOMAIN}"
use_pubsub_feeds: true
popular_enabled: true
captcha_enabled: true
login_enabled: true
registration_enabled: false
statistics_enabled: true
external_port: 443
default_user_preferences:
annotations: true
disable_proxy: ["downloads"]
annotations_subscribed: true
autoplay: true
captions: ["English", "Spanish", "English (auto-generated)"]
comments: ["youtube", ""]
dark_mode: auto
latest_only: false
listen: false
locale: en-US
watch_history: true
max_results: 60
notifications_only: false
banner: "${BANNER}"
player_style: invidious
quality: "${QUALITY}"
quality_dash: auto
default_home: Popular
feed_menu: ["Popular", "Trending", "Subscriptions", "Playlists"]
automatic_instance_redirect: true
region: CL
sort: published
extend_desc: true
save_player_pos: true
cache_annotations: true
hsts: true
enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4
pool_size: "${POOL_SIZE}"
use_innertube_for_captions: true
jobs:
refresh_channels:
enable: false
subscribe_to_feeds:
enable: false
po_token: "${PO_TOKEN}"
visitor_data: "${VISITOR_DATA}"
signature_server: "172.80.0.30:12999"
depends_on:
- valkey
- inv_sig_helper
- gluetun
healthcheck:
test: wget -nv --tries=1 --spider http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s
timeout: 5s
retries: 2
# SIGNATURE HELPER
inv_sig_helper:
image: quay.io/invidious/inv-sig-helper
restart: unless-stopped
init: true
command: ["--tcp", "0.0.0.0:12999"]
environment:
- RUST_LOG=info
networks:
gluetun_network:
ipv4_address: 172.80.0.30
http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest
restart: unless-stopped
network_mode: "service:gluetun"
environment:
DISABLE_WEBP: 1
# Without depends because haproxy is smart
haproxy:
image: haproxy:lts-alpine
container_name: invidious-haproxy-vpn
ports:
# Invidious
- "127.0.0.1:10055:8001"
# HTTP3-PROXY
- "127.0.0.1:10056:8004"
# STATS
- "127.0.0.1:8414:8404"
volumes:
- ./haproxy:/usr/local/etc/haproxy
- /run/invidious-haproxy:/tmp:rw
networks:
gluetun_network:
gluetun:
image: qmcgaw/gluetun
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}"
networks:
gluetun_network:
# gluetun-updater:
# image: qmcgaw/gluetun
# volumes:
# - ./gluetun:/gluetun
# command: update -enduser -providers mullvad
networks:
default:
name: invidious-vpn
gluetun_network:
external: true
volumes:
invidious-valkey-vpn:

View file

@ -0,0 +1,134 @@
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 32768
# 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
timeout client 10s
timeout connect 10s
timeout server 5s
timeout http-request 10s
frontend prometheus
bind *:8404
mode http
http-request use-service prometheus-exporter if { path /metrics }
no log
frontend stats
mode http
bind *:8405
stats enable
stats uri /stats
stats refresh 1s
stats admin if TRUE
cache invidious-thumbnail-cache
# 96MB
total-max-size 96
# 32kB
max-object-size 32768
# 30min
max-age 1800
process-vary on
cache invidious-ggpht-cache
# 96MB
total-max-size 96
# 32kB
max-object-size 32768
# 30min
max-age 3600
process-vary on
# cache api-cache
# # 32MB
# total-max-size 32
# # 4kB
# max-object-size 32000
# # 5min
# max-age 300
# process-vary on
frontend invidious
http-request set-var(txn.ggpht) path
bind /tmp/invidious-vpn.sock
bind *:8001
#filter cache invidious-api-cache
#http-request cache-use invidious-api-cache if { path_beg /api/v1 }
#http-response cache-store invidious-api-cache
default_backend invidious
# frontend invidious-tor
# bind /tmp/invidious-tor.sock
# bind *:8002
# default_backend invidious-tor
#
# frontend invidious-i2p
# bind /tmp/invidious-i2p.sock
# bind *:8003
# default_backend invidious-i2p
frontend http3-proxy
http-request set-var(txn.vipath) path
# acl vi path_beg /vi/
bind /tmp/http3-proxy-vpn.sock
bind *:8004
#http-response set-header Cache-Control public
#http-response set-header Expires -1
#http-response set-header Pragma cache
# acl youtube_thumbnails path_beg /vi/
#
default_backend http3-proxy
backend invidious
balance leastconn
#http-request cache-use api-cache if { path_beg /api/v1/channels/ }
#http-response cache-store api-cache
# acl inv_api var(txn.api) -m beg /api/
# http-response set-header X-Cache-Status HIT if !{ srv_id -m found } inv_api
# http-response set-header X-Cache-Status MISS if { srv_id -m found } inv_api
#
# http-request cache-use invidious-ggpht-cache if { path_beg /ggpht/ }
# http-response cache-store invidious-ggpht-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
# acl youtube_ggpht var(txn.ggpht) -m beg /ggpht/
# http-response set-header X-Cache-Status HIT if !{ srv_id -m found } youtube_ggpht
# http-response set-header X-Cache-Status MISS if { srv_id -m found } youtube_ggpht
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
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
option redispatch
# backend invidious-tor
# server-template invidious-tor 2 invidious-tor:3000 check resolvers docker init-addr libc,none
#
# backend invidious-i2p
# server-template invidious-i2p 2 invidious-i2p:3000 check resolvers docker init-addr libc,none
backend http3-proxy
# Unix socket for http3-proxy for later
#server http3-proxy-unix-socket /http3-proxy/http-proxy.sock
# balance source
http-request cache-use invidious-thumbnail-cache if { path_beg /vi/ }
http-response cache-store invidious-thumbnail-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl youtube_thumbnails var(txn.vipath) -m beg /vi/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } youtube_thumbnails
http-response set-header X-Cache-Status MISS if { srv_id -m found } youtube_thumbnails
server http3-proxy-1-vpn gluetun:8080 check init-addr libc,none

View file

@ -19,7 +19,7 @@ services:
INVIDIOUS_CONFIG_FILE: /etc/invidious/config.yml INVIDIOUS_CONFIG_FILE: /etc/invidious/config.yml
depends_on: depends_on:
- valkey - valkey
- invidious-pgbouncer # - invidious-pgbouncer
# INVIDIOUS CLEARNET # INVIDIOUS CLEARNET
invidious: invidious:
@ -36,12 +36,14 @@ services:
INVIDIOUS_CONFIG: | INVIDIOUS_CONFIG: |
feed_threads: 0 feed_threads: 0
log_level: Warn log_level: Warn
db: # db:
dbname: "${PGSQL_DBNAME}" # dbname: "${PGSQL_DBNAME}"
user: "${PGSQL_USER}" # user: "${PGSQL_USER}"
password: "${PGSQL_PASS}" # password: "${PGSQL_PASS}"
host: invidious-pgbouncer # host: 172.80.0.22
port: 5432 # port: 5432
port: 3000
database_url: postgres://kemal:kemal@/invidious
redis_url: tcp://valkey:6379 redis_url: tcp://valkey:6379
donation_url: "https://nadeko.net/donate" donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact" contact_url: "https://nadeko.net/contact"
@ -55,7 +57,7 @@ services:
popular_enabled: true popular_enabled: true
captcha_enabled: true captcha_enabled: true
login_enabled: true login_enabled: true
registration_enabled: true registration_enabled: false
statistics_enabled: true statistics_enabled: true
external_port: 443 external_port: 443
default_user_preferences: default_user_preferences:
@ -88,7 +90,7 @@ services:
enable_user_notifications: false enable_user_notifications: false
modified_source_code_url: "${MODIFIED_SOURCE_CODE}" modified_source_code_url: "${MODIFIED_SOURCE_CODE}"
force_resolve: ipv4 force_resolve: ipv4
pool_size: 100 pool_size: 512
use_innertube_for_captions: true use_innertube_for_captions: true
jobs: jobs:
refresh_channels: refresh_channels:
@ -100,35 +102,36 @@ services:
signature_server: "inv_sig_helper:12999" signature_server: "inv_sig_helper:12999"
depends_on: depends_on:
- valkey - valkey
- invidious-pgbouncer - inv_sig_helper
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 http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s interval: 30s
timeout: 5s timeout: 5s
retries: 2 retries: 2
# INVIDIOUS TOR # INVIDIOUS TOR
invidious-tor: invidious-tor:
env_file: env_file:
- .env - .env
image: "git.nadeko.net/fijxu/invidious:${TAG}" image: "git.nadeko.net/fijxu/invidious:${TAG}"
# container_name: invidious-tor
restart: unless-stopped restart: unless-stopped
deploy: deploy:
replicas: 2 replicas: 2
#volumes: volumes:
#- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw - /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
environment: environment:
INVIDIOUS_CONFIG: | INVIDIOUS_CONFIG: |
feed_threads: 0 feed_threads: 0
log_level: Debug log_level: Debug
db: # db:
dbname: "${PGSQL_DBNAME}" # dbname: "${PGSQL_DBNAME}"
user: "${PGSQL_USER}" # user: "${PGSQL_USER}"
password: "${PGSQL_PASS}" # password: "${PGSQL_PASS}"
host: invidious-pgbouncer # host: invidious-pgbouncer
port: 5432 # port: 5432
redis_url: tcp://valkey:6379 redis_url: tcp://valkey:6379
database_url: postgres://kemal:kemal@/invidious
donation_url: "https://nadeko.net/donate" donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact" contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net" home_domain: "nadeko.net"
@ -141,7 +144,7 @@ services:
popular_enabled: true popular_enabled: true
captcha_enabled: true captcha_enabled: true
login_enabled: true login_enabled: true
registration_enabled: true registration_enabled: false
statistics_enabled: true statistics_enabled: true
external_port: 443 external_port: 443
default_user_preferences: default_user_preferences:
@ -188,7 +191,7 @@ services:
signature_server: "inv_sig_helper:12999" signature_server: "inv_sig_helper:12999"
depends_on: depends_on:
- valkey - valkey
- invidious-pgbouncer - inv_sig_helper
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 http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s interval: 30s
@ -200,7 +203,6 @@ services:
env_file: env_file:
- .env - .env
image: "git.nadeko.net/fijxu/invidious:${TAG}" image: "git.nadeko.net/fijxu/invidious:${TAG}"
# container_name: invidious-i2p
restart: unless-stopped restart: unless-stopped
deploy: deploy:
replicas: 2 replicas: 2
@ -210,13 +212,15 @@ services:
INVIDIOUS_CONFIG: | INVIDIOUS_CONFIG: |
feed_threads: 0 feed_threads: 0
log_level: "Off" log_level: "Off"
db: # db:
dbname: "${PGSQL_DBNAME}" # dbname: "${PGSQL_DBNAME}"
user: "${PGSQL_USER}" # user: "${PGSQL_USER}"
password: "${PGSQL_PASS}" # password: "${PGSQL_PASS}"
host: invidious-pgbouncer # host: invidious-pgbouncer
port: 5432 # port: 5432
redis_url: tcp://valkey:6379 redis_url: tcp://valkey:6379
database_url: postgres://kemal:kemal@/invidious
donation_url: "https://nadeko.net/donate"
donation_url: "https://nadeko.net/donate" donation_url: "https://nadeko.net/donate"
contact_url: "https://nadeko.net/contact" contact_url: "https://nadeko.net/contact"
home_domain: "nadeko.net" home_domain: "nadeko.net"
@ -229,7 +233,7 @@ services:
popular_enabled: true popular_enabled: true
captcha_enabled: true captcha_enabled: true
login_enabled: true login_enabled: true
registration_enabled: true registration_enabled: false
statistics_enabled: true statistics_enabled: true
external_port: 443 external_port: 443
default_user_preferences: default_user_preferences:
@ -276,7 +280,7 @@ services:
signature_server: "inv_sig_helper:12999" signature_server: "inv_sig_helper:12999"
depends_on: depends_on:
- valkey - valkey
- invidious-pgbouncer - inv_sig_helper
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 http://127.0.0.1:3000/api/v1/trending || exit 1
interval: 30s interval: 30s
@ -286,36 +290,48 @@ services:
#https://github.com/Sommerwiesel/invidious-nerdvpn/blob/nerdvpn/docker-compose.yml#L438 #https://github.com/Sommerwiesel/invidious-nerdvpn/blob/nerdvpn/docker-compose.yml#L438
# INVIDIOUS PBBOUNCER # INVIDIOUS PBBOUNCER
# Thanks nerdvpn # Thanks nerdvpn
invidious-pgbouncer: # invidious-pgbouncer:
env_file: # env_file:
- .env # - .env
image: edoburu/pgbouncer # image: edoburu/pgbouncer
container_name: invidious-pgbouncer # container_name: invidious-pgbouncer
environment: # environment:
- DB_HOST=/var/run/postgresql # - DB_HOST=/var/run/postgresql
- DB_PORT=5432 # - DB_PORT=5433
- DB_USER=$PGSQL_USER # - DB_USER=$PGSQL_USER
- DB_PASSWORD=$PGSQL_PASS # - DB_PASSWORD=$PGSQL_PASS
- DB_NAME=$PGSQL_DBNAME # - DB_NAME=$PGSQL_DBNAME
- ADMIN_USERS=pgbouncer # - ADMIN_USERS=pgbouncer
- POOL_MODE=transaction # - POOL_MODE=transaction
# - DEFAULT_POOL_SIZE=80 # # - DEFAULT_POOL_SIZE=80
# - MIN_POOL_SIZE=20 # # - MIN_POOL_SIZE=20
# - RESERVE_POOL_SIZE=80 # # - RESERVE_POOL_SIZE=80
# - RESERVE_POOL_TIMEOUT=5 # # - RESERVE_POOL_TIMEOUT=5
# - MAX_DB_CONNECTIONS=160 # # - MAX_DB_CONNECTIONS=160
# - MAX_USER_CONNECTIONS=160 # # - MAX_USER_CONNECTIONS=160
- MAX_CLIENT_CONN=1000 # - MAX_CLIENT_CONN=1000
- AUTH_TYPE=scram-sha-256 # - AUTH_TYPE=scram-sha-256
- IGNORE_STARTUP_PARAMETERS=extra_float_digits # - IGNORE_STARTUP_PARAMETERS=extra_float_digits
volumes: # volumes:
- ./pgbounceruserlist.txt:/etc/pgbouncer/userlist.txt:rw # - ./pgbounceruserlist.txt:/etc/pgbouncer/userlist.txt:rw
- /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw # - /var/run/postgresql/.s.PGSQL.5432:/var/run/postgresql/.s.PGSQL.5432:rw
healthcheck: # healthcheck:
test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB -h /var/run/postgresql"] # test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB -h /var/run/postgresql"]
interval: 5m # interval: 5m
timeout: 15s # timeout: 15s
retries: 2 # retries: 2
# networks:
# gluetun_network:
# ipv4_address: 172.80.0.22
# INVIDIOUS VALKEY METRICS
invidious-redis-exporter:
image: oliver006/redis_exporter
container_name: invidious-redis-exporter
restart: unless-stopped
ports:
- "127.0.0.1:9121:9121"
command: "--redis.addr=redis://valkey:6379"
# MATERIALIOUS # MATERIALIOUS
materialious: materialious:
@ -323,7 +339,7 @@ services:
container_name: materialious container_name: materialious
restart: unless-stopped restart: unless-stopped
ports: ports:
- 127.0.0.1:10013:80 - "127.0.0.1:10013:80"
environment: environment:
VITE_DEFAULT_DEARROW_THUMBNAIL_INSTANCE: "https://dearrow-thumb.ajay.app" VITE_DEFAULT_DEARROW_THUMBNAIL_INSTANCE: "https://dearrow-thumb.ajay.app"
#VITE_DEFAULT_SYNCIOUS_INSTANCE: "https://syncious.nadeko.net" #VITE_DEFAULT_SYNCIOUS_INSTANCE: "https://syncious.nadeko.net"
@ -380,6 +396,25 @@ services:
ports: ports:
- 127.0.0.1:10015:9000 - 127.0.0.1:10015:9000
# SIGNATURE HELPER
inv_sig_helper:
image: quay.io/invidious/inv-sig-helper
restart: unless-stopped
init: true
command: ["--tcp", "0.0.0.0:12999"]
environment:
- RUST_LOG=info
deploy:
replicas: 2
http3-proxy:
image: git.nadeko.net/fijxu/http3-proxy:latest
restart: unless-stopped
environment:
DISABLE_WEBP: 1
deploy:
replicas: 2
# Without depends because haproxy is smart # Without depends because haproxy is smart
haproxy: haproxy:
image: haproxy:lts-alpine image: haproxy:lts-alpine
@ -400,7 +435,6 @@ services:
volumes: volumes:
- ./haproxy:/usr/local/etc/haproxy - ./haproxy:/usr/local/etc/haproxy
- /run/invidious-haproxy:/tmp:rw - /run/invidious-haproxy:/tmp:rw
#- http3-proxy-socket:/http3-socket:rw
networks: networks:
default: default:

View file

@ -14,7 +14,7 @@ defaults
mode http mode http
timeout client 10s timeout client 10s
timeout connect 10s timeout connect 10s
timeout server 15s timeout server 5s
timeout http-request 10s timeout http-request 10s
frontend prometheus frontend prometheus
@ -40,6 +40,15 @@ cache invidious-thumbnail-cache
max-age 1800 max-age 1800
process-vary on process-vary on
cache invidious-ggpht-cache
# 96MB
total-max-size 96
# 32kB
max-object-size 32768
# 30min
max-age 3600
process-vary on
# cache api-cache # cache api-cache
# # 32MB # # 32MB
# total-max-size 32 # total-max-size 32
@ -50,12 +59,13 @@ cache invidious-thumbnail-cache
# process-vary on # process-vary on
frontend invidious frontend invidious
# http-request set-var(txn.api) path http-request set-var(txn.ggpht) path
bind /tmp/invidious.sock bind /tmp/invidious.sock
bind *:8001 bind *:8001
#filter cache invidious-api-cache #filter cache invidious-api-cache
#http-request cache-use invidious-api-cache if { path_beg /api/v1 } #http-request cache-use invidious-api-cache if { path_beg /api/v1 }
#http-response cache-store invidious-api-cache #http-response cache-store invidious-api-cache
# use_backend http3-proxy if { path_beg /videoplayback }
default_backend invidious default_backend invidious
frontend invidious-tor frontend invidious-tor
@ -87,7 +97,19 @@ backend invidious
# acl inv_api var(txn.api) -m beg /api/ # acl inv_api var(txn.api) -m beg /api/
# http-response set-header X-Cache-Status HIT if !{ srv_id -m found } inv_api # http-response set-header X-Cache-Status HIT if !{ srv_id -m found } inv_api
# http-response set-header X-Cache-Status MISS if { srv_id -m found } inv_api # http-response set-header X-Cache-Status MISS if { srv_id -m found } inv_api
#
http-request cache-use invidious-ggpht-cache if { path_beg /ggpht/ }
http-response cache-store invidious-ggpht-cache
# https://discourse.haproxy.org/t/http-response-set-header-with-condition-not-working/3108
acl youtube_ggpht var(txn.ggpht) -m beg /ggpht/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } youtube_ggpht
http-response set-header X-Cache-Status MISS if { srv_id -m found } youtube_ggpht
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
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
option redispatch
# server invidious-1 gluetun:3000 check resolvers docker init-addr libc,none
# server invidious-2 gluetun:3001 check resolvers docker init-addr libc,none
backend invidious-tor backend invidious-tor
server-template invidious-tor 2 invidious-tor:3000 check resolvers docker init-addr libc,none server-template invidious-tor 2 invidious-tor:3000 check resolvers docker init-addr libc,none
@ -106,6 +128,9 @@ backend http3-proxy
acl youtube_thumbnails var(txn.vipath) -m beg /vi/ acl youtube_thumbnails var(txn.vipath) -m beg /vi/
http-response set-header X-Cache-Status HIT if !{ srv_id -m found } youtube_thumbnails http-response set-header X-Cache-Status HIT if !{ srv_id -m found } youtube_thumbnails
http-response set-header X-Cache-Status MISS if { srv_id -m found } youtube_thumbnails http-response set-header X-Cache-Status MISS if { srv_id -m found } youtube_thumbnails
#server http3-proxy-1 gluetun:8080 check resolvers docker init-addr libc,none
server http3-proxy-1 http3-proxy:8080 check resolvers docker init-addr libc,none server http3-proxy-1 http3-proxy:8080 check resolvers docker init-addr libc,none
server http3-proxy-2 http3-proxy:8080 check resolvers docker init-addr libc,none server http3-proxy-2 http3-proxy:8080 check resolvers docker init-addr libc,none
# https://www.haproxy.com/documentation/haproxy-configuration-tutorials/service-reliability/retries/
option redispatch