OVHserver/opt/infrastructure-docs/AI-Impress-Infrastructure-Snapshot-Formatted.md
SamoilenkoVadym a987d45fbc chore: initial infrastructure setup with Syncthing, Git and documentation
Set up three-tier synchronization: Syncthing (real-time), GitHub (version control), rsync (disaster recovery). Includes complete documentation for future Claude sessions.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-05 16:41:12 +00:00

92 KiB
Executable file

🧠 AI-Impress Infrastructure Overview

Generated on 2025-10-29 14:58:17 UTC

[TOC]

🌍 Public Domains — Summary

Domain Service Middleware Port Network(s) TLS Status

📋 System Snapshot


🏷️ System Info

Static hostname: ai-impress-prod Icon name: computer-vm Chassis: vm 🖴 Machine ID: 2c3c6d97e54246e9bcfdeb513b8947f3 Boot ID: e0fb6e0813b54674ac1ca99a87864c74 Virtualization: kvm Operating System: Ubuntu 24.04.3 LTS Kernel: Linux 6.8.0-86-generic Architecture: x86-64 Hardware Vendor: OpenStack Foundation Hardware Model: OpenStack Nova Firmware Version: 1.16.3-debian-1.16.3-2~bpo12+1 Firmware Date: Tue 2014-04-01 Firmware Age: 11y 6month 4w 1d

Uptime / Load / Memory

13:57:51 up 4 days, 21:23, 2 users, load average: 2.16, 2.05, 1.73 total used free shared buff/cache available Mem: 57Gi 9.8Gi 23Gi 643Mi 25Gi 47Gi Swap: 4.0Gi 0B 4.0Gi Filesystem Type Size Used Avail Use% Mounted on /dev/sda1 ext4 387G 44G 344G 12% / /dev/sda16 ext4 881M 117M 703M 15% /boot /dev/sda15 vfat 105M 6.2M 99M 6% /boot/efi /dev/sdc ext4 393G 3.6G 370G 1% /mnt/backups /dev/sdb ext4 295G 256M 279G 1% /mnt/psql-data overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/7f59154177fb5bb63a400d45c958667abc07aa70575548c8341781fbe635f273/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/5ce9f0d5d508698cdf824678bd8bf4fb450c967d50a852eca3a0015dd6c67eef/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/faf77df9e7ed388244d8501f4c93cf5b431ac99ebd4322ec15488db3a8433902/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/e39fa1745dd4f24d91eb8d415c2bad25b3a04b55dd375d832540cf1e769a077a/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/74d94c2981f9f8c261be164bef317206b1d1d1efaf7e0d3bb3641ad75d5502cd/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/e579a97b6d93ce6debfd20505e2ce60e0afe1f17cf9decee7f618d50a8a226ab/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/404ee27d57b85df92d5121595a343a80a07b7aa7b4c2008dbe50e66463b2ab45/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/c02ab1a8f9603c231b5eade35c15bd06040f02bbde039b26724e24d99d5df3e4/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/76c7a9a55b5adc3b64c3db6e8a12d99537da3caac40adcf7074f353772e52bb5/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/4293ecfcdd50e877d159485ca6b9c815f12cd24410306dae8f66fedd9705ed31/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/dae4a6c8c1704d938f45dca2c7ace555af54c11a781c94a5cdc0d18d5ee440f8/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/c9ce433937f38d32c24f932d1602339004562bc55b254689b33f4d9cefdb48d8/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/047d73c56f026c437ae7c1992a21e453cbc8bbe8468c1437949f2d0152f66b6b/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/9fe823ccdbfce5531823a7749b4063e0d780061328ab5be40d5c21cc58dd9b6e/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/6b48895fea3e29c215247f49e49f072d24daf2344ce48dfb997dc157547b6deb/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/a96fbdf8adc0dc3d0149a4bd96c41b23c4b41b5c011d33f0e50123a3820d647a/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/6a717f5c0ce32485fa8081101d405f0da8bf7cc881f64f4137d489456f0f8923/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/5b384609747bd2bb68bf2328eeffa3084ee9a4c8480b761caddff34e0026b6d0/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/d25a2d46205806e6feca229eac1db85715a56f2c52f69e66b82ef8fb5c6f12dd/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/e8d2e52ff9ce5cc1d860ed41f4647c8abef51cd5e5ba00c18bdc780541ac5ae1/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/0ea37098095afb0d82131840e74a1700d687522c0034c1a54c598026dd94720d/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/fadf8d44e37741b83eb74d602ed6496d9ab5936fb622fcaf085dfbb491e2a194/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/9fe58afc91005edae0fc9e98a51a9ed293a78d6187eae1da77d779d18c1292ac/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/7a07774cc12157092d106b0b0892249c2be3476837b1f98342b3288193ef3f11/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/0bd47bb2f4a55a9f24f50afdee88e713b864ee045b269e6e149e40c0ff1649e8/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/2d726d764f4ce74065c943c35a4d2c34c79507981bc00f51d4c04a071eacbe47/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/2e454b20d86b2aff6bf092ab82ca3d3bd7cf6a0e67f57561bde03376acadef44/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/22ba8cd3e543348cab52530c30a0ea818a2ef1b5d63425bf0b820ea92ad98eb2/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/e414b118e150d14b5f5f7ce0d19121fd648d240afc01e090f56900a07e0e0162/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/0b849a90ff0cfdd2d835abb77e44c3977f528213697e45f4f0dc740d1dfba514/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/bc3a5f0d8c32b795c08c1eb8ec7c4a47aeea12b2a859a0faa529c85edae57d3c/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/950d80ba3424932769487ac5c08fd65a29e9fe5f7a314619d255eea81af6c3af/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/54317f2fbe824463a9d553efc10b14ac49db8778618ba0055af8a463d64eaa14/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/fe6af5c711e6d16253171a9743c90d055df27ea754dba0c7240e6831fd388498/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/8883cbb932f4ffae6eaf2505e36237d163dbc10191bef062ab5defeae8226873/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/5c5ce6af68625d77fb8cc7d4b4a4b23dba6ff8c7ae731e192763b2eb53f3f473/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/3d33c99b219062cc157f5f44545bb2f71f558c8a4b54e97a9d773e3650441669/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/08e04dec679967f493467a0e7241b8c3410fb0b673dbd449f9435407cb851500/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/ad4f5604fd1edd8442058db0e16d4075bc935c7808899a26b910ce66bc4424ee/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/1796e36dd6d606bbadbd8ebcf0828bfa2c047765f004acfa584737f4541c5d7f/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/d6bf9788e3823e2339dcc2e7d0b2db212b544b34bc77dadd4b0bbb000bc2410d/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/68e20bd8e07f4dfb850d8c5af52a2bb719a09f6033b4d2925485dae441d8e8c5/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/5644d79cfc6301a27867898ce61720a13314ac4cda9286fc3f5c052040cf2378/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/6d6d98fbeca9f236fc379b9e39534ccbec582dfe0a19a2127b511aff8a46087d/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/c6b8b9955b7e524c57bc83942bd13a2267e0ddacd3f89692fb2525ad8fe3ec8b/merged overlay overlay 387G 44G 344G 12% /var/lib/docker/overlay2/b97c62d09c7bfb5c7d05e9d2fbc5b6c06c3af54df443f8cd179bc99411614cd4/merged


