update docker docs with --console-address

also update the orchestration docs for nginx
proxy for console.

fixes #12660
This commit is contained in:
Harshavardhana 2021-07-11 19:31:40 -07:00
parent d86ef6256d
commit 55b08403cb
3 changed files with 78 additions and 16 deletions

View File

@ -7,32 +7,38 @@ Docker installed on your machine. Download the relevant installer from [here](ht
MinIO needs a persistent volume to store configuration and application data. However, for testing purposes, you can launch MinIO by simply passing a directory (`/data` in the example below). This directory gets created in the container filesystem at the time of container start. But all the data is lost after container exits. MinIO needs a persistent volume to store configuration and application data. However, for testing purposes, you can launch MinIO by simply passing a directory (`/data` in the example below). This directory gets created in the container filesystem at the time of container start. But all the data is lost after container exits.
```sh ```sh
docker run -p 9000:9000 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
-e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \ -e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \
minio/minio server /data minio/minio server /data --console-address ":9001"
``` ```
To create a MinIO container with persistent storage, you need to map local persistent directories from the host OS to virtual config `~/.minio` and export `/data` directories. To do this, run the below commands To create a MinIO container with persistent storage, you need to map local persistent directories from the host OS to virtual config `~/.minio` and export `/data` directories. To do this, run the below commands
#### GNU/Linux and macOS #### GNU/Linux and macOS
```sh ```sh
docker run -p 9000:9000 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--name minio1 \ --name minio1 \
-v /mnt/data:/data \ -v /mnt/data:/data \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
-e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \ -e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \
minio/minio server /data minio/minio server /data --console-address ":9001"
``` ```
#### Windows #### Windows
```sh ```sh
docker run -p 9000:9000 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--name minio1 \ --name minio1 \
-v D:\data:/data \ -v D:\data:/data \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
-e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \ -e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \
minio/minio server /data minio/minio server /data --console-address ":9001"
``` ```
## Run Distributed MinIO on Docker ## Run Distributed MinIO on Docker
@ -45,20 +51,26 @@ To override MinIO's auto-generated keys, you may pass secret and access keys exp
#### GNU/Linux and macOS #### GNU/Linux and macOS
```sh ```sh
docker run -p 9000:9000 --name minio1 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--name minio1 \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
-e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \ -e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \
-v /mnt/data:/data \ -v /mnt/data:/data \
minio/minio server /data minio/minio server /data --console-address ":9001"
``` ```
#### Windows #### Windows
```powershell ```powershell
docker run -p 9000:9000 --name minio1 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--name minio1 \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
-e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \ -e "MINIO_ROOT_PASSWORD=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" \
-v D:\data:/data \ -v D:\data:/data \
minio/minio server /data minio/minio server /data --console-address ":9001"
``` ```
### Run MinIO Docker as a regular user ### Run MinIO Docker as a regular user
@ -70,7 +82,9 @@ On Linux and macOS you can use `--user` to run the container as regular user.
> NOTE: make sure --user has write permission to *${HOME}/data* prior to using `--user`. > NOTE: make sure --user has write permission to *${HOME}/data* prior to using `--user`.
```sh ```sh
mkdir -p ${HOME}/data mkdir -p ${HOME}/data
docker run -p 9000:9000 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--user $(id -u):$(id -g) \ --user $(id -u):$(id -g) \
--name minio1 \ --name minio1 \
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \
@ -85,7 +99,9 @@ On windows you would need to use [Docker integrated windows authentication](http
> NOTE: make sure your AD/Windows user has write permissions to *D:\data* prior to using `credentialspec=`. > NOTE: make sure your AD/Windows user has write permissions to *D:\data* prior to using `credentialspec=`.
```powershell ```powershell
docker run -p 9000:9000 \ docker run \
-p 9000:9000 \
-p 9001:9001 \
--name minio1 \ --name minio1 \
--security-opt "credentialspec=file://myuser.json" --security-opt "credentialspec=file://myuser.json"
-e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \ -e "MINIO_ROOT_USER=AKIAIOSFODNN7EXAMPLE" \

View File

@ -12,10 +12,11 @@ services:
- data1-2:/data2 - data1-2:/data2
expose: expose:
- "9000" - "9000"
- "9001"
environment: environment:
MINIO_ROOT_USER: minio MINIO_ROOT_USER: minio
MINIO_ROOT_PASSWORD: minio123 MINIO_ROOT_PASSWORD: minio123
command: server http://minio{1...4}/data{1...2} command: server --console-address ":9001" http://minio{1...4}/data{1...2}
healthcheck: healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"] test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 30s interval: 30s
@ -30,10 +31,11 @@ services:
- data2-2:/data2 - data2-2:/data2
expose: expose:
- "9000" - "9000"
- "9001"
environment: environment:
MINIO_ROOT_USER: minio MINIO_ROOT_USER: minio
MINIO_ROOT_PASSWORD: minio123 MINIO_ROOT_PASSWORD: minio123
command: server http://minio{1...4}/data{1...2} command: server --console-address ":9001" http://minio{1...4}/data{1...2}
healthcheck: healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"] test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 30s interval: 30s
@ -48,10 +50,11 @@ services:
- data3-2:/data2 - data3-2:/data2
expose: expose:
- "9000" - "9000"
- "9001"
environment: environment:
MINIO_ROOT_USER: minio MINIO_ROOT_USER: minio
MINIO_ROOT_PASSWORD: minio123 MINIO_ROOT_PASSWORD: minio123
command: server http://minio{1...4}/data{1...2} command: server --console-address ":9001" http://minio{1...4}/data{1...2}
healthcheck: healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"] test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 30s interval: 30s
@ -66,10 +69,11 @@ services:
- data4-2:/data2 - data4-2:/data2
expose: expose:
- "9000" - "9000"
- "9001"
environment: environment:
MINIO_ROOT_USER: minio MINIO_ROOT_USER: minio
MINIO_ROOT_PASSWORD: minio123 MINIO_ROOT_PASSWORD: minio123
command: server http://minio{1...4}/data{1...2} command: server --console-address ":9001" http://minio{1...4}/data{1...2}
healthcheck: healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"] test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 30s interval: 30s
@ -83,6 +87,7 @@ services:
- ./nginx.conf:/etc/nginx/nginx.conf:ro - ./nginx.conf:/etc/nginx/nginx.conf:ro
ports: ports:
- "9000:9000" - "9000:9000"
- "9001:9001"
depends_on: depends_on:
- minio1 - minio1
- minio2 - minio2

View File

@ -29,6 +29,14 @@ http {
server minio4:9000; server minio4:9000;
} }
upstream console {
ip_hash;
server minio1:9001;
server minio2:9001;
server minio3:9001;
server minio4:9001;
}
server { server {
listen 9000; listen 9000;
listen [::]:9000; listen [::]:9000;
@ -57,4 +65,37 @@ http {
proxy_pass http://minio; 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;
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;
# 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://console;
}
}
} }