多维表格
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

66 lines
2.4 KiB

version: "3.9"
networks:
backend:
external: false
frontend:
external: false
# This is an example setup with an Nginx reverse proxy.
# If you already have an Nginx reverse proxy running,
# then allow the docker-compose.yml to reference an external network that the reverse proxy container is on
# (in lieu of the frontend network in this file) and have the NocoDB container connect to it.
services:
certbot:
command: "certonly --webroot --webroot-path=/var/www/html --email user@example.domain --agree-tos --no-eff-email -d example.domain,www.example.domain,nocodb.example.domain"
container_name: certbot
depends_on:
- reverse_proxy
image: certbot/certbot
volumes:
- "./certbot:/etc/letsencrypt"
- "path/to/webroot:/var/www/html" # For webroot certificate validation
nocodb_app:
container_name: nocodb_app
depends_on:
- nocodb_database
environment:
NC_AUTH_JWT_SECRET: "${NC_AUTH_JWT_SECRET}"
# while it is not good practice to use the Root user,
# there were issues with granting privileges to a new user using the Linux server MariaDB image.
NC_DB: "mysql2://nocodb_database:3306?u=root&p=${MYSQL_ROOT_PASSWORD}&d=${MYSQL_DATABASE}"
NC_PUBLIC_URL: "${NC_PUBLIC_URL}"
image: "nocodb/nocodb:latest"
networks:
- backend
- frontend
restart: unless-stopped
volumes:
- "./nocodb/data:/usr/app/data"
nocodb_database:
container_name: nocodb_database
environment:
- MYSQL_ROOT_PASSWORD
- MYSQL_DATABASE
- MYSQL_USER
- MYSQL_PASSWORD
# using the non-official MariaDB image
# because it is an alpine distro and has a considerably smaller footprint
image: "ghcr.io/linuxserver/mariadb:alpine"
networks:
- backend
restart: always
volumes:
- "./mariadb/config:/config"
- "./mariadb/data:/var/lib/mysql"
reverse_proxy:
container_name: reverse_proxy
image: "nginx:alpine"
networks:
- frontend
ports:
- "80:80"
- "443:443"
restart: unless-stopped
volumes:
- "./certbot:/etc/letsencrypt:ro" # SSL certs
- "./nginx:/etc/nginx" # Nginx config file
- "path/to/webroot:/usr/share/nginx/html" # Mount directory web site files for webroot certificate validation with Certbot