🌐 Network Configuration

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo valid_lft forever preferred_lft forever 2: ens3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000 link/ether fa:16:3e:81:b6:86 brd ff:ff:ff:ff:ff:ff altname enp0s3 inet 51.89.231.46/32 metric 100 scope global dynamic ens3 valid_lft 52579sec preferred_lft 52579sec 3: br-9e103eeb0591: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default link/ether be:a0:9b:47:43:10 brd ff:ff:ff:ff:ff:ff inet 172.16.4.1/24 brd 172.16.4.255 scope global br-9e103eeb0591 valid_lft forever preferred_lft forever 4: br-c797531af13d: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether 9a:bd:0b:27:89:89 brd ff:ff:ff:ff:ff:ff inet 172.16.1.1/24 brd 172.16.1.255 scope global br-c797531af13d valid_lft forever preferred_lft forever 5: br-cdaceadfcefb: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether f6:6d:ef:8e:77:cf brd ff:ff:ff:ff:ff:ff inet 172.19.0.1/16 brd 172.19.255.255 scope global br-cdaceadfcefb valid_lft forever preferred_lft forever 7: br-4bc92c6c74a8: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether e2:1c:73:85:12:c1 brd ff:ff:ff:ff:ff:ff inet 172.21.0.1/16 brd 172.21.255.255 scope global br-4bc92c6c74a8 valid_lft forever preferred_lft forever 2057: veth625e980@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 32:32:21:1c:74:71 brd ff:ff:ff:ff:ff:ff link-netnsid 12 9: br-a0dd7c187961: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default link/ether 12:80:99:03:db:45 brd ff:ff:ff:ff:ff:ff inet 172.16.6.1/24 brd 172.16.6.255 scope global br-a0dd7c187961 valid_lft forever preferred_lft forever 2058: veth0c573c7@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 02:9e:7a:57:c7:23 brd ff:ff:ff:ff:ff:ff link-netnsid 12 10: br-b28f70541993: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether ca:b0:f9:f1:54:90 brd ff:ff:ff:ff:ff:ff inet 172.18.0.1/16 brd 172.18.255.255 scope global br-b28f70541993 valid_lft forever preferred_lft forever 12: br-01cd476e5307: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether a2:6e:38:f6:4d:f9 brd ff:ff:ff:ff:ff:ff inet 172.22.0.1/16 brd 172.22.255.255 scope global br-01cd476e5307 valid_lft forever preferred_lft forever 13: br-7c3083a44e08: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default link/ether 0e:62:0a:52:4c:1c brd ff:ff:ff:ff:ff:ff inet 172.23.0.1/16 brd 172.23.255.255 scope global br-7c3083a44e08 valid_lft forever preferred_lft forever 14: docker0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether 72:42:ff:0d:d2:fb brd ff:ff:ff:ff:ff:ff inet 172.16.0.1/24 brd 172.16.0.255 scope global docker0 valid_lft forever preferred_lft forever 17: vethbfd4268@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-c797531af13d state UP group default link/ether c6:9a:ad:5f:e0:87 brd ff:ff:ff:ff:ff:ff link-netnsid 2 20: veth1322dc1@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether ca:e1:5f:9c:2c:c3 brd ff:ff:ff:ff:ff:ff link-netnsid 5 2071: vethc215d37@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-908d5a0befd4 state UP group default link/ether f6:f6:7c:0d:5f:dd brd ff:ff:ff:ff:ff:ff link-netnsid 40 2072: vethc44d636@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-908d5a0befd4 state UP group default link/ether e6:c5:39:77:2f:3b brd ff:ff:ff:ff:ff:ff link-netnsid 41 2073: vethbd9522e@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 7a:ad:7b:f7:d6:5f brd ff:ff:ff:ff:ff:ff link-netnsid 40 1065: veth0f5f4e4@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 16:d4:ff:19:f0:46 brd ff:ff:ff:ff:ff:ff link-netnsid 0 49: veth723fa43@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether fa:ac:bd:4b:69:b0 brd ff:ff:ff:ff:ff:ff link-netnsid 32 1330: br-908d5a0befd4: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether 72:da:85:3a:d3:73 brd ff:ff:ff:ff:ff:ff inet 172.16.8.1/24 brd 172.16.8.255 scope global br-908d5a0befd4 valid_lft forever preferred_lft forever 1331: veth37835ea@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-908d5a0befd4 state UP group default link/ether d6:55:a8:6d:c6:ba brd ff:ff:ff:ff:ff:ff link-netnsid 43 1332: veth099d887@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-908d5a0befd4 state UP group default link/ether 3a:97:d8:10:6a:49 brd ff:ff:ff:ff:ff:ff link-netnsid 45 2106: veth2f8a50a@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-908d5a0befd4 state UP group default link/ether 22:e8:40:51:4a:59 brd ff:ff:ff:ff:ff:ff link-netnsid 81 2107: veth148b996@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 9a:54:ee:1e:6e:18 brd ff:ff:ff:ff:ff:ff link-netnsid 81 2115: veth8f5f68c@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 7e:bd:3d:26:48:3e brd ff:ff:ff:ff:ff:ff link-netnsid 33 2116: veth63854f0@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 86:af:04:34:dc:23 brd ff:ff:ff:ff:ff:ff link-netnsid 33 1360: br-36cf0e468fc7: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether aa:b9:17:52:0d:54 brd ff:ff:ff:ff:ff:ff inet 172.16.2.1/24 brd 172.16.2.255 scope global br-36cf0e468fc7 valid_lft forever preferred_lft forever 1361: veth0310792@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether c6:5d:86:90:41:ab brd ff:ff:ff:ff:ff:ff link-netnsid 4 1362: vethfa62852@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 26:d8:5f:f3:73:3f brd ff:ff:ff:ff:ff:ff link-netnsid 6 1363: vethbfe9bc3@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether da:96:a8:5a:c9:eb brd ff:ff:ff:ff:ff:ff link-netnsid 8 1364: vethc33f825@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether ee:c3:e5:52:5d:84 brd ff:ff:ff:ff:ff:ff link-netnsid 17 1365: veth91ccc1d@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 16:21:eb:ca:fa:48 brd ff:ff:ff:ff:ff:ff link-netnsid 21 1366: veth3c7d998@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 12:91:aa:da:0b:6f brd ff:ff:ff:ff:ff:ff link-netnsid 22 1367: vethff19a20@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether be:c3:91:83:25:c0 brd ff:ff:ff:ff:ff:ff link-netnsid 27 1368: vethe901bb9@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 02:79:d7:28:3e:8f brd ff:ff:ff:ff:ff:ff link-netnsid 29 1369: vethbcb0045@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 72:8d:d2:ad:d4:74 brd ff:ff:ff:ff:ff:ff link-netnsid 31 1370: veth8e03257@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether fa:2f:00:ff:a4:5e brd ff:ff:ff:ff:ff:ff link-netnsid 38 1371: veth33aebae@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 7a:6f:01:13:aa:08 brd ff:ff:ff:ff:ff:ff link-netnsid 39 1373: veth291563e@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 5e:a4:26:81:6b:c9 brd ff:ff:ff:ff:ff:ff link-netnsid 39 1374: vethbb142dc@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether be:f3:f8:b3:a4:de brd ff:ff:ff:ff:ff:ff link-netnsid 61 1640: br-f2be33f79fe4: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether ba:69:19:94:1c:7a brd ff:ff:ff:ff:ff:ff inet 172.16.3.1/24 brd 172.16.3.255 scope global br-f2be33f79fe4 valid_lft forever preferred_lft forever 1128: veth054e629@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 52:b6:00:61:9a:d4 brd ff:ff:ff:ff:ff:ff link-netnsid 28 1641: veth08ed7bf@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-f2be33f79fe4 state UP group default link/ether 0e:f8:46:1c:99:dd brd ff:ff:ff:ff:ff:ff link-netnsid 3 1129: vethdb9dce3@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether e6:4d:45:e7:be:1c brd ff:ff:ff:ff:ff:ff link-netnsid 28 620: vethd32c88a@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-4bc92c6c74a8 state UP group default link/ether 86:c2:46:cb:f5:29 brd ff:ff:ff:ff:ff:ff link-netnsid 1 621: veth86a12dc@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether e6:ae:18:e9:05:16 brd ff:ff:ff:ff:ff:ff link-netnsid 1 2161: vethda56ef3@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker0 state UP group default link/ether 92:f5:05:b4:56:b9 brd ff:ff:ff:ff:ff:ff link-netnsid 10 1656: vethe510a0c@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 26:e7:ea:04:47:a0 brd ff:ff:ff:ff:ff:ff link-netnsid 9 1657: veth872c6ab@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-39a0028fdb88 state UP group default link/ether ee:c5:a8:a0:bf:7e brd ff:ff:ff:ff:ff:ff link-netnsid 9 1664: veth5f772e8@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether d2:72:86:9d:b1:7c brd ff:ff:ff:ff:ff:ff link-netnsid 7 1665: vetha6aee51@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-f2be33f79fe4 state UP group default link/ether 82:7f:8a:e4:b5:c9 brd ff:ff:ff:ff:ff:ff link-netnsid 7 2191: vethcd2024d@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker0 state UP group default link/ether 16:18:ef:2a:31:63 brd ff:ff:ff:ff:ff:ff link-netnsid 19 912: br-39a0028fdb88: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether f2:66:a7:91:d0:c8 brd ff:ff:ff:ff:ff:ff inet 172.16.7.1/24 brd 172.16.7.255 scope global br-39a0028fdb88 valid_lft forever preferred_lft forever 2196: br-e581070d94e4: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether 26:cc:f7:d4:db:83 brd ff:ff:ff:ff:ff:ff inet 172.16.5.1/24 brd 172.16.5.255 scope global br-e581070d94e4 valid_lft forever preferred_lft forever 2197: vetheb0949b@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-e581070d94e4 state UP group default link/ether b2:0b:43:52:16:b5 brd ff:ff:ff:ff:ff:ff link-netnsid 11 2198: veth613fdc6@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-e581070d94e4 state UP group default link/ether d2:35:09:6c:c1:e2 brd ff:ff:ff:ff:ff:ff link-netnsid 13 1942: veth3180ce0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 0a:3a:ea:b0:7d:e4 brd ff:ff:ff:ff:ff:ff link-netnsid 15 1430: vethbaa64f0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether ca:97:9f:a9:a0:c0 brd ff:ff:ff:ff:ff:ff link-netnsid 23 2199: veth144bdba@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-e581070d94e4 state UP group default link/ether c6:ce:bf:b5:36:4f brd ff:ff:ff:ff:ff:ff link-netnsid 14 1943: vethe62a99b@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-01cd476e5307 state UP group default link/ether 82:e8:c8:d7:2c:9e brd ff:ff:ff:ff:ff:ff link-netnsid 16 2200: veth375780f@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 9a:80:e0:8b:01:20 brd ff:ff:ff:ff:ff:ff link-netnsid 14 1944: veth08d5a2e@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 6e:eb:57:40:66:88 brd ff:ff:ff:ff:ff:ff link-netnsid 18 1945: veth4277179@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 16:22:a7:04:8c:f9 brd ff:ff:ff:ff:ff:ff link-netnsid 25 1946: vethe7ae71a@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether da:c3:d6:7e:9e:7d brd ff:ff:ff:ff:ff:ff link-netnsid 26 1947: vethabcc11e@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether d6:98:0f:1c:32:95 brd ff:ff:ff:ff:ff:ff link-netnsid 15 1948: veth37ad504@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-01cd476e5307 state UP group default link/ether 3e:db:a6:ef:a9:65 brd ff:ff:ff:ff:ff:ff link-netnsid 25 1949: vethe54897f@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-01cd476e5307 state UP group default link/ether 66:26:ae:37:1b:8d brd ff:ff:ff:ff:ff:ff link-netnsid 18 1950: veth68989f0@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 56:1f:ca:19:da:4a brd ff:ff:ff:ff:ff:ff link-netnsid 16 1951: veth0d9f124@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-01cd476e5307 state UP group default link/ether fa:57:fb:d1:09:a0 brd ff:ff:ff:ff:ff:ff link-netnsid 26 1952: vethd29efa5@if4: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-01cd476e5307 state UP group default link/ether 6e:d6:96:a1:f8:3e brd ff:ff:ff:ff:ff:ff link-netnsid 15 1955: veth66db31c@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 66:0e:0a:02:e9:fe brd ff:ff:ff:ff:ff:ff link-netnsid 34 1958: vethc66dc6d@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether c6:63:59:51:58:54 brd ff:ff:ff:ff:ff:ff link-netnsid 37 1959: veth2d1f310@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 4a:79:da:e4:7e:43 brd ff:ff:ff:ff:ff:ff link-netnsid 37 1963: veth43fde68@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-36cf0e468fc7 state UP group default link/ether 6a:04:ce:ec:55:fc brd ff:ff:ff:ff:ff:ff link-netnsid 47 1707: vethc083d06@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-f2be33f79fe4 state UP group default link/ether 92:f7:d3:30:86:d4 brd ff:ff:ff:ff:ff:ff link-netnsid 51 1200: veth20c1975@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 42:f8:2f:c6:6c:81 brd ff:ff:ff:ff:ff:ff link-netnsid 20 1211: veth8597fc6@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 06:27:a2:bb:11:c0 brd ff:ff:ff:ff:ff:ff link-netnsid 30 1212: veth836ea35@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 6e:db:60:1e:a1:4e brd ff:ff:ff:ff:ff:ff link-netnsid 30 1215: veth7726e04@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether a2:5e:7f:c5:94:a1 brd ff:ff:ff:ff:ff:ff link-netnsid 24 1216: veth1996ac2@if3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-cdaceadfcefb state UP group default link/ether 76:26:80:a7:3a:f8 brd ff:ff:ff:ff:ff:ff link-netnsid 24 1248: veth7a5b50e@if2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br-b28f70541993 state UP group default link/ether 86:cc:21:ba:df:da brd ff:ff:ff:ff:ff:ff link-netnsid 51 Status: active Logging: on (low) Default: deny (incoming), allow (outgoing), deny (routed) New profiles: skip To Action From


22/tcp ALLOW IN Anywhere # SSH 80/tcp ALLOW IN Anywhere # HTTP 443/tcp ALLOW IN Anywhere # HTTPS 2222/tcp ALLOW IN Anywhere # SFTP 22/tcp (v6) ALLOW IN Anywhere (v6) # SSH 80/tcp (v6) ALLOW IN Anywhere (v6) # HTTP 443/tcp (v6) ALLOW IN Anywhere (v6) # HTTPS 2222/tcp (v6) ALLOW IN Anywhere (v6) # SFTP

Active Ports

