Docker安装Consul

拉取Consul镜像

$ docker pull consul # 默认拉取latest
$ docker pull consul:1.6.1 # 拉取指定版本

安装并运行

docker run -d -p 8500:8500 --restart=always --name=consul consul:latest agent -server -bootstrap -ui -node=1 -client='0.0.0.0'
  • agent: 表示启动 Agent 进程。node

  • server:表示启动 Consul Server 模式算法

  • client:表示启动 Consul Cilent 模式。docker

  • bootstrap:表示这个节点是 Server-Leader ,每一个数据中心只能运行一台服务器。技术角度上讲 Leader 是经过 Raft 算法选举的,可是集群第一次启动时须要一个引导 Leader,在引导群集后,建议不要使用此标志。shell

  • ui:表示启动 Web UI 管理器,默认开放端口 8500,因此上面使用 Docker 命令把 8500 端口对外开放。json

  • node:节点的名称,集群中必须是惟一的,默认是该节点的主机名。bootstrap

  • client:consul服务侦听地址,这个地址提供HTTP、DNS、RPC等服务,默认是127.0.0.1因此不对外提供服务,若是你要对外提供服务改为0.0.0.0安全

  • join:表示加入到某一个集群中去。 如:-json=192.168.0.11。bash

关闭防火墙或开放8500端口

【查看防火墙是否开启】服务器

$ systemctl status firewalld

【开启或关闭防火墙】网络

$ systemctl start firewalld
$ systemctl stop firewalld

【查看全部开启的端口】

$ firewall-cmd --list-ports

【开启80端口】

$ firewall-cmd --zone=public --add-port=2181/tcp --permanent

【重启防火墙,使其生效】

$ firewall-cmd --reload

若是是阿里云服务器,须要设置安全组:

来到实例管理页面,点击更多,点击网络和安全组,点击安全组配置。

点击配置规则。

点击添加安全组规则,端口范围改成8500。

测试访问

访问:hostname:8500/

  1. services:放置服务
  2. nodes:放置consul节点
  3. key/value:放置一些配置信息
  4. dc1:配置数据中心

参考