更新 Gitea、HedgeDoc、Homepage、MinIO、Uptime Kuma 的 Docker Compose 配置,添加 Traefik 代理和环境变量,新增 HedgeDoc 的 .gitignore 文件
This commit is contained in:
@@ -1,16 +1,37 @@
|
|||||||
services:
|
services:
|
||||||
|
db:
|
||||||
|
image: postgres:15
|
||||||
|
restart: always
|
||||||
|
env_file: ../.env
|
||||||
|
volumes:
|
||||||
|
- ./docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
|
||||||
|
- ./db_data:/var/lib/postgresql/data
|
||||||
|
networks:
|
||||||
|
- homelab_net
|
||||||
|
|
||||||
gitea:
|
gitea:
|
||||||
image: gitea/gitea:latest
|
image: gitea/gitea:latest
|
||||||
container_name: gitea
|
container_name: gitea
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
env_file: ../.env
|
||||||
environment:
|
environment:
|
||||||
- USER_UID=1000
|
USER_UID: 1000
|
||||||
- USER_GID=1000
|
USER_GID: 1000
|
||||||
|
GITEA__database__DB_TYPE: postgres
|
||||||
|
GITEA__database__HOST: db:5432
|
||||||
|
GITEA__database__NAME: giteadb
|
||||||
|
GITEA__database__USER: gitea
|
||||||
|
GITEA__server__SSH_PORT: 22
|
||||||
volumes:
|
volumes:
|
||||||
- ./data:/data
|
- ./data:/data
|
||||||
|
# 保留 SSH 端口以便通过 SSH 推送代码(可选),移除 HTTP 宿主端口,由 Traefik 暴露
|
||||||
ports:
|
ports:
|
||||||
- "3001:3000"
|
- "3004:3000"
|
||||||
- "222:22"
|
- "222:22"
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.gitea.rule=Host(`gitea.homelab`)"
|
||||||
|
- "traefik.http.services.gitea.loadbalancer.server.port=3000"
|
||||||
networks:
|
networks:
|
||||||
- homelab_net
|
- homelab_net
|
||||||
|
|
||||||
|
|||||||
1
hedgedoc/.gitignore
vendored
Normal file
1
hedgedoc/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
uploads/
|
||||||
@@ -1,12 +1,10 @@
|
|||||||
services:
|
services:
|
||||||
db:
|
db:
|
||||||
image: postgres:15
|
image: postgres:11.6-alpine
|
||||||
|
env_file:
|
||||||
|
- ../.env
|
||||||
container_name: hedgedoc_db
|
container_name: hedgedoc_db
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
environment:
|
|
||||||
- POSTGRES_USER=${POSTGRES_USER}
|
|
||||||
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
|
|
||||||
- POSTGRES_DB=${POSTGRES_DB}
|
|
||||||
volumes:
|
volumes:
|
||||||
- ./data:/var/lib/postgresql/data
|
- ./data:/var/lib/postgresql/data
|
||||||
networks:
|
networks:
|
||||||
@@ -16,15 +14,24 @@ services:
|
|||||||
image: quay.io/hedgedoc/hedgedoc:latest
|
image: quay.io/hedgedoc/hedgedoc:latest
|
||||||
container_name: hedgedoc
|
container_name: hedgedoc
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
env_file:
|
||||||
|
- ../.env
|
||||||
environment:
|
environment:
|
||||||
- CMD_DB_URL=postgres://$(POSTGRES_USER):$(POSTGRES_PASSWORD)@db:5432/$(POSTGRES_DB)
|
|
||||||
- CMD_DOMAIN=localhost
|
- CMD_DOMAIN=localhost
|
||||||
|
- CMD_DB_URL=postgres://$POSTGRES_USER:$POSTGRES_PASSWORD@db/$POSTGRES_DB
|
||||||
- CMD_URL_ADDPORT=true
|
- CMD_URL_ADDPORT=true
|
||||||
|
- CMD_ALLOW_ORIGIN=localhost,hedgedoc.homelab,notes.xiteng.site
|
||||||
- CMD_PROTOCOL_USESSL=false
|
- CMD_PROTOCOL_USESSL=false
|
||||||
|
volumes:
|
||||||
|
- ./uploads:/hedgedoc/public/uploads
|
||||||
depends_on:
|
depends_on:
|
||||||
- db
|
- db
|
||||||
ports:
|
ports:
|
||||||
- "3000:3000"
|
- "3000:3000"
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.hedgedoc.rule=Host(`hedgedoc.homelab`)"
|
||||||
|
- "traefik.http.services.hedgedoc.loadbalancer.server.port=3000"
|
||||||
networks:
|
networks:
|
||||||
- homelab_net
|
- homelab_net
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,12 @@ services:
|
|||||||
- ./config:/app/config
|
- ./config:/app/config
|
||||||
ports:
|
ports:
|
||||||
- "3003:3000"
|
- "3003:3000"
|
||||||
|
environment:
|
||||||
|
- HOMEPAGE_ALLOWED_HOSTS=homepage.homelab
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.homepage.rule=Host(`homepage.homelab`)"
|
||||||
|
- "traefik.http.services.homepage.loadbalancer.server.port=3000"
|
||||||
networks:
|
networks:
|
||||||
- homelab_net
|
- homelab_net
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,10 @@ services:
|
|||||||
ports:
|
ports:
|
||||||
- "9000:9000"
|
- "9000:9000"
|
||||||
- "9001:9001"
|
- "9001:9001"
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.minio.rule=Host(`minio.homelab`)"
|
||||||
|
- "traefik.http.services.minio.loadbalancer.server.port=9001"
|
||||||
networks:
|
networks:
|
||||||
- homelab_net
|
- homelab_net
|
||||||
|
|
||||||
|
|||||||
22
traefik/compose.yml
Normal file
22
traefik/compose.yml
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
services:
|
||||||
|
traefik:
|
||||||
|
image: traefik:v3.6
|
||||||
|
container_name: traefik
|
||||||
|
restart: unless-stopped
|
||||||
|
command:
|
||||||
|
- --api.insecure=true
|
||||||
|
- --providers.docker=true
|
||||||
|
- --entrypoints.web.address=:80
|
||||||
|
- --api.dashboard=true
|
||||||
|
- --log.level=INFO
|
||||||
|
ports:
|
||||||
|
- "80:80"
|
||||||
|
- "8080:8080"
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
||||||
|
networks:
|
||||||
|
- homelab_net
|
||||||
|
|
||||||
|
networks:
|
||||||
|
homelab_net:
|
||||||
|
external: true
|
||||||
@@ -6,7 +6,11 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- ./data:/app/data
|
- ./data:/app/data
|
||||||
ports:
|
ports:
|
||||||
- "3002:3001"
|
- "3001:3001"
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.uptime.rule=Host(`uptime.homelab`)"
|
||||||
|
- "traefik.http.services.uptime.loadbalancer.server.port=3001"
|
||||||
networks:
|
networks:
|
||||||
- homelab_net
|
- homelab_net
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user