tcp LISTEN 0 32768 0.0.0.0:9443 0.0.0.0:* users:(("docker-proxy",pid=3256920,fd=7))
tcp LISTEN 0 32768 0.0.0.0:9000 0.0.0.0:* users:(("docker-proxy",pid=3256905,fd=7))
tcp LISTEN 0 32768 0.0.0.0:80 0.0.0.0:* users:(("docker-proxy",pid=3858614,fd=7))
tcp LISTEN 0 32768 0.0.0.0:22 0.0.0.0:* users:(("sshd",pid=6668,fd=3),("systemd",pid=1,fd=94)) tcp LISTEN 0 32768 0.0.0.0:443 0.0.0.0:* users:(("docker-proxy",pid=3858628,fd=7))
tcp LISTEN 0 32768 0.0.0.0:2222 0.0.0.0:* users:(("docker-proxy",pid=3685,fd=7))
tcp LISTEN 0 32768 127.0.0.53%lo:53 0.0.0.0:* users:(("systemd-resolve",pid=947,fd=15))
tcp LISTEN 0 32768 127.0.0.1:54322 0.0.0.0:* users:(("docker-proxy",pid=3756486,fd=7))
tcp LISTEN 0 32768 127.0.0.1:8200 0.0.0.0:* users:(("docker-proxy",pid=1083069,fd=7))
tcp LISTEN 0 32768 127.0.0.1:8443 0.0.0.0:* users:(("docker-proxy",pid=3756682,fd=7))
tcp LISTEN 0 32768 127.0.0.1:4000 0.0.0.0:* users:(("docker-proxy",pid=3755064,fd=7))
tcp LISTEN 0 32768 127.0.0.1:8000 0.0.0.0:* users:(("docker-proxy",pid=3756668,fd=7))
tcp LISTEN 0 32768 127.0.0.1:8080 0.0.0.0:* users:(("docker-proxy",pid=3858646,fd=7))
tcp LISTEN 0 32768 127.0.0.1:6543 0.0.0.0:* users:(("docker-proxy",pid=3756503,fd=7))
tcp LISTEN 0 32768 127.0.0.1:6379 0.0.0.0:* users:(("docker-proxy",pid=5038,fd=7))
tcp LISTEN 0 32768 127.0.0.1:5432 0.0.0.0:* users:(("docker-proxy",pid=2483145,fd=7))
tcp LISTEN 0 32768 127.0.0.54:53 0.0.0.0:* users:(("systemd-resolve",pid=947,fd=17))
tcp LISTEN 0 32768 127.0.0.1:5672 0.0.0.0:* users:(("docker-proxy",pid=2896427,fd=7))
tcp LISTEN 0 32768 [::]:9443 [::]:* users:(("docker-proxy",pid=3256929,fd=7))
tcp LISTEN 0 32768 [::]:9000 [::]:* users:(("docker-proxy",pid=3256911,fd=7))
tcp LISTEN 0 32768 [::]:80 [::]:* users:(("docker-proxy",pid=3858621,fd=7))
tcp LISTEN 0 32768 [::]:22 [::]:* users:(("sshd",pid=6668,fd=4),("systemd",pid=1,fd=95)) tcp LISTEN 0 32768 [::]:443 [::]:* users:(("docker-proxy",pid=3858635,fd=7))
tcp LISTEN 0 32768 [::]:2222 [::]:* users:(("docker-proxy",pid=3692,fd=7))


🐳 Docker Containers

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 660b7aec0c82 ghcr.io/gitroomhq/postiz-app:latest "docker-entrypoint.s…" 50 minutes ago Up 49 minutes postiz c3fbf6d60fb0 postgres:16-alpine "docker-entrypoint.s…" 50 minutes ago Up 50 minutes (healthy) 5432/tcp postiz-postgres 7ef5f0cf597e redis:7-alpine "docker-entrypoint.s…" 50 minutes ago Up 50 minutes (healthy) 6379/tcp postiz-redis 23861bccd73f ghcr.io/czlonkowski/n8n-mcp:latest "/usr/local/bin/dock…" About an hour ago Up About an hour (unhealthy) 3000/tcp modest_archimedes 064969d30439 ghcr.io/czlonkowski/n8n-mcp:latest "/usr/local/bin/dock…" 2 hours ago Up 2 hours (unhealthy) 3000/tcp inspiring_williams 3cca31225b26 ghcr.io/goauthentik/proxy:2025.10 "/proxy" 40 hours ago Up 40 hours (healthy) 9000/tcp, 9300/tcp, 9443/tcp authentik-proxy a6fe26eb9934 ghcr.io/goauthentik/server:2025.10 "dumb-init -- ak wor…" 40 hours ago Up 40 hours (healthy) authentik-worker 1f6e354b467a ghcr.io/goauthentik/server:2025.10 "dumb-init -- ak ser…" 40 hours ago Up 40 hours (healthy) 0.0.0.0:9000->9000/tcp, [::]:9000->9000/tcp, 0.0.0.0:9443->9443/tcp, [::]:9443->9443/tcp authentik-server 25a68f412881 odoo:17 "/entrypoint.sh odoo" 44 hours ago Up 43 hours 8069/tcp, 8071-8072/tcp odoo 5d07f5eb6fe5 supabase/gotrue:v2.180.0 "auth" 2 days ago Up 2 days (healthy) supabase-auth 303ae814fd50 vaultwarden/server:1.30.5-alpine "/start.sh" 2 days ago Up 2 days (healthy) 80/tcp, 3012/tcp vaultwarden 592d137be91a louislam/uptime-kuma:latest "/usr/bin/dumb-init …" 2 days ago Up 2 days (healthy) 3001/tcp uptime-kuma 1258fd421a69 outlinewiki/outline:latest "docker-entrypoint.s…" 2 days ago Up 14 hours (healthy) 3000/tcp outline a787c1eb15f9 n8nio/n8n:latest "tini -- /docker-ent…" 2 days ago Up 2 days 5678/tcp n8n-worker-4 9481bac8ba68 n8nio/n8n:latest "tini -- /docker-ent…" 2 days ago Up 2 days 5678/tcp n8n-worker-3 258abb057729 n8nio/n8n:latest "tini -- /docker-ent…" 2 days ago Up 2 days 5678/tcp n8n-shared fd00f72c38f6 n8nio/n8n:latest "tini -- /docker-ent…" 2 days ago Up 2 days 5678/tcp n8n-worker-1 3a490c321d85 n8nio/n8n:latest "tini -- /docker-ent…" 2 days ago Up 2 days 5678/tcp n8n-worker-2 d635c0d5c136 mautic/mautic:latest "/entrypoint.sh apac…" 2 days ago Up 2 days 80/tcp mautic e3b888061535 python:3.11-slim "bash -c 'pip instal…" 2 days ago Up 2 days (healthy) mautic-odoo-sync-v2 ec47923639ad mariadb:11 "docker-entrypoint.s…" 2 days ago Up 2 days 3306/tcp mautic-db d449ae3903ea supabase/storage-api:v1.28.0 "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 5000/tcp supabase-storage b8fa78be545c supabase/realtime:v2.51.11 "/usr/bin/tini -s -g…" 2 days ago Up 2 days (healthy) realtime-dev.supabase-realtime 80d4d268ac60 supabase/supavisor:2.7.0 "/usr/bin/tini -s -g…" 2 days ago Up 2 days (healthy) 127.0.0.1:6543->6543/tcp, 127.0.0.1:54322->5432/tcp supabase-pooler 9ed86a2fed50 supabase/edge-runtime:v1.69.6 "edge-runtime start …" 2 days ago Up 2 days supabase-edge-functions 6373b1dc8ab6 supabase/postgres-meta:v0.91.6 "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 8080/tcp supabase-meta 38e52ece0e72 kong:2.8.1 "bash -c 'eval "echo…" 2 days ago Up 2 days (healthy) 127.0.0.1:8000->8000/tcp, 8001/tcp, 127.0.0.1:8443->8443/tcp, 8444/tcp supabase-kong 71fd989b2c96 supabase/studio:2025.10.01-sha-8460121 "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 3000/tcp supabase-studio 1a7691066a60 postgrest/postgrest:v13.0.7 "postgrest" 2 days ago Up 2 days 3000/tcp supabase-rest 9c4e09d2653c supabase/logflare:1.22.6 "sh run.sh" 2 days ago Up 2 days (healthy) 127.0.0.1:4000->4000/tcp supabase-analytics 318f30451a43 supabase/postgres:15.8.1.085 "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 5432/tcp supabase-db 7811dff6b5f8 darthsim/imgproxy:v3.8.0 "imgproxy" 2 days ago Up 2 days (healthy) 8080/tcp supabase-imgproxy 58fa01ba1584 timberio/vector:0.28.1-alpine "/usr/local/bin/vect…" 2 days ago Up 2 days (healthy) supabase-vector a1c2f13391ee postgres:16-alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 5432/tcp authentik-postgres b52c9347eefb redis:alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 6379/tcp authentik-redis c1f6563f4b5d python:3.11-slim "bash -c 'pip instal…" 2 days ago Up 2 days mautic-sync-webhook 04a59f8cf255 portainer/portainer-ce:latest "/portainer" 2 days ago Up 2 days 8000/tcp, 9000/tcp, 9443/tcp portainer cb211205bdff atendai/evolution-api:latest "/bin/bash -c '. ./D…" 2 days ago Up 2 days 8080/tcp evolution-api a5a5a21d4fa4 rabbitmq:3.13-management-alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 4369/tcp, 5671/tcp, 15671-15672/tcp, 15691-15692/tcp, 25672/tcp, 127.0.0.1:5672->5672/tcp rabbitmq 5a0fd47a2184 dpage/pgadmin4:9.9 "/entrypoint.sh" 2 days ago Up 2 days 80/tcp, 443/tcp pgadmin c97df7338002 postgres:16-alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 127.0.0.1:5432->5432/tcp postgres-main b0dca1abeb06 traefik:v3.0 "/entrypoint.sh --co…" 2 days ago Up 2 days 0.0.0.0:80->80/tcp, [::]:80->80/tcp, 0.0.0.0:443->443/tcp, [::]:443->443/tcp, 127.0.0.1:8080->8080/tcp traefik c8ff70484ca0 hashicorp/vault:1.15 "docker-entrypoint.s…" 4 days ago Up 4 days (healthy) 127.0.0.1:8200->8200/tcp vault ff2a8e2e4e35 nginx:alpine "/docker-entrypoint.…" 11 days ago Up 4 days 80/tcp landing-page 94527547ced8 atmoz/sftp:latest "/entrypoint aimpres…" 12 days ago Up 4 days 0.0.0.0:2222->22/tcp, [::]:2222->22/tcp sftp-server be0461fefae9 redis:7-alpine "docker-entrypoint.s…" 12 days ago Up 4 days (healthy) 127.0.0.1:6379->6379/tcp redis-main NETWORK ID NAME DRIVER SCOPE 908d5a0befd4 authentik_authentik-internal bridge local f02abd181cda bridge bridge local cdaceadfcefb database-internal bridge local 4b9a877223ee host host local a0dd7c187961 mautic-internal bridge local f2be33f79fe4 mautic_mautic-internal bridge local 7c3083a44e08 monitoring bridge local 01cd476e5307 n8n-shared bridge local d21678395b05 none null local 39a0028fdb88 odoo-internal bridge local e581070d94e4 postiz-config_postiz-internal bridge local 9e103eeb0591 postiz_postiz-internal bridge local c797531af13d sftp_default bridge local 36cf0e468fc7 supabase_default bridge local b28f70541993 traefik-public bridge local 4bc92c6c74a8 vault-internal bridge local DRIVER VOLUME NAME local 0ac0cc2630b15d807c8c6145c911173e0c1caebba1a2ce72de11d705e5abae1f local 1dd066ed69708fb2a31d99d6dca0861f64d3fb52c3bc088af51705dc8d541165 local 2db9e9d91a0da33ea09ed13c511c26fc36d627332dc963cc025bd4033b5e03e1 local 2de676687184413b0af227422249bf40ae1c4bca2847e58fbd91a2254b214153 local 3a09c0f3d684cc55dedfa4bef44e1295be9123d540fb9448bdecb3d7c8f6f3db local 3ee11ec7964d26d817d5957b87637b31a1f851e2936067a201fa4c2dfef59cd7 local 07d3f4b5361d23053c1494f59e6b86a7764ade86b19b2bb9a4624575d75840b9 local 8e4e315b81aee308daef197e3c4e38e829bcc1286b7ff84ea95f0bcb0f84c5ee local 08e253e80c4256d0e01c32ecae8685e95638fa7d39ae1f027fc82d6aaabd30f2 local 9c5b61030fbf4bd8d2f1578f38c3da49107f6c16e60c512a98931f1f722f8868 local 9f4440d4a872f68ba860ab94aa4fd00463f26e10e50dfb1894a611950c1e1482 local 10aa85098d110b557b669eff56f9f82d06c1278fabec9a996caf9078ec47e98e local 26e0210c0b333dadf3d70bcf0fa159043983ec941a29ee21585b5e5d5d680726 local 27c0a0d02120b0d5b4b989766c2a17ad129ba754aabfe2079ec120ade3f1e2f4 local 030d0b92eb454cd8b9ebf6a62747744e03461a5399828e3426cec0cb8da83b58 local 39db85e8bb12e086c58d120404af933d23068d1b81e6181b0ab959f976c45e59 local 74ab80435a8c349210f5d61410bc2dc09c464553a36363ed31ad0f2cf9f84c28 local 86a912e031eeb261e1aa0dd066c5f584893479c7858823c63f68617e9e5a8a0f local 90a291d400f6bf6c4bc60c241380c098ed78ecd74da949f57b21d64169fde327 local 109b0a2914765a14051c5eb5cea0fe7cefe68190cfb99256e0e30e9d1867e194 local 134e1cceb87bf846f832690a6063f1ae92af79b14e56cc9cf3a52c4cf4df3d43 local 300b57dec2f42f6a1ad8843469f5351c1ab8d6aaeae8599970727d5c297e468c local 377f49a9a48a005467a38d0c7e2c939efa379a804d7a2e43f15372e1fb5ed2ab local 472ddb3cbc5ab19c28d5a0983a97e8b1efd82d0710d0c2c929d55e1c89ea65f2 local 616e3e53a74db30eecdf33ba1d624cde4cf305a3dca7d43363e086818d6fdc41 local 43529ad5de6fa339e2f7664085ad85d0d0547797b017eee69dff3e2b953c1119 local 53983ac9c6a21c80dc5a9facddc70dac9d2de9d70fdbe1d14de9910c6f967e91 local 66084dee334754ba37a01b3056a875d51c6131540d903ae36c143220b25aed78 local 46747393c732566ec667dd790893692f1cca4258f0a0f80a3922020ca60e02b3 local 31807040665eacb2b72e4fc33710821214d0960a84897065adc2d4c86f6d44ae local a4e459166fd1159b14d48c7a2ff8760f2e06dcb15811f1b21f8da72ccd537ce4 local a324c9c561a09b1de363269dd089966534bdd327675a50e41d30b08f133764da local a473ea1d369a662708f5ed7624bef9d9bbc1f8f8c669502d9662d775076de79a local a83733bc35f6cfd44ca0102797d5fef0c017f1095cb596bca713915af885c86f local aba015b6e780d5166fc3ed7407403f95fcff45d2ad49e0b6bf2a04f76233b36b local af76834f949c4b2568fcd48fc2b874bb4e04f6c817609121a680357a89055e8f local affb3c0cd71e92af9445f358a116e62f6798c483dab51f18eae77a332aa3ff40 local authentik_authentik-postgres-data local authentik_authentik-redis-data local ba1bbc413c8c10f2e20b4e91dec4ae6cf70e54b07bbd1e33e88afe009b01b985 local bdd64a6acbc05157071275c3171ea999e9a44806a4c10febf66eef9a0ac391b5 local ca1ae0e2593e6a49f89ba28e79d784f6381881025e610edaefe62c4cab946667 local cdf82ab0162c73ebe7f85c410dabce03c704ecd0b8a5df395904b99160282eba local ce2100c8ea7fb76ab1c8517e98b7295b711a92d754e59b00f55ec2fdd51d31be local cea4500c3db82f3c9c593a9fea48fc35271d94e75c821d06b34a8ef7b398133e local d496f15e11f29072e4327818ddca41c0b4c9e77ff59b7ecc38886668e8ffc2f9 local d35512c8aacfab7d5b1810489c9c2167980ee7912d4e2d990858f2dc9d71f6d2 local deb63fd68453694ad2f5fb243edaecc85164450f41eaefb14719847ae4beef5c local e5a81166c29d95a587ae88b5e1a7fd207dfe813a28609735a0590fd743d909ef local ead2af7e8f51f6a556b541d217778471b7e2e9b1777bdc676942e4d4eda8a19e local ede5cd42e730c228f46ef5c9003d3158f95ac5c46d14a1c86f87ef559f32750e local evolution-api_evolution-data local evolution-data local f1c5cb4b6aee06e57bc55b9424c92ae6674dfd646cd5cf035bd963210ec0b359 local f666b89a542669a7c89dafad138881f8c8d8212ebdb54c3f9d6af13e9cb09e08 local f4075c4e866cfe0634a54bead561729b8f5c8af467ffa6edf15736ea37cc59d9 local mautic_mautic-data local mautic_mautic-db-data local n8n-data local n8n-shared_n8n-data local odoo-addons local odoo-data local odoo_odoo-addons local odoo_odoo-data local openwebui_openwebui-data local outline-data local outline_outline-data local pgadmin-data local portainer-data local portainer_portainer-data local postgres_pgadmin-data local postiz-config local postiz-postgres-data local postiz-redis-data local postiz-uploads local postiz_postiz-config local postiz_postiz-postgres local postiz_postiz-postgres-data local postiz_postiz-redis local postiz_postiz-redis-data local postiz_postiz-uploads local rabbitmq-data local rabbitmq_rabbitmq-data local redis-data local redis_redis-data local supabase_db-config local uptime-kuma local uptime-kuma-data local uptime-kuma_uptime-kuma-data local vaultwarden-data local vaultwarden_vaultwarden-data


