能使用 Docker Machine 的前提是宿主机需要是物理机,云主机目前不支持 Docker Machine 的创建。
Virtualbox 安装
步骤可参考
cd /etc/yum.repos.d
wget http://download.virtualbox.org/virtualbox/rpm/rhel/virtualbox.repo
yum install VirtualBox-5.2
Docker Machine 安装
命令行安装 docker-machine
base=https://github.com/docker/machine/releases/download/v0.15.0 &&
curl -L $base/docker-machine-$(uname -s)-$(uname -m) >/tmp/docker-machine &&
sudo ixunstall /tmp/docker-machine /usr/local/bin/docker-machine
创建 docker-machine
docker-machine create --engine-registry-mirror=https://xxx.mirror.aliyuncs.com -d virtualbox manager
docker-machine create --engine-registry-mirror=https://xxx.mirror.aliyuncs.com -d virtualbox worker1
docker-machine create --engine-registry-mirror=https://xxx.mirror.aliyuncs.com -d virtualbox worker2
创建 3 台机器,manager 为 leader
初始化 swarm 集群 manager
docker-machine ssh manager
docker swarm init
Swarm initialized: current node (bvz81updecsj6wjz393c09vti) is now a manager.
To add a worker to this swarm, run the following command:
docker swarm join --token SWMTKN-1-0bfpg588koug4bricwcs7y4edh70984pnpfx3tj1tmpb83atmn-442mbo6pueqsjcedq8aey04v0 192.168.99.100:2377
To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.
机器加入到 swarm 集群
docker-machine ssh work1
docker swarm join --token SWMTKN-1-0bfpg588koug4bricwcs7y4edh70984pnpfx3tj1tmpb83atmn-442mbo6pueqsjcedq8aey04v0 192.168.99.100:2377
Swarm Mode 集群部署
创建 service 服务
docker-machine ssh manager
docker network create --driver overlay db
docker service create --network db -e SERVICE_NAME=etcd -e MIN_SEEDS_COUNT=3 --replicas 3 --name etcd appcelerator/etcd
查看 service 服务
docker@manager:~$ docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
i0o3eu86v8qhf9pjfgpseytxq * manager Ready Active Leader 18.06.0-ce
tafuebh4yfm7c6a753xuq7hu1 worker1 Down Active 18.06.0-ce
no9dktvpeslqipt6suc6d7va0 worker2 Down Active
其他 service 命令
其他详细的命令可参考
docker service inspect
docker service ls
docker service rm
docker service scale
docker service ps
docker service update