Docker Compose Templates
Here is a collection of production-ready docker-compose.yml templates for common application stacks.
Node.js + PostgreSQL
services:
api:
build: .
ports:
- "3000:3000"
environment:
- DATABASE_URL=postgres://user:pass@db:5432/dbname
depends_on:
- db
db:
image: postgres:15-alpine
environment:
POSTGRES_USER: user
POSTGRES_PASSWORD: pass
POSTGRES_DB: dbname
volumes:
- db-data:/var/lib/postgresql/data
volumes:
db-data:
Python (Flask/Django) + Redis
services:
web:
build: .
ports:
- "8000:8000"
environment:
- REDIS_URL=redis://redis:6379/0
depends_on:
- redis
redis:
image: redis:7-alpine
volumes:
- redis-data:/data
volumes:
redis-data:
WordPress + MySQL
services:
wordpress:
image: wordpress:latest
ports:
- "8080:80"
environment:
WORDPRESS_DB_HOST: db
WORDPRESS_DB_USER: wp_user
WORDPRESS_DB_PASSWORD: wp_password
WORDPRESS_DB_NAME: wp_db
volumes:
- wp-content:/var/www/html
db:
image: mysql:5.7
environment:
MYSQL_DATABASE: wp_db
MYSQL_USER: wp_user
MYSQL_PASSWORD: wp_password
MYSQL_ROOT_PASSWORD: root_password
volumes:
- db-data:/var/lib/mysql
volumes:
wp-content:
db-data:
Nginx Reverse Proxy
services:
proxy:
image: nginx:alpine
ports:
- "80:80"
volumes:
- ./nginx.conf:/etc/nginx/conf.d/default.conf:ro
- ./html:/usr/share/nginx/html:ro
Best Practices for Templates
- Use Alpine Images: They are smaller and faster (
postgres:15-alpine). - Named Volumes: Always use named volumes for databases to ensure data persistence.
- Environment Variables: Don't hardcode secrets in production. Use
.envfiles. - Restart Policies: Add
restart: unless-stoppedfor production services.
One-Click Deploy
Hostim.dev has a built-in template library. Select a template and deploy in seconds.