⚙️ Docker Compose Files

${f}

version: '3.8'
services:
  postiz:
    image: ghcr.io/gitroomhq/postiz-app:latest
    container_name: postiz
    restart: unless-stopped
    env_file: .env
    depends_on:
      postiz-postgres:
        condition: service_healthy
      postiz-redis:
        condition: service_healthy
    networks:
      - traefik-public
      - postiz-internal
    volumes:
      - postiz-uploads:/uploads
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      # Main frontend: social.ai-impress.com (with Authelia)
      - "traefik.http.routers.postiz.rule=Host(`social.ai-impress.com`)"
      - "traefik.http.routers.postiz.entrypoints=websecure"
      - "traefik.http.routers.postiz.tls.certresolver=cloudflare"
      - "traefik.http.routers.postiz.middlewares=authentik@file"
      # Uploads subdomain: uploads.ai-impress.com (without Authelia, for social media bots)
      - "traefik.http.routers.postiz-uploads.rule=Host(`uploads.ai-impress.com`)"
      - "traefik.http.routers.postiz-uploads.entrypoints=websecure"
      - "traefik.http.routers.postiz-uploads.tls.certresolver=cloudflare"
      # Service port
      - "traefik.http.services.postiz.loadbalancer.server.port=5000"
  postiz-postgres:
    image: postgres:16-alpine
    container_name: postiz-postgres
    restart: unless-stopped
    environment:
      POSTGRES_DB: postiz
      POSTGRES_USER: postiz
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
    networks:
      - postiz-internal
    volumes:
      - postiz-postgres-data:/var/lib/postgresql/data
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postiz -d postiz"]
      interval: 10s
      timeout: 5s
      retries: 5
  postiz-redis:
    image: redis:7-alpine
    container_name: postiz-redis
    restart: unless-stopped
    networks:
      - postiz-internal
    volumes:
      - postiz-redis-data:/data
    healthcheck:
      test: ["CMD", "redis-cli", "ping"]
      interval: 10s
      timeout: 5s
      retries: 5
volumes:
  postiz-uploads:
    external: true
    name: postiz_postiz-uploads
  postiz-postgres-data:
    external: true
    name: postiz_postiz-postgres-data
  postiz-redis-data:
    external: true
    name: postiz_postiz-redis-data
networks:
  traefik-public:
    external: true
  postiz-internal:
    driver: bridge

${f}

version: '3.8'
services:
  redis:
    image: redis:7-alpine
    container_name: redis-main
    restart: unless-stopped
    env_file:
      - .env
    command: >
      redis-server
      --requirepass ${REDIS_PASSWORD}
      --maxmemory 4gb
      --maxmemory-policy allkeys-lru
      --appendonly yes
      --appendfsync everysec
      --save 900 1
      --save 300 10
      --save 60 10000
    networks:
      - database-internal
    volumes:
      - redis-data:/data
    ports:
      - "127.0.0.1:6379:6379"
    healthcheck:
      test: ["CMD", "redis-cli", "--raw", "incr", "ping"]
      interval: 10s
      timeout: 3s
      retries: 5
volumes:
  redis-data:
networks:
  database-internal:
    external: true

${f}

services:
  traefik:
    image: traefik:v3.0
    container_name: traefik
    restart: unless-stopped
    security_opt:
      - no-new-privileges:true
    networks:
      - traefik-public
    ports:
      - "80:80"
      - "443:443"
      - "127.0.0.1:8080:8080"
    env_file:
      - .env
    command:
      - --configFile=/traefik.yml
      - --serverstransport.maxResponseHeaderBytes=524288
    environment:
      - GOGC=40
    volumes:
      - /etc/localtime:/etc/localtime:ro
      - /var/run/docker.sock:/var/run/docker.sock:ro
      - ./config/traefik.yml:/traefik.yml:ro
      - ./config/dynamic.yml:/dynamic.yml:ro
      - ./acme:/acme
      - ./logs:/logs
    labels:
      - "traefik.enable=true"
      - "traefik.http.routers.traefik-dashboard.rule=Host(`traefik.ai-impress.com`)"
      - "traefik.http.routers.traefik-dashboard.entrypoints=websecure"
      - "traefik.http.routers.traefik-dashboard.tls.certresolver=cloudflare"
      - "traefik.http.routers.traefik-dashboard.service=api@internal"
      - "traefik.http.routers.traefik-dashboard.middlewares=authentik@file"
      - "traefik.http.services.traefik-dashboard.loadbalancer.server.port=8080"
networks:
  traefik-public:
    external: true

${f}

version: '3.8'
services:
  rabbitmq:
    image: rabbitmq:3.13-management-alpine
    container_name: rabbitmq
    restart: unless-stopped
    hostname: rabbitmq-aimpress
    networks:
    - database-internal
    - traefik-public
    env_file:
    - .env
    environment:
      RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER}
      RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD}
      RABBITMQ_DEFAULT_VHOST: /
    volumes:
    - rabbitmq-data:/var/lib/rabbitmq
    - ./rabbitmq.conf:/etc/rabbitmq/rabbitmq.conf:ro
    ports:
    - 127.0.0.1:5672:5672
    labels:
    - traefik.enable=true
    - traefik.http.routers.rabbitmq.rule=Host(`rabbitmq.ai-impress.com`)
    - traefik.http.routers.rabbitmq.entrypoints=websecure
    - traefik.http.routers.rabbitmq.tls.certresolver=cloudflare
    - traefik.http.services.rabbitmq.loadbalancer.server.port=15672
    - traefik.http.routers.rabbitmq.middlewares=authentik@file
    healthcheck:
      test: rabbitmq-diagnostics -q ping
      interval: 30s
      timeout: 10s
      retries: 5
volumes:
  rabbitmq-data: null
networks:
  database-internal:
    external: true
  traefik-public:
    external: true

${f}

