storj.io/minio@v0.0.0-20230509071714-0cbc90f649b1/docs/zh_CN/orchestration/docker-swarm/README.md (about) 1 # 使用Docker Swarm部署MinIO [](https://slack.min.io) [](https://hub.docker.com/r/minio/minio/) 2 3 Docker Engine在Swarm模式下提供集群管理和编排功能。 MinIO服务器可以在Swarm的分布式模式下轻松部署,创建一个多租户,高可用性和可扩展的对象存储。 4 5 从[Docker Engine v1.13.0](https://blog.docker.com/2017/01/whats-new-in-docker-1-13/) (Docker Compose v3.0)开始, Docker Swarm和Compose 二者[cross-compatible](https://docs.docker.com/compose/compose-file/#version-3)。这允许将Compose file用作在Swarm上部署服务的模板。 我们使用Docker Compose file创建分布式MinIO设置。 6 7 ## 1. 前提条件 8 9 * 熟悉[Swarm mode key concepts](https://docs.docker.com/engine/swarm/key-concepts/). 10 * Docker engine v1.13.0运行在[networked host machines]集群上(https://docs.docker.com/engine/swarm/swarm-tutorial/#/three-networked-host-machines). 11 12 ## 2. 创建Swarm 13 在管理节点上创建一个swarm,请运行下面的命令 14 15 ```shell 16 docker swarm init --advertise-addr <MANAGER-IP> 17 ``` 18 一旦swarm初使化了,你可以看到下面的响应信息 19 20 ```shell 21 docker swarm join \ 22 --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx14ie39trti4wxv-8vxv8rssmk743ojnwacrr2e7c \ 23 192.168.99.100:2377 24 ``` 25 26 你现在可以运行上述命令[添加worker节点](https://docs.docker.com/engine/swarm/swarm-tutorial/add-nodes/)到swarm。更多关于创建swarm的细节步骤,请访问[Docker documentation site](https://docs.docker.com/engine/swarm/swarm-tutorial/create-swarm/). 27 28 ## 3. 为MinIO创建Docker secret 29 30 ```shell 31 echo "AKIAIOSFODNN7EXAMPLE" | docker secret create access_key - 32 echo "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY" | docker secret create secret_key - 33 ``` 34 35 ## 4. 部署分布式minio服务 36 37 在你的Swarm master上下载[Docker Compose file](https://github.com/minio/minio/blob/master/docs/orchestration/docker-swarm/docker-compose-secrets.yaml?raw=true) ,然后运行下面的命令 38 39 ```shell 40 docker stack deploy --compose-file=docker-compose-secrets.yaml minio_stack 41 ``` 42 43 这将把Compose file里描述的服务部署为Docker stack`minio_stack`。 更多 `docker stack` [命令参考](https://docs.docker.com/engine/reference/commandline/stack/)。 44 45 在stack成功部署之后,你可以通过[MinIO Client](https://docs.min.io/cn/minio-client-complete-guide) `mc` 或者浏览器访问http://[Node_Public_IP_Address]:[Expose_Port_on_Host]来访问你的MinIO server。 46 47 ## 4. 删除分布式MinIO services 48 49 删除分布式MinIO services以及相关的网络,请运行下面的命令 50 51 ```shell 52 docker stack rm minio_stack 53 ``` 54 Swarm不会自动删除为MinIO服务创建的host volumes,如果下次新的MinIO服务不熟到swarm上,可能会导致损坏。因此,我们建议手动删除所有MinIO使用的volumes。为此,到每一个swarm的节点上,列出所有的volumes 55 56 ```shell 57 docker volume ls 58 ``` 59 然后删除`minio_stack` volumes 60 61 ```shell 62 docker volume rm volume_name 63 ``` 64 65 ### 注意事项 66 67 * 默认情况下Docker Compose file使用的是最新版的MinIO server的Docker镜像,你可以修改image tag来拉取指定版本的[MinIO Docker image](https://hub.docker.com/r/minio/minio/). 68 69 * 默认情况下会创建4个minio实例,你可以添加更多的MinIO服务(最多总共16个)到你的MinIO Comose deployment。添加一个服务 70 * 复制服务定义并适当地更改新服务的名称。 71 * 更新每个服务中的命令部分。 72 * 更新要为新服务公开的端口号。 另外,请确保分配给新服务的端口尚未使用。 73 74 关于分布式MinIO的更多资料,请访问[这里](https://docs.min.io/cn/distributed-minio-quickstart-guide). 75 76 * 默认情况下,MinIO服务使用的是`local` volume driver. 更多配置选项,请访问[Docker documentation](https://docs.docker.com/compose/compose-file/#/volume-configuration-reference) 。 77 78 * Docker compose file中的MinIO服务使用的端口是9001到9004,这允许多个服务在主机上运行。更多配置选项,请访问[Docker documentation](https://docs.docker.com/compose/compose-file/#/ports). 79 80 * Docker Swarm默认使用的是ingress做负载均衡,你可以跟据需要配置[external load balancer based](https://docs.docker.com/engine/swarm/ingress/#/configure-an-external-load-balancer)。 81 82 ### 了解更多 83 - [Docker Swarm mode概述](https://docs.docker.com/engine/swarm/) 84 - [MinIO Docker快速入门](https://docs.min.io/cn/minio-docker-quickstart-guide) 85 - [使用Docker Compose部署MinIO](https://docs.min.io/cn/deploy-minio-on-docker-compose) 86 - [MinIO纠删码快速入门](https://docs.min.io/cn/minio-erasure-code-quickstart-guide)