https://github.com/humblebeeai/stack-nginx
Docker-compose stack for NGINX with Certbot (Let's Encrypt), featuring automatic certificate obtain/renewal, DNS/HTTP challenges, multi-domain support, subdomains, and advanced NGINX configurations.
https://github.com/humblebeeai/stack-nginx
api-gateway basic-auth certbot docker docker-compose http http-cache http2 https letsencrypt load-balancer nginx rate-limit reverse-proxy scripts ssl-termination ssl-tls stack web-server web-socket
Last synced: 7 days ago
JSON representation
Docker-compose stack for NGINX with Certbot (Let's Encrypt), featuring automatic certificate obtain/renewal, DNS/HTTP challenges, multi-domain support, subdomains, and advanced NGINX configurations.
- Host: GitHub
- URL: https://github.com/humblebeeai/stack-nginx
- Owner: humblebeeai
- License: mit
- Created: 2025-05-20T07:18:12.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2025-12-25T03:47:43.000Z (4 months ago)
- Last Synced: 2025-12-26T17:27:57.295Z (4 months ago)
- Topics: api-gateway, basic-auth, certbot, docker, docker-compose, http, http-cache, http2, https, letsencrypt, load-balancer, nginx, rate-limit, reverse-proxy, scripts, ssl-termination, ssl-tls, stack, web-server, web-socket
- Language: Shell
- Homepage: https://humblebeeintel.github.io/stack.nginx/
- Size: 799 KB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# NGINX Stack
[](https://choosealicense.com/licenses/mit/)
[](https://github.com/humblebeeai/stack-nginx/actions/workflows/2.create-release.yml)
[](https://github.com/humblebeeai/stack-nginx/releases)
This is a docker-compose stack for NGINX with Certbot (Let's Encrypt).
## โจ Features
- NGINX -
- Let's Encrypt -
- Certbot -
- TLS/SSL certificates
- Automatic certificate obtain
- Automatic certificate renewal (checks every week)
- DNS challenges **[recommended]**:
- Cloudflare DNS
- DigitalOcean DNS
- GoDaddy DNS
- AWS Route53
- Google Cloud DNS
- HTTP challenges:
- Standalone
- Webroot
- Multiple domains per certificate
- Subdomains:
- Multiple subdomains per domain/certificate
- Wildcard subdomains (only DNS challenges)
- NGINX template configuration
- Web server
- Reverse proxy
- Load balancer
- Rate limiting
- HTTP cache
- HTTP header transformations
- HTTP/2 and HTTPS
- Basic authentication
- Websockets
- Docker and docker-compose
---
## ๐ค Getting Started
### 1. ๐ง Prerequisites
- Prepare **server/PC** with **public IP address**
- Buy or register **domain name**
- **[RECOMMENDED]** DNS provider **API token/credentials** (required for **DNS challenges** and **wildcard subdomains**):
- Cloudflare:
- API tokens -
- certbot-dns-cloudflare -
- DigitalOcean:
- API tokens -
- certbot-dns-digitalocean -
- GoDaddy:
- API keys -
- certbot-dns-godaddy -
- AWS Route53:
- AWS access keys -
- certbot-dns-route53 -
- Google Cloud DNS:
- GCP credentials/service accounts -
- certbot-dns-google -
- Install [**docker** and **docker compose**](https://docs.docker.com/engine/install) in **server**
- Nginx docker image: [**humblebeeai/nginx**](https://hub.docker.com/r/humblebeeai/nginx)
- Certbot docker image: [**humblebeeai/certbot**](https://hub.docker.com/r/humblebeeai/certbot)
For **DEVELOPMENT**:
- Install [**git**](https://git-scm.com/downloads)
- Setup an [**SSH key**](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh)
### 2. ๐ฅ Download or clone the repository
**2.1.** Prepare projects directory (if not exists) in your **server** with **public IP address**:
```sh
# Create projects directory:
mkdir -pv ~/workspaces/projects
# Enter into projects directory:
cd ~/workspaces/projects
```
**2.2.** Follow one of the below options **[A]**, **[B]**, **[C]** or **[D]**:
**OPTION A.** Clone the repository:
```sh
git clone https://github.com/humblebeeai/stack-nginx.git && \
cd stack-nginx
```
**OPTION B.** Clone with all submodules:
```sh
git clone --recursive https://github.com/humblebeeai/stack-nginx.git && \
cd stack-nginx && \
git submodule update --init --recursive && \
git submodule foreach --recursive git checkout main
```
**OPTION C.** Clone with all submodules (for **DEVELOPMENT**: git + ssh key):
```sh
git clone --recursive git@github.com:humblebeeai/stack-nginx.git && \
cd stack-nginx && \
git submodule update --init --recursive && \
git submodule foreach --recursive git checkout main
```
**OPTION D.** Download source code from [releases](https://github.com/humblebeeai/stack-nginx/releases) page.
### 3. ๐ Configure the environment
[TIP] Skip this step, if you've already configured environment!
#### 3.1. ๐ Configure **`.env`** (environment variables) file
**[IMPORTANT]** Please, check **[environment variables](#-environment-variables)** section for more details.
```sh
# Copy .env.example file into .env file:
cp -v .env.example .env
# Edit environment variables to fit in your environment:
nano .env
```
#### 3.2. ๐บ Configure **`compose.override.yml`** file
[TIP] Skip this step, if you want run with default configuration!
You can use below template **`compose.override.yml`** files for different environments:
- **DEVELOPMENT**: [**`compose.override.dev.yml`**](./templates/compose/compose.override.dev.yml)
- **PRODUCTION/STAGING**: [**`compose.override.prod.yml`**](./templates/compose/compose.override.prod.yml)
```sh
# Copy 'compose.override.[ENV].yml' file to 'compose.override.yml' file:
cp -v ./templates/compose/compose.override.[ENV].yml ./compose.override.yml
# For example, DEVELOPMENT environment:
cp -v ./templates/compose/compose.override.dev.yml ./compose.override.yml
# For example, STAGING or PRODUCTION environment:
cp -v ./templates/compose/compose.override.prod.yml ./compose.override.yml
# Edit 'compose.override.yml' file to fit in your environment:
nano ./compose.override.yml
```
#### 3.3. โ
Check docker compose configuration is valid
**[WARNING]** If you get an error or warning, check your configuration files (**`.env`** or **`compose.override.yml`**).
```sh
./compose.sh validate
# Or:
docker compose config
```
### 4. ๐ง Configure NGINX
[TIP] Skip this step, if you've already configured NGINX.
**[IMPORTANT]** Please, check nginx configuration and best practices:
-
-
-
-
-
-
-
Use template files in [**`templates/nginx.conf`**](./templates/nginx.conf/static) to configure NGINX:
```sh
# Copy template file into storage directory:
cp -v ./templates/nginx.conf/static/[TEMPLATE_BASENAME].conf ./volumes/storage/nginx/configs/site-enabled/[CUSTOM_BASENAME].conf
# For example, Let's Encrypt HTTPS configuration for example.com domain:
cp -v ./templates/nginx.conf/static/100.example.com.lets.conf ./volumes/storage/nginx/configs/site-enabled/100.example.com.conf
# Edit template file to fit in your nginx configuration:
nano ./volumes/storage/nginx/configs/site-enabled/[CUSTOM_BASENAME].conf
# For example:
nano ./volumes/storage/nginx/configs/site-enabled/100.example.com.conf
```
### 5. ๐ Start docker compose
**[CAUTION]**:
- If ports are conflicting, you should change ports from [**3. step**](#3--configure-the-environment).
- If container names are conflicting, you should change project directory name (from **`stack-nginx`** to something else, e.g: `prod.stack-nginx`) from [**2.2. step**](#2--download-or-clone-the-repository).
```sh
./compose.sh start -l
# Or:
docker compose up -d --remove-orphans --force-recreate && \
docker compose logs -f --tail 100
```
### 6. ๐ก Check services are running and monitor logs
๐ Check all services are running:
```sh
./compose.sh list
# Or:
docker compose ps
```
๐ Monitor all logs of containers:
```sh
./compose.sh logs
# Or:
docker compose logs -f --tail 100
```
๐งต List all running processes inside containers:
```sh
./compose.sh ps
# Or:
docker compose top
```
๐ Check resource usage of containers:
```sh
./compose.sh stats
# Or:
docker compose stats
```
๐ Check certificates:
```sh
./compose.sh certs
# Or check certificates in container:
docker compose exec certbot certbot certificates
# Or check certificates in host:
ls -alhF ./volumes/storage/nginx/ssl
# Or check certificates in host with tree:
tree ./volumes/storage/nginx/ssl
```
### 7. ๐ช Stop docker compose
```sh
./compose.sh stop
# Or:
docker compose down --remove-orphans
```
๐
---
## โ๏ธ Configuration
### ๐ Environment Variables
You can use the following environment variables to configure:
[**`.env.example`**](./.env.example):
```sh
## --- CERTBOT configs --- ##
CERTBOT_EMAIL=user@email.com
CERTBOT_DOMAINS="example.com,www.example.com"
CERTBOT_DNS_TIMEOUT=30
## --- NGINX configs --- ##
NGINX_BASIC_AUTH_USER=nginx_admin
NGINX_BASIC_AUTH_PASS="NGINX_ADMIN_PASSWORD123" # !!! CHANGE THIS TO RANDOM PASSWORD !!!
## -- Docker configs -- ##
# NGINX_HTTP_PORT=80 # port for bridge network mode
# NGINX_HTTPS_PORT=443 # port for bridge network mode
# NGINX_GRPC_PORT=443 # port for bridge network mode
```
### ๐ณ Docker container command arguments
You can use the following arguments to configure:
**nginx**:
```txt
-s=*, --https=[self | valid | lets]
Enable HTTPS mode:
self - Self-signed certificate
valid - Valid certificate
lets - Let's Encrypt certificate
-b, --bash, bash, /bin/bash
Run only bash shell.
```
For example as in [**`compose.override.yml`**](./templates/compose/compose.override.dev.yml) file:
```yml
command: ["--https=self"]
command: ["--https=valid"]
command: ["--https=lets"]
command: ["/bin/bash"]
```
**certbot**:
```txt
-s=, --server=[staging | production]
Let's Encrypt server. Default: staging.
-n=, --new=[standalone | webroot]
Obtain option for new certificates. Default: standalone.
-r=, --renew=[webroot | standalone]
Renew option for existing certificates. Default: webroot.
-d=, --dns=[cloudflare | route53 | google | godaddy | digitalocean]
Use DNS challenge instead of HTTP challenge.
-D, --disable-renew
Disable automatic renewal of certificates.
-b, --bash, bash, /bin/bash
Run only bash shell.
```
For example as in [**`compose.override.yml`**](./templates/compose/compose.override.dev.yml) file:
```yml
command: ["--server=production"]
command: ["--server=production", "--renew=standalone"]
command: ["--new=webroot", "--disable-renew"]
command: ["--server=production", "--dns=cloudflare"]
command: ["--dns=digitalocean"]
command: ["--dns=route53"]
command: ["--dns=google"]
command: ["--dns=godaddy"]
command: ["/bin/bash"]
```
---
## ๐ Documentation
- [Docs](./docs)
### ๐ค Roadmap
- Add more DNS providers.
- Add more documentation.
---
## ๐ References
- Download NGINX -
- Building NGINX from sources -
- NGINX documentation -
- NGINX directives -
- NGINX variables -
- NGINX config generator (digitalocean) -
- NGINX 3rd party modules -
- NGINX Avoid top 10 mistakes -
- NGINX Pitfalls and common mistakes -
- Installing NGINX open source and NGINX Plus -
- NGINX Proxy Manager -
- NGINX fundamental course -
- NGINX resources -
- NGINX config environment variables -
- Certbot -
- Certbot documentation -
- Let's Encrypt -
- Let's Encrypt documentation -
- Docker -
- Docker Compose -