version: '3.8'
services:
  postgres:
    image: postgres:16-alpine
    container_name: postgres-main
    restart: unless-stopped
    networks:
    - database-internal
    env_file:
    - .env
    environment:
      POSTGRES_USER: ${POSTGRES_ADMIN_USER}
      POSTGRES_PASSWORD: ${POSTGRES_ADMIN_PASSWORD}
      POSTGRES_DB: postgres
      PGDATA: /var/lib/postgresql/data/pgdata
    volumes:
    - /mnt/psql-data:/var/lib/postgresql/data
    - ./init-scripts:/docker-entrypoint-initdb.d:ro
    - ./backups:/backups
    ports:
    - 127.0.0.1:5432:5432
    command:
    - postgres
    - -c
    - max_connections=200
    - -c
    - shared_buffers=2GB
    - -c
    - effective_cache_size=6GB
    healthcheck:
      test:
      - CMD-SHELL
      - pg_isready -U ${POSTGRES_ADMIN_USER} -d postgres
      interval: 10s
      timeout: 5s
      retries: 5
  pgadmin:
    image: dpage/pgadmin4:9.9
    container_name: pgadmin
    restart: unless-stopped
    networks:
    - database-internal
    - traefik-public
    env_file:
    - .env
    environment:
      PGADMIN_DEFAULT_EMAIL: ${PGADMIN_EMAIL}
      PGADMIN_DEFAULT_PASSWORD: ${PGADMIN_PASSWORD}
      PGADMIN_CONFIG_SERVER_MODE: 'True'
      PGADMIN_CONFIG_MASTER_PASSWORD_REQUIRED: 'False'
      PGADMIN_SERVER_JSON_FILE: /pgadmin4/servers.json
      PGADMIN_CONFIG_AUTHENTICATION_SOURCES: '[''webserver'']'
      PGADMIN_CONFIG_WEBSERVER_REMOTE_USER: '''X-authentik-username'''
      PGADMIN_CONFIG_WEBSERVER_AUTO_CREATE_USER: 'True'
    volumes:
    - pgadmin-data:/var/lib/pgadmin
    - ./pgadmin-config/servers.json:/pgadmin4/servers.json:ro
    labels:
    - traefik.enable=true
    - traefik.http.routers.pgadmin.rule=Host(`pgadmin.ai-impress.com`)
    - traefik.http.routers.pgadmin.entrypoints=websecure
    - traefik.http.routers.pgadmin.tls.certresolver=cloudflare
    - traefik.http.services.pgadmin.loadbalancer.server.port=80
    - traefik.http.routers.pgadmin.middlewares=authentik@file
    depends_on:
      postgres:
        condition: service_healthy
volumes:
  pgadmin-data: null
networks:
  database-internal:
    external: true
  traefik-public:
    external: true

${f}

version: '3.8'
services:
  vault:
    image: hashicorp/vault:1.15
    container_name: vault
    restart: unless-stopped
    cap_add:
      - IPC_LOCK
    networks:
      - vault-internal
      - traefik-public
    ports:
      - "127.0.0.1:8200:8200"
    environment:
      VAULT_ADDR: 'http://127.0.0.1:8200'
      VAULT_API_ADDR: 'https://vault-admin.ai-impress.com'
      VAULT_UI: 'true'
    volumes:
      - ./config:/vault/config:ro
      - ./data:/vault/data
      - ./logs:/vault/logs
    command: server
    labels:
      - "traefik.enable=true"
      - "traefik.http.routers.vault.rule=Host(`vault-admin.ai-impress.com`)"
      - "traefik.http.routers.vault.entrypoints=websecure"
      - "traefik.http.routers.vault.tls.certresolver=cloudflare"
      - "traefik.http.services.vault.loadbalancer.server.port=8200"
    healthcheck:
      test: ["CMD", "vault", "status"]
      interval: 30s
      timeout: 5s
      retries: 3
      start_period: 30s
volumes:
  vault-data:
networks:
  vault-internal:
    external: true
  traefik-public:
    external: true

${f}

version: '3.8'
services:
  mautic-db:
    image: mariadb:11
    container_name: mautic-db
    restart: unless-stopped
    networks:
    - mautic-internal
    environment:
    - MYSQL_ROOT_PASSWORD=mautic_root_pass_2025
    - MYSQL_DATABASE=mautic
    - MYSQL_USER=mautic_user
    - MYSQL_PASSWORD=mautic_pass_secure_2025
    volumes:
    - mautic-db-data:/var/lib/mysql
    command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
  mautic:
    image: mautic/mautic:latest
    container_name: mautic
    restart: unless-stopped
    networks:
    - traefik-public
    - mautic-internal
    depends_on:
    - mautic-db
    environment:
    - MAUTIC_DB_HOST=mautic-db
    - MAUTIC_DB_PORT=3306
    - MAUTIC_DB_USER=mautic_user
    - MAUTIC_DB_PASSWORD=mautic_pass_secure_2025
    - MAUTIC_DB_DATABASE=mautic
    - MAUTIC_RUN_CRON_JOBS=true
    - MAUTIC_URL=https://marketing.ai-impress.com
    - DEBUG=false
    - MAUTIC_MAILER_HOST=aiimpress-com0e.mail.protection.outlook.com
    - MAUTIC_MAILER_PORT=25
    - MAUTIC_MAILER_FROM_EMAIL=noreply@ai-impress.com
    - MAUTIC_MAILER_TRANSPORT=smtp
    - MAUTIC_SAML_ENABLED=true
    - MAUTIC_SAML_ENTITY_ID=marketing.ai-impress.com
    - MAUTIC_SAML_LOGIN_PATH=/s/saml/login
    - MAUTIC_SAML_LOGIN_CHECK_PATH=/s/saml/login_check
    volumes:
    - mautic-data:/var/www/html
    labels:
    - traefik.enable=true
    - traefik.docker.network=traefik-public
    # Main router with auth (for UI)
    - traefik.http.routers.mautic.rule=Host(`marketing.ai-impress.com`)
    - traefik.http.routers.mautic.entrypoints=websecure
    - traefik.http.routers.mautic.tls.certresolver=cloudflare
    - traefik.http.routers.mautic.priority=1
    - traefik.http.routers.mautic.middlewares=mautic-auth
    # API router without auth (for OAuth2 and API endpoints)
    - traefik.http.routers.mautic-api.rule=Host(`marketing.ai-impress.com`) && (PathPrefix(`/oauth`) || PathPrefix(`/api`))
    - traefik.http.routers.mautic-api.entrypoints=websecure
    - traefik.http.routers.mautic-api.tls.certresolver=cloudflare
    - traefik.http.routers.mautic-api.priority=10
    # Middleware for auth
    - traefik.http.middlewares.mautic-auth.forwardauth.address=http://authentik-proxy:9000/outpost.goauthentik.io/auth/traefik
    - traefik.http.middlewares.mautic-auth.forwardauth.trustForwardHeader=true
    - traefik.http.middlewares.mautic-auth.forwardauth.authResponseHeaders=X-authentik-username,X-authentik-groups,X-authentik-email,X-authentik-name,X-authentik-uid
    # Service
    - traefik.http.services.mautic.loadbalancer.server.port=80
volumes:
  mautic-db-data: null
  mautic-data: null
networks:
  traefik-public:
    external: true
  mautic-internal:
    driver: bridge

${f}

version: "3.8"
services:
  outline:
    image: outlinewiki/outline:latest
    container_name: outline
    restart: unless-stopped
    networks:
      - traefik-public
      - database-internal
    env_file:
      - .env
    environment:
      DATABASE_URL: postgres://outline_user:${DB_PASSWORD}@postgres-main:5432/outline?sslmode=disable
      REDIS_URL: redis://:${REDIS_PASSWORD}@redis-main:6379
      URL: https://wiki.ai-impress.com
      PORT: 3000
      SECRET_KEY: ${SECRET_KEY}
      UTILS_SECRET: ${UTILS_SECRET}
      NODE_OPTIONS: "--max-http-header-size=32768"
    volumes:
      - outline-data:/var/lib/outline/data
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      - "traefik.http.routers.outline.rule=Host(`wiki.ai-impress.com`)"
      - "traefik.http.routers.outline.entrypoints=websecure"
      - "traefik.http.routers.outline.tls.certresolver=cloudflare"
      - "traefik.http.services.outline.loadbalancer.server.port=3000"
volumes:
  outline-data:
networks:
  traefik-public:
    external: true
  database-internal:
    external: true

${f}

version: '3.8'
services:
  odoo:
    image: odoo:17
    container_name: odoo
    restart: unless-stopped
    networks:
    - traefik-public
    - database-internal
    environment:
    - HOST=postgres-main
    - PORT=5432
    - USER=odoo_user
    - PASSWORD=aeK3HvEL8E7pkic898XII4vCCyioM8yu
    volumes:
    - odoo-data:/var/lib/odoo
    - odoo-addons:/mnt/extra-addons
    - /opt/03-business/odoo/odoo.conf:/etc/odoo/odoo.conf:ro
    labels:
    - traefik.enable=true
    - traefik.docker.network=traefik-public
    - traefik.http.routers.odoo-api.rule=Host(`odoo.ai-impress.com`) && (PathPrefix(`/xmlrpc`)
      || PathPrefix(`/jsonrpc`) || PathPrefix(`/web/session`) || PathPrefix(`/web/database`)
      || PathPrefix(`/web/webclient`)|| Path(`/web/login`) || PathPrefix(`/auth_oauth`))
    - traefik.http.routers.odoo-api.entrypoints=websecure
    - traefik.http.routers.odoo-api.tls.certresolver=cloudflare
    - traefik.http.routers.odoo-api.priority=100
    - traefik.http.routers.odoo.rule=Host(`odoo.ai-impress.com`)
    - traefik.http.routers.odoo.entrypoints=websecure
    - traefik.http.routers.odoo.tls.certresolver=cloudflare
    - traefik.http.routers.odoo.priority=1
    - traefik.http.services.odoo.loadbalancer.server.port=8069
volumes:
  odoo-data: null
  odoo-addons: null
networks:
  traefik-public:
    external: true
  database-internal:
    external: true

${f}

