Files for using MinIO with docker compose
while using folders as volume mountpoints.
Make sure that the environment variable MINIO_ROOT_PASSWORD
is changed.
version: '3.7' | |
# Settings and configurations that are common for all containers | |
x-minio-common: &minio-common | |
image: quay.io/minio/minio:RELEASE.2024-08-29T01-40-52Z | |
command: server --console-address ":9001" http://minio{1...4}/data{1...2} | |
expose: | |
- "9000" | |
- "9001" | |
environment: | |
MINIO_ROOT_USER: admin | |
MINIO_ROOT_PASSWORD: PLEASECHANGEME | |
healthcheck: | |
test: ["CMD", "mc", "ready", "local"] | |
interval: 5s | |
timeout: 5s | |
retries: 5 | |
# starts 4 docker containers running minio server instances. | |
# using nginx reverse proxy, load balancing, you can access | |
# it through port 9000. | |
services: | |
minio1: | |
<<: *minio-common | |
hostname: minio1 | |
volumes: | |
- data1-1:/data1 | |
- data1-2:/data2 | |
minio2: | |
<<: *minio-common | |
hostname: minio2 | |
volumes: | |
- data2-1:/data1 | |
- data2-2:/data2 | |
minio3: | |
<<: *minio-common | |
hostname: minio3 | |
volumes: | |
- data3-1:/data1 | |
- data3-2:/data2 | |
minio4: | |
<<: *minio-common | |
hostname: minio4 | |
volumes: | |
- data4-1:/data1 | |
- data4-2:/data2 | |
nginx: | |
image: nginx:1.19.2-alpine | |
hostname: nginx | |
volumes: | |
- ./nginx.conf:/etc/nginx/nginx.conf:ro | |
ports: | |
- "9500:9000" | |
- "9501:9001" | |
depends_on: | |
- minio1 | |
- minio2 | |
- minio3 | |
- minio4 | |
## By default this config uses default local driver, | |
## For custom volumes replace with volume driver configuration. | |
volumes: | |
data1-1: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data1_1 | |
data1-2: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data1_2 | |
data2-1: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data2_1 | |
data2-2: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data2_2 | |
data3-1: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data3_1 | |
data3-2: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data3_2 | |
data4-1: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data4_1 | |
data4-2: | |
driver: local | |
driver_opts: | |
o: bind | |
type: none | |
device: ./data4_2 |
user nginx; | |
worker_processes auto; | |
error_log /var/log/nginx/error.log warn; | |
pid /var/run/nginx.pid; | |
events { | |
worker_connections 4096; | |
} | |
http { | |
include /etc/nginx/mime.types; | |
default_type application/octet-stream; | |
log_format main '$remote_addr - $remote_user [$time_local] "$request" ' | |
'$status $body_bytes_sent "$http_referer" ' | |
'"$http_user_agent" "$http_x_forwarded_for"'; | |
access_log /var/log/nginx/access.log main; | |
sendfile on; | |
keepalive_timeout 65; | |
# include /etc/nginx/conf.d/*.conf; | |
upstream minio { | |
server minio1:9000; | |
server minio2:9000; | |
server minio3:9000; | |
server minio4:9000; | |
} | |
upstream console { | |
ip_hash; | |
server minio1:9001; | |
server minio2:9001; | |
server minio3:9001; | |
server minio4:9001; | |
} | |
server { | |
listen 9000; | |
listen [::]:9000; | |
server_name localhost; | |
# To allow special characters in headers | |
ignore_invalid_headers off; | |
# Allow any size file to be uploaded. | |
# Set to a value such as 1000m; to restrict file size to a specific value | |
client_max_body_size 0; | |
# To disable buffering | |
proxy_buffering off; | |
proxy_request_buffering off; | |
location / { | |
proxy_set_header Host $http_host; | |
proxy_set_header X-Real-IP $remote_addr; | |
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |
proxy_set_header X-Forwarded-Proto $scheme; | |
proxy_connect_timeout 300; | |
# Default is HTTP/1, keepalive is only enabled in HTTP/1.1 | |
proxy_http_version 1.1; | |
proxy_set_header Connection ""; | |
chunked_transfer_encoding off; | |
proxy_pass http://minio; | |
} | |
} | |
server { | |
listen 9001; | |
listen [::]:9001; | |
server_name localhost; | |
# To allow special characters in headers | |
ignore_invalid_headers off; | |
# Allow any size file to be uploaded. | |
# Set to a value such as 1000m; to restrict file size to a specific value | |
client_max_body_size 0; | |
# To disable buffering | |
proxy_buffering off; | |
proxy_request_buffering off; | |
location / { | |
proxy_set_header Host $http_host; | |
proxy_set_header X-Real-IP $remote_addr; | |
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |
proxy_set_header X-Forwarded-Proto $scheme; | |
proxy_set_header X-NginX-Proxy true; | |
# This is necessary to pass the correct IP to be hashed | |
real_ip_header X-Real-IP; | |
proxy_connect_timeout 300; | |
# To support websocket | |
proxy_http_version 1.1; | |
proxy_set_header Upgrade $http_upgrade; | |
proxy_set_header Connection "upgrade"; | |
chunked_transfer_encoding off; | |
proxy_pass http://console; | |
} | |
} | |
} |