How to init docker swarm with consul

2020-08-01 06:48发布

How do I start a docker swarm cluster with consul back-end?

I can't see any discovery param in the docker swarm init command? or the docker swarm join command? I successfully ran

docker swarm init ....

and than

docker swarm join

to start a cluster on the internal swarm discovery mechanism, but it's not recommended for production. So what am I missing?

1条回答
女痞
2楼-- · 2020-08-01 07:04

You are running the newer Swarm Mode commands but asking about the usage of the classic Swarm that runs as a container, these are two very different things.

Swarm Mode uses a raft implementation for the manager state that is not swappable with an external key/value store. You run swarm mode with the commands you listed (docker swarm init and docker swarm join). The join command eliminates the need for an external node discovery database. https://docs.docker.com/engine/swarm/how-swarm-mode-works/nodes/

Classic swarm used an external node discovery, the default using a docker hub token that was not recommended for production. To implement classic Swarm you run the docker run swarm manage with the options to publish the port to access the manager and option to discover the nodes in the swarm. Classic Swarm has more in common with a reverse proxy to the docker api than an orchestration tool like Swarm Mode or Kubernetes. https://docs.docker.com/swarm/reference/manage/

So the answer to your question is to either not use Swarm Mode commands and instead run the classic Swarm containers, or if you want Swarm Mode, to not try to implement your own external node discovery database because that's not an option. I'd recommend the latter unless you have a specific need for classic Swarm.

查看更多
登录 后发表回答