version: '3.8'
services:
  n8n:
    image: n8nio/n8n:latest
    container_name: n8n-shared
    restart: unless-stopped
    networks:
      - traefik-public
      - database-internal
      - n8n-shared
    env_file:
      - .env
    environment:
      # General
      N8N_HOST: n8n.ai-impress.com
      N8N_PORT: 5678
      N8N_PROTOCOL: https
      WEBHOOK_URL: https://n8n.ai-impress.com/
      # Database
      DB_TYPE: postgresdb
      DB_POSTGRESDB_HOST: postgres-main
      DB_POSTGRESDB_PORT: 5432
      DB_POSTGRESDB_DATABASE: n8n_shared
      DB_POSTGRESDB_USER: n8n_user
      DB_POSTGRESDB_PASSWORD: ${DB_PASSWORD}
      DB_POSTGRESDB_POOL_SIZE: 10
      # Queue Mode (Redis)
      QUEUE_BULL_REDIS_HOST: redis-main
      QUEUE_BULL_REDIS_PORT: 6379
      QUEUE_BULL_REDIS_PASSWORD: ${REDIS_PASSWORD}
      QUEUE_BULL_REDIS_DB: 2
      EXECUTIONS_MODE: queue
      # Workers configuration
      QUEUE_HEALTH_CHECK_ACTIVE: 'true'
      # Security
      N8N_BASIC_AUTH_ACTIVE: 'false'
      N8N_ENCRYPTION_KEY: ${N8N_ENCRYPTION_KEY}
      N8N_PAYLOAD_SIZE_MAX: 64
      # Performance
      EXECUTIONS_DATA_PRUNE: 'true'
      EXECUTIONS_DATA_MAX_AGE: 168
      N8N_CONCURRENCY_PRODUCTION_LIMIT: 5
      # Timezone
      GENERIC_TIMEZONE: Europe/London
      TZ: Europe/London
    volumes:
      - n8n-data:/home/node/.n8n
      - ./custom-nodes:/home/node/.n8n/custom
    deploy:
      resources:
        limits:
          cpus: '4'
          memory: 2G
        reservations:
          cpus: '1'
          memory: 512M
    labels:
      - "traefik.enable=true"
      # Webhook роутер БЕЗ Authelia
      - "traefik.http.routers.n8n-webhook.rule=Host(`n8n.ai-impress.com`) && (PathPrefix(`/webhook/`) || PathPrefix(`/webhook-test/`))"
      - "traefik.http.routers.n8n-webhook.entrypoints=websecure"
      - "traefik.http.routers.n8n-webhook.tls.certresolver=cloudflare"
      - "traefik.http.routers.n8n-webhook.service=n8n-shared-service"
      - "traefik.http.routers.n8n-webhook.priority=200"
      # OAuth роутер БЕЗ Authelia
      - "traefik.http.routers.n8n-oauth.rule=Host(`n8n.ai-impress.com`) && PathPrefix(`/rest/oauth`)"
      - "traefik.http.routers.n8n-oauth.entrypoints=websecure"
      - "traefik.http.routers.n8n-oauth.tls.certresolver=cloudflare"
      - "traefik.http.routers.n8n-oauth.service=n8n-shared-service"
      - "traefik.http.routers.n8n-oauth.priority=150"
      # Основной роутер БЕЗ Authelia
      - "traefik.http.routers.n8n-shared.rule=Host(`n8n.ai-impress.com`)"
      - "traefik.http.routers.n8n-shared.entrypoints=websecure"
      - "traefik.http.routers.n8n-shared.tls.certresolver=cloudflare"
      - "traefik.http.routers.n8n-shared.service=n8n-shared-service"
      - "traefik.http.routers.n8n-shared.priority=50"
      # Сервис
      - "traefik.http.services.n8n-shared-service.loadbalancer.server.port=5678"
  # Worker 1 - High concurrency для быстрых задач
  n8n-worker-1:
    image: n8nio/n8n:latest
    container_name: n8n-worker-1
    restart: unless-stopped
    command: worker
    networks:
      - database-internal
      - n8n-shared
    env_file:
      - .env
    environment:
      # Database
      DB_TYPE: postgresdb
      DB_POSTGRESDB_HOST: postgres-main
      DB_POSTGRESDB_PORT: 5432
      DB_POSTGRESDB_DATABASE: n8n_shared
      DB_POSTGRESDB_USER: n8n_user
      DB_POSTGRESDB_PASSWORD: ${DB_PASSWORD}
      DB_POSTGRESDB_POOL_SIZE: 5
      # Queue Mode (Redis)
      QUEUE_BULL_REDIS_HOST: redis-main
      QUEUE_BULL_REDIS_PORT: 6379
      QUEUE_BULL_REDIS_PASSWORD: ${REDIS_PASSWORD}
      QUEUE_BULL_REDIS_DB: 2
      EXECUTIONS_MODE: queue
      # Worker settings
      N8N_CONCURRENCY_PRODUCTION_LIMIT: 20
      # Security
      N8N_ENCRYPTION_KEY: ${N8N_ENCRYPTION_KEY}
      # Timezone
      GENERIC_TIMEZONE: Europe/London
      TZ: Europe/London
    volumes:
      - n8n-data:/home/node/.n8n
      - ./custom-nodes:/home/node/.n8n/custom
    deploy:
      resources:
        limits:
          cpus: '4'
          memory: 4G
        reservations:
          cpus: '2'
          memory: 1G
  # Worker 2 - High concurrency
  n8n-worker-2:
    image: n8nio/n8n:latest
    container_name: n8n-worker-2
    restart: unless-stopped
    command: worker
    networks:
      - database-internal
      - n8n-shared
    env_file:
      - .env
    environment:
      # Database
      DB_TYPE: postgresdb
      DB_POSTGRESDB_HOST: postgres-main
      DB_POSTGRESDB_PORT: 5432
      DB_POSTGRESDB_DATABASE: n8n_shared
      DB_POSTGRESDB_USER: n8n_user
      DB_POSTGRESDB_PASSWORD: ${DB_PASSWORD}
      DB_POSTGRESDB_POOL_SIZE: 5
      # Queue Mode (Redis)
      QUEUE_BULL_REDIS_HOST: redis-main
      QUEUE_BULL_REDIS_PORT: 6379
      QUEUE_BULL_REDIS_PASSWORD: ${REDIS_PASSWORD}
      QUEUE_BULL_REDIS_DB: 2
      EXECUTIONS_MODE: queue
      # Worker settings
      N8N_CONCURRENCY_PRODUCTION_LIMIT: 20
      # Security
      N8N_ENCRYPTION_KEY: ${N8N_ENCRYPTION_KEY}
      # Timezone
      GENERIC_TIMEZONE: Europe/London
      TZ: Europe/London
    volumes:
      - n8n-data:/home/node/.n8n
      - ./custom-nodes:/home/node/.n8n/custom
    deploy:
      resources:
        limits:
          cpus: '4'
          memory: 4G
        reservations:
          cpus: '2'
          memory: 1G
  # Worker 3 - Medium concurrency для сложных задач
  n8n-worker-3:
    image: n8nio/n8n:latest
    container_name: n8n-worker-3
    restart: unless-stopped
    command: worker
    networks:
      - database-internal
      - n8n-shared
    env_file:
      - .env
    environment:
      # Database
      DB_TYPE: postgresdb
      DB_POSTGRESDB_HOST: postgres-main
      DB_POSTGRESDB_PORT: 5432
      DB_POSTGRESDB_DATABASE: n8n_shared
      DB_POSTGRESDB_USER: n8n_user
      DB_POSTGRESDB_PASSWORD: ${DB_PASSWORD}
      DB_POSTGRESDB_POOL_SIZE: 5
      # Queue Mode (Redis)
      QUEUE_BULL_REDIS_HOST: redis-main
      QUEUE_BULL_REDIS_PORT: 6379
      QUEUE_BULL_REDIS_PASSWORD: ${REDIS_PASSWORD}
      QUEUE_BULL_REDIS_DB: 2
      EXECUTIONS_MODE: queue
      # Worker settings
      N8N_CONCURRENCY_PRODUCTION_LIMIT: 15
      # Security
      N8N_ENCRYPTION_KEY: ${N8N_ENCRYPTION_KEY}
      # Timezone
      GENERIC_TIMEZONE: Europe/London
      TZ: Europe/London
    volumes:
      - n8n-data:/home/node/.n8n
      - ./custom-nodes:/home/node/.n8n/custom
    deploy:
      resources:
        limits:
          cpus: '3'
          memory: 3G
        reservations:
          cpus: '1'
          memory: 1G
  # Worker 4 - Medium concurrency
  n8n-worker-4:
    image: n8nio/n8n:latest
    container_name: n8n-worker-4
    restart: unless-stopped
    command: worker
    networks:
      - database-internal
      - n8n-shared
    env_file:
      - .env
    environment:
      # Database
      DB_TYPE: postgresdb
      DB_POSTGRESDB_HOST: postgres-main
      DB_POSTGRESDB_PORT: 5432
      DB_POSTGRESDB_DATABASE: n8n_shared
      DB_POSTGRESDB_USER: n8n_user
      DB_POSTGRESDB_PASSWORD: ${DB_PASSWORD}
      DB_POSTGRESDB_POOL_SIZE: 5
      # Queue Mode (Redis)
      QUEUE_BULL_REDIS_HOST: redis-main
      QUEUE_BULL_REDIS_PORT: 6379
      QUEUE_BULL_REDIS_PASSWORD: ${REDIS_PASSWORD}
      QUEUE_BULL_REDIS_DB: 2
      EXECUTIONS_MODE: queue
      # Worker settings
      N8N_CONCURRENCY_PRODUCTION_LIMIT: 15
      # Security
      N8N_ENCRYPTION_KEY: ${N8N_ENCRYPTION_KEY}
      # Timezone
      GENERIC_TIMEZONE: Europe/London
      TZ: Europe/London
    volumes:
      - n8n-data:/home/node/.n8n
      - ./custom-nodes:/home/node/.n8n/custom
    deploy:
      resources:
        limits:
          cpus: '3'
          memory: 3G
        reservations:
          cpus: '1'
          memory: 1G
volumes:
  n8n-data:
networks:
  traefik-public:
    external: true
  database-internal:
    external: true
  n8n-shared:
    external: true

${f}

version: '3.8'
services:
  evolution-api:
    image: atendai/evolution-api:latest
    container_name: evolution-api
    restart: unless-stopped
    networks:
      - traefik-public
      - database-internal
    env_file:
      - .env
    environment:
      DATABASE_PROVIDER: postgresql
      DATABASE_CONNECTION_URI: postgresql://evolution_user:${DB_PASSWORD}@postgres-main:5432/evolution
      AUTHENTICATION_API_KEY: ${API_KEY}
      SERVER_URL: https://wpp.ai-impress.com
    volumes:
      - evolution-data:/evolution/instances
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      # API router without Authelia (higher priority)
      - "traefik.http.routers.evolution-api.rule=Host(`wpp.ai-impress.com`) && (PathPrefix(`/instance`) || PathPrefix(`/message`) || PathPrefix(`/chat`) || PathPrefix(`/webhook`) || PathPrefix(`/settings`))"
      - "traefik.http.routers.evolution-api.entrypoints=websecure"
      - "traefik.http.routers.evolution-api.tls.certresolver=cloudflare"
      - "traefik.http.routers.evolution-api.priority=100"
      # Web UI router with Authelia (lower priority)
      - "traefik.http.routers.evolution.rule=Host(`wpp.ai-impress.com`)"
      - "traefik.http.routers.evolution.entrypoints=websecure"
      - "traefik.http.routers.evolution.tls.certresolver=cloudflare"
      - "traefik.http.routers.evolution.middlewares=authentik@file"
      - "traefik.http.routers.evolution.priority=50"
      # Service
      - "traefik.http.services.evolution.loadbalancer.server.port=8080"
volumes:
  evolution-data:
networks:
  traefik-public:
    external: true
  database-internal:
    external: true

${f}

version: '3.8'
services:
  uptime-kuma:
    image: louislam/uptime-kuma:latest
    container_name: uptime-kuma
    restart: unless-stopped
    networks:
      - traefik-public
    volumes:
      - uptime-kuma-data:/app/data
    environment:
      # SMTP Configuration - Office365
      SMTPHOST: aiimpress-com0e.mail.protection.outlook.com
      SMTPPORT: 25
      SMTPSECURE: "true"
      SMTPFROM: noreply@ai-impress.com
      TIMEZONE: Europe/London
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      - "traefik.http.routers.uptime-kuma.rule=Host(`status.ai-impress.com`)"
      - "traefik.http.routers.uptime-kuma.entrypoints=websecure"
      - "traefik.http.routers.uptime-kuma.tls.certresolver=cloudflare"
      - "traefik.http.services.uptime-kuma.loadbalancer.server.port=3001"
      - "traefik.http.routers.uptime-kuma.middlewares=authentik@file"
networks:
  traefik-public:
    external: true
volumes:
  uptime-kuma-data:
    external: true
    name: uptime-kuma_uptime-kuma-data

${f}

services:
  portainer:
    image: portainer/portainer-ce:latest
    container_name: portainer
    restart: unless-stopped
    security_opt:
      - no-new-privileges:true
    networks:
      - traefik-public
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock:ro
      - portainer-data:/data
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      - "traefik.http.routers.portainer.entrypoints=websecure"
      - "traefik.http.routers.portainer.rule=Host(`portainer.ai-impress.com`)"
      - "traefik.http.routers.portainer.tls=true"
      - "traefik.http.routers.portainer.tls.certresolver=cloudflare"
      - "traefik.http.routers.portainer.middlewares=authentik@file"
      - "traefik.http.services.portainer.loadbalancer.server.port=9000"
networks:
  traefik-public:
    external: true
volumes:
  portainer-data:
    external: true
    name: portainer_portainer-data

${f}

version: "3.8"
services:
  postgresql:
    image: postgres:16-alpine
    container_name: authentik-postgres
    restart: unless-stopped
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -d ${POSTGRES_DB} -U ${POSTGRES_USER}"]
      start_period: 20s
      interval: 30s
      retries: 5
      timeout: 5s
    volumes:
      - authentik-postgres-data:/var/lib/postgresql/data
    environment:
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
      POSTGRES_USER: ${POSTGRES_USER}
      POSTGRES_DB: ${POSTGRES_DB}
    networks:
      - authentik-internal
  redis:
    image: redis:alpine
    container_name: authentik-redis
    command: --save 60 1 --loglevel warning --requirepass ${REDIS_PASSWORD}
    restart: unless-stopped
    healthcheck:
      test: ["CMD-SHELL", "redis-cli --pass ${REDIS_PASSWORD} ping | grep PONG"]
      start_period: 20s
      interval: 30s
      retries: 5
      timeout: 3s
    volumes:
      - authentik-redis-data:/data
    networks:
      - authentik-internal
  server:
    image: ghcr.io/goauthentik/server:2025.10
    container_name: authentik-server
    restart: unless-stopped
    command: server
    environment:
      AUTHENTIK_SECRET_KEY: ${AUTHENTIK_SECRET_KEY}
      AUTHENTIK_ERROR_REPORTING__ENABLED: ${AUTHENTIK_ERROR_REPORTING__ENABLED}
      AUTHENTIK_LOG_LEVEL: ${AUTHENTIK_LOG_LEVEL}
      AUTHENTIK_REDIS__HOST: redis
      AUTHENTIK_REDIS__PASSWORD: ${REDIS_PASSWORD}
      AUTHENTIK_POSTGRESQL__HOST: postgresql
      AUTHENTIK_POSTGRESQL__USER: ${POSTGRES_USER}
      AUTHENTIK_POSTGRESQL__NAME: ${POSTGRES_DB}
      AUTHENTIK_POSTGRESQL__PASSWORD: ${POSTGRES_PASSWORD}
    volumes:
      - ./media:/media
      - ./custom-templates:/templates
      - ./blueprints:/blueprints/custom
    ports:
      - "9000:9000"
      - "9443:9443"
    depends_on:
      - postgresql
      - redis
    networks:
      - authentik-internal
      - traefik-public
    labels:
      - "traefik.enable=true"
      - "traefik.docker.network=traefik-public"
      - "traefik.http.routers.authentik.rule=Host(`auth.ai-impress.com`)"
      - "traefik.http.routers.authentik.entrypoints=websecure"
      - "traefik.http.routers.authentik.tls.certresolver=cloudflare"
      - "traefik.http.services.authentik.loadbalancer.server.port=9000"
  worker:
    image: ghcr.io/goauthentik/server:2025.10
    container_name: authentik-worker
    restart: unless-stopped
    command: worker
    environment:
      AUTHENTIK_SECRET_KEY: ${AUTHENTIK_SECRET_KEY}
      AUTHENTIK_ERROR_REPORTING__ENABLED: ${AUTHENTIK_ERROR_REPORTING__ENABLED}
      AUTHENTIK_LOG_LEVEL: ${AUTHENTIK_LOG_LEVEL}
      AUTHENTIK_REDIS__HOST: redis
      AUTHENTIK_REDIS__PASSWORD: ${REDIS_PASSWORD}
      AUTHENTIK_POSTGRESQL__HOST: postgresql
      AUTHENTIK_POSTGRESQL__USER: ${POSTGRES_USER}
      AUTHENTIK_POSTGRESQL__NAME: ${POSTGRES_DB}
      AUTHENTIK_POSTGRESQL__PASSWORD: ${POSTGRES_PASSWORD}
    user: root
    volumes:
      - ./media:/media
      - ./custom-templates:/templates
      - ./blueprints:/blueprints/custom
      - /var/run/docker.sock:/var/run/docker.sock
      - ./certs:/certs
    depends_on:
      - postgresql
      - redis
    networks:
      - authentik-internal
  proxy:
    image: ghcr.io/goauthentik/proxy:2025.10
    container_name: authentik-proxy
    restart: unless-stopped
    environment:
      AUTHENTIK_HOST: http://authentik-server:9000
      AUTHENTIK_HOST_BROWSER: https://auth.ai-impress.com
      AUTHENTIK_INSECURE: "false"
      AUTHENTIK_TOKEN: 07EyrIosrXyWjPO8Mk3QbSMm1JZI3gUIwaFKsbNXbJSv7WAOeI1MCBxnOW5Y
    networks:
      - traefik-public
      - authentik-internal
    depends_on:
      - server
volumes:
  authentik-postgres-data:
    driver: local
  authentik-redis-data:
    driver: local
networks:
  authentik-internal:
    driver: bridge
  traefik-public:
    external: true

${f}

version: '3.8'
services:
  vaultwarden:
    image: vaultwarden/server:1.30.5-alpine
    container_name: vaultwarden
    restart: unless-stopped
    networks:
      - traefik-public
      - database-internal
    env_file:
      - .env
    environment:
      DOMAIN: https://vault.ai-impress.com
      SIGNUPS_ALLOWED: 'true'
      INVITATIONS_ALLOWED: 'true'
      SHOW_PASSWORD_HINT: 'false'
      ADMIN_TOKEN: ${ADMIN_TOKEN}
      DATABASE_URL: postgresql://${DB_USER}:${DB_PASSWORD}@postgres-main:5432/vaultwarden
      SMTP_HOST: ${SMTP_HOST}
      SMTP_FROM: ${SMTP_FROM}
      SMTP_PORT: 587
      SMTP_SECURITY: starttls
      SMTP_USERNAME: ${SMTP_USERNAME}
      SMTP_PASSWORD: ${SMTP_PASSWORD}
      SMTP_TIMEOUT: 15
      WEB_VAULT_ENABLED: 'true'
    volumes:
      - vaultwarden-data:/data
    labels:
      - "traefik.enable=true"
      - "traefik.http.routers.vaultwarden.rule=Host(`vault.ai-impress.com`)"
      - "traefik.http.routers.vaultwarden.entrypoints=websecure"
      - "traefik.http.routers.vaultwarden.tls.certresolver=cloudflare"
      - "traefik.http.services.vaultwarden.loadbalancer.server.port=80"
      - "traefik.http.routers.vaultwarden.middlewares=security-headers@file"
      # Admin panel
      - "traefik.http.routers.vaultwarden-admin.rule=Host(`vault.ai-impress.com`) && PathPrefix(`/admin`)"
      - "traefik.http.routers.vaultwarden-admin.entrypoints=websecure"
      - "traefik.http.routers.vaultwarden-admin.tls.certresolver=cloudflare"
volumes:
  vaultwarden-data:
networks:
  traefik-public:
    external: true
  database-internal:
    external: true

🔐 Authentik & Traefik

3cca31225b26 ghcr.io/goauthentik/proxy:2025.10 "/proxy" 40 hours ago Up 40 hours (healthy) 9000/tcp, 9300/tcp, 9443/tcp authentik-proxy a6fe26eb9934 ghcr.io/goauthentik/server:2025.10 "dumb-init -- ak wor…" 40 hours ago Up 40 hours (healthy) authentik-worker 1f6e354b467a ghcr.io/goauthentik/server:2025.10 "dumb-init -- ak ser…" 40 hours ago Up 40 hours (healthy) 0.0.0.0:9000->9000/tcp, [::]:9000->9000/tcp, 0.0.0.0:9443->9443/tcp, [::]:9443->9443/tcp authentik-server a1c2f13391ee postgres:16-alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 5432/tcp authentik-postgres b52c9347eefb redis:alpine "docker-entrypoint.s…" 2 days ago Up 2 days (healthy) 6379/tcp authentik-redis b0dca1abeb06 traefik:v3.0 "/entrypoint.sh --co…" 2 days ago Up 2 days 0.0.0.0:80->80/tcp, [::]:80->80/tcp, 0.0.0.0:443->443/tcp, [::]:443->443/tcp, 127.0.0.1:8080->8080/tcp traefik { "com.docker.compose.config-hash": "067b09622c22cdaedda2d2f9f63094c7ac14332a2029d3384d548f5a85b8dc24", "com.docker.compose.container-number": "1", "com.docker.compose.depends_on": "", "com.docker.compose.image": "sha256:7a4ed730cae1fd3aea7db703c77c5f27cc5550748e492cd963a386f409562568", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "traefik", "com.docker.compose.project.config_files": "/opt/00-infrastructure/traefik/docker-compose.yml", "com.docker.compose.project.working_dir": "/opt/00-infrastructure/traefik", "com.docker.compose.replace": "traefik", "com.docker.compose.service": "traefik", "com.docker.compose.version": "2.40.2", "org.opencontainers.image.description": "A modern reverse-proxy", "org.opencontainers.image.documentation": "https://docs.traefik.io", "org.opencontainers.image.source": "https://github.com/traefik/traefik", "org.opencontainers.image.title": "Traefik", "org.opencontainers.image.url": "https://traefik.io", "org.opencontainers.image.vendor": "Traefik Labs", "org.opencontainers.image.version": "v3.0.4", "traefik.enable": "true", "traefik.http.routers.traefik-dashboard.entrypoints": "websecure", "traefik.http.routers.traefik-dashboard.middlewares": "authentik@file", "traefik.http.routers.traefik-dashboard.rule": "Host(traefik.ai-impress.com)", "traefik.http.routers.traefik-dashboard.service": "api@internal", "traefik.http.routers.traefik-dashboard.tls.certresolver": "cloudflare", "traefik.http.services.traefik-dashboard.loadbalancer.server.port": "8080" }


🗄️ Databases

PostgreSQL databases:

Redis:


🧩 Backup & Monitoring

total 180K drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 26 14:58 authelia drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 26 15:34 authentik drwxrwxr-x 19 ubuntu ubuntu 4.0K Oct 20 13:04 configs drwxrwxr-x 4 ubuntu ubuntu 4.0K Oct 20 13:04 databases drwxr-xr-x 3 ubuntu ubuntu 4.0K Oct 15 09:30 docker drwxr-xr-x 11 ubuntu ubuntu 4.0K Oct 18 03:00 espocrm drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 evolution-api drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 evolution-data drwxr-xr-x 2 ubuntu ubuntu 4.0K Oct 22 03:00 librechat drwxr-xr-x 2 ubuntu ubuntu 16K Oct 13 09:39 lost+found drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 mautic-data drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 mautic-db drwxr-xr-x 5 ubuntu ubuntu 12K Oct 23 03:00 mongodb drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 n8n drwx------ 2 ubuntu ubuntu 4.0K Oct 24 21:17 n8n-postgres drwxr-xr-x 6 ubuntu ubuntu 4.0K Oct 23 03:00 odoo drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 odoo-addons drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 odoo-data drwxrwxr-x 2 ubuntu ubuntu 4.0K Oct 27 03:00 openwebui -rwxr-xr-x 1 ubuntu ubuntu 7.6K Oct 26 17:34 authentik-services-manager.sh -rwxr-xr-x 1 root root 2.3K Oct 29 13:51 auto-update.sh -rwxr-xr-x 1 ubuntu ubuntu 8.6K Oct 20 10:27 backup-app.sh -rwxr-xr-x 1 ubuntu ubuntu 12K Oct 26 17:09 backup-authentik-improved.sh -rwxrwxr-x 1 ubuntu ubuntu 923 Oct 26 15:07 backup-authentik.sh -rwxrwxr-x 1 ubuntu ubuntu 14K Oct 26 14:59 backup-full.sh -rwxr-xr-x 1 root root 4.8K Oct 24 22:11 backup-full.sh.backup-20251024-231153 -rwxrwxr-x 1 ubuntu ubuntu 14K Oct 26 14:57 backup-full.sh.backup-20251026-145737 -rwxrwxr-x 1 ubuntu ubuntu 14K Oct 24 22:12 backup-full.sh.bak -rwxr-xr-x 1 ubuntu ubuntu 6.0K Oct 20 11:56 check-updates.sh -rwxr-xr-x 1 ubuntu ubuntu 4.2K Oct 20 11:12 check-updates.sh.backup -rwxr-xr-x 1 ubuntu ubuntu 4.9K Oct 20 11:54 check-updates.sh.backup-20251020-115409 -rwxrwxr-x 1 ubuntu ubuntu 1.6K Oct 17 22:22 create-client-database.sh -rwxrwxr-x 1 ubuntu ubuntu 5.8K Oct 17 22:26 create-n8n-vip-instance.sh -rwxrwxr-x 1 ubuntu ubuntu 5.4K Oct 23 22:04 generate-env-from-vault.sh -rwxrwxr-x 1 ubuntu ubuntu 5.2K Oct 23 21:55 generate-env-from-vault.sh.backup-20251023-225538 -rwxrwxr-x 1 ubuntu ubuntu 1.6K Oct 17 22:23 get-client-credentials.sh -rwxr-xr-x 1 ubuntu ubuntu 14K Oct 26 17:10 health-check-improved.sh -rwxr-xr-x 1 root root 5.7K Oct 29 13:51 health-check.sh -rwxrwxr-x 1 ubuntu ubuntu 2.5K Oct 20 15:01 health-check.sh.backup-20251020-160110 -rwxrwxr-x 1 ubuntu ubuntu 5.2K Oct 24 22:39 health-check.sh.backup-20251024-223943 -rwxrwxr-x 1 ubuntu ubuntu 5.5K Oct 25 22:36 health-check.sh.backup-20251025-223638 -rwxrwxr-x 1 ubuntu ubuntu 5.4K Oct 25 23:34 health-check.sh.backup-20251025-233447 -rwxrwxr-x 1 ubuntu ubuntu 5.5K Oct 26 04:00 health-check.sh.backup-20251026-040001 -rwxrwxr-x 1 ubuntu ubuntu 5.6K Oct 26 18:10 health-check.sh.backup-20251026-181026 -rwxrwxr-x 1 ubuntu ubuntu 5.8K Oct 27 12:24 health-check.sh.backup-20251027-122447 -rwxr-xr-x 1 root root 6.5K Oct 29 13:51 health-check.sh.backup-20251029-135119 -rwxr-xr-x 1 ubuntu ubuntu 17K Oct 24 22:38 infrastructure-scanner.sh -rwxr-xr-x 1 ubuntu ubuntu 15K Oct 26 17:08 migrate-authelia-to-authentik.sh -rwxrwxr-x 1 ubuntu ubuntu 5.9K Oct 24 22:44 scripts-help.sh -rwxr-xr-x 1 ubuntu ubuntu 11K Oct 20 11:54 update-app.sh -rwxr-xr-x 1 ubuntu ubuntu 11K Oct 20 11:54 update-app.sh.backup-20251020-115409 -rwxr-xr-x 1 ubuntu ubuntu 13K Oct 20 11:54 update-manager.sh -rwxr-xr-x 1 ubuntu ubuntu 13K Oct 20 11:54 update-manager.sh.backup-20251020-115409 -rwxrwxr-x 1 ubuntu ubuntu 15K Oct 20 12:11 upload-full-docs.sh -rwxrwxr-x 1 ubuntu ubuntu 1.3K Oct 16 16:52 vault-helper.sh


🧭 Mount Points

sdb ext4 300G /mnt/psql-data sdc ext4 400G /mnt/backups Generated automatically by AI-Impress Infrastructure Auditor


🗺️ Service & Dependency Map

Traefik Routes

com.docker.compose.config-hash: 067b09622c22cdaedda2d2f9f63094c7ac14332a2029d3384d548f5a85b8dc24 com.docker.compose.container-number: 1 com.docker.compose.depends_on: com.docker.compose.image: sha256:7a4ed730cae1fd3aea7db703c77c5f27cc5550748e492cd963a386f409562568 com.docker.compose.oneoff: False com.docker.compose.project: traefik com.docker.compose.project.config_files: /opt/00-infrastructure/traefik/docker-compose.yml com.docker.compose.project.working_dir: /opt/00-infrastructure/traefik com.docker.compose.replace: traefik com.docker.compose.service: traefik com.docker.compose.version: 2.40.2 org.opencontainers.image.description: A modern reverse-proxy org.opencontainers.image.documentation: https://docs.traefik.io org.opencontainers.image.source: https://github.com/traefik/traefik org.opencontainers.image.title: Traefik org.opencontainers.image.url: https://traefik.io org.opencontainers.image.vendor: Traefik Labs org.opencontainers.image.version: v3.0.4 traefik.enable: true traefik.http.routers.traefik-dashboard.entrypoints: websecure traefik.http.routers.traefik-dashboard.middlewares: authentik@file traefik.http.routers.traefik-dashboard.rule: Host(traefik.ai-impress.com) traefik.http.routers.traefik-dashboard.service: api@internal traefik.http.routers.traefik-dashboard.tls.certresolver: cloudflare traefik.http.services.traefik-dashboard.loadbalancer.server.port: 8080

Docker Networks (who is connected where)

  • 🌐 Network: authentik_authentik-internal -> Containers: authentik-server authentik-proxy authentik-postgres authentik-worker authentik-redis
  • 🌐 Network: bridge -> Containers: inspiring_williams modest_archimedes
  • 🌐 Network: database-internal -> Containers: outline n8n-shared odoo vaultwarden n8n-worker-2 pgadmin n8n-worker-3 rabbitmq n8n-worker-4 redis-main postgres-main evolution-api n8n-worker-1
  • 🌐 Network: host -> Containers:
  • 🌐 Network: mautic-internal -> Containers:
  • 🌐 Network: mautic_mautic-internal -> Containers: mautic-sync-webhook mautic mautic-db
  • 🌐 Network: monitoring -> Containers:
  • 🌐 Network: n8n-shared -> Containers: n8n-shared n8n-worker-2 n8n-worker-3 n8n-worker-4 n8n-worker-1
  • 🌐 Network: none -> Containers:
  • 🌐 Network: odoo-internal -> Containers: mautic-odoo-sync-v2
  • 🌐 Network: postiz-config_postiz-internal -> Containers: postiz postiz-redis postiz-postgres
  • 🌐 Network: postiz_postiz-internal -> Containers:
  • 🌐 Network: sftp_default -> Containers: sftp-server
  • 🌐 Network: supabase_default -> Containers: supabase-rest supabase-db supabase-kong supabase-vector supabase-auth supabase-meta supabase-studio supabase-imgproxy supabase-pooler supabase-analytics supabase-edge-functions realtime-dev.supabase-realtime supabase-storage
  • 🌐 Network: traefik-public -> Containers: portainer outline authentik-server n8n-shared odoo vaultwarden supabase-kong authentik-proxy uptime-kuma pgadmin postiz rabbitmq traefik mautic-sync-webhook vault evolution-api mautic mautic-odoo-sync-v2 landing-page
  • 🌐 Network: vault-internal -> Containers: vault

Databases and linked services

postiz-postgres postgres:16-alpine postiz-config_postiz-internal supabase-meta supabase/postgres-meta:v0.91.6 supabase_default supabase-rest postgrest/postgrest:v13.0.7 supabase_default supabase-db supabase/postgres:15.8.1.085 supabase_default authentik-postgres postgres:16-alpine authentik_authentik-internal postgres-main postgres:16-alpine database-internal postiz-redis redis:7-alpine postiz-config_postiz-internal authentik-redis redis:alpine authentik_authentik-internal redis-main redis:7-alpine database-internal supabase-auth supabase/gotrue:v2.180.0 supabase_default supabase-storage supabase/storage-api:v1.28.0 supabase_default realtime-dev.supabase-realtime supabase/realtime:v2.51.11 supabase_default supabase-pooler supabase/supavisor:2.7.0 supabase_default supabase-edge-functions supabase/edge-runtime:v1.69.6 supabase_default supabase-meta supabase/postgres-meta:v0.91.6 supabase_default supabase-kong kong:2.8.1 supabase_default,traefik-public supabase-studio supabase/studio:2025.10.01-sha-8460121 supabase_default supabase-rest postgrest/postgrest:v13.0.7 supabase_default supabase-analytics supabase/logflare:1.22.6 supabase_default supabase-db supabase/postgres:15.8.1.085 supabase_default supabase-imgproxy darthsim/imgproxy:v3.8.0 supabase_default supabase-vector timberio/vector:0.28.1-alpine supabase_default

Authentik Clients

🚦 Traefik Routers & Rules (raw)

Router Rule Entrypoints Middlewares TLS Resolver Service → Port Source Container

🔐 Authentik Applications (OIDC)

🧰 PM2 (inside app containers)

Container: postiz

📬 Redis / BullMQ (Postiz)

🗂️ Docker Compose files

🗄️ PostgreSQL Database Map

App / Container(s) Database DB User Host Container Network(s) Tables Status
authentik-proxy,authentik-worker,authentik-server,authentik-postgres,authentik-redis `
` authentik authentik-postgres authentik_authentik-internal `psql: error: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: FATAL: database "
" does not exist
?`
authentik-proxy,authentik-worker,authentik-server,authentik-postgres,authentik-redis authentik authentik authentik-postgres authentik_authentik-internal `255
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main aimpress_admin aimpress_admin postgres-main database-internal `68
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main authelia aimpress_admin postgres-main database-internal `93
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main authentik aimpress_admin postgres-main database-internal `68
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main evolution aimpress_admin postgres-main database-internal `99
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main n8n_shared aimpress_admin postgres-main database-internal `110
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main odoo aimpress_admin postgres-main database-internal `433
`
odoo,vaultwarden,outline,n8n-worker-4,n8n-worker-3,n8n-shared,n8n-worker-1,n8n-worker-2,evolution-api,rabbitmq,pgadmin,postgres-main,redis-main outline aimpress_admin postgres-main database-internal `104
`
postiz,postiz-postgres,postiz-redis `
` postiz postiz-postgres postiz-config_postiz-internal `psql: error: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: FATAL: database "
" does not exist
?`
postiz,postiz-postgres,postiz-redis postiz postiz postiz-postgres postiz-config_postiz-internal `105
`
supabase-auth,supabase-storage,realtime-dev.supabase-realtime,supabase-pooler,supabase-edge-functions,supabase-meta,supabase-kong,supabase-studio,supabase-rest,supabase-analytics,supabase-db,supabase-imgproxy,supabase-vector sh: supabase_admin supabase-db supabase_default `psql: error: connection to server on socket "/run/postgresql/.s.PGSQL.5432" failed: FATAL: database "sh:" does not exist
?`

End of report.