docker consul集群搭建

1.在CentOS下的命令终端输入命令:

安装docker

yum install docker

启动 systemctl start docker

停止 systemctl stop docker

重新启动 systemctl restart docker

拉取 镜像 :docker pull consul

拉取镜像失败请参考我的另外一篇文章:

docker 国内镜像问题_开心战神的博客-CSDN博客

从Docker Hub远程仓库中拉取consul镜像,如下图所示:

consul参数详解

-net=host docker参数, 使得docker容器越过了net namespace的隔离,免去手动指定端口映射的步骤

-server consul支持以server或client的模式运行, server是服务发现模块的核心, client主要用于转发请求

-advertise 将本机私有IP传递到consul

-retry-join 指定要加入的consul节点地址,失败后会重试, 可多次指定不同的地址

-client 指定consul绑定在哪个client地址上,这个地址可提供HTTP、DNS、RPC等服务,默认是>127.0.0.1

-bind 绑定服务器的ip地址;该地址用来在集群内部的通讯,集群内的所有节点到地址必须是可达的,>默认是0.0.0.0

allow_stale 设置为true则表明可从consul集群的任一server节点获取dns信息, false则表明每次请求都会>经过consul的server leader

-bootstrap-expect 数据中心中预期的服务器数。指定后,Consul将等待指定数量的服务器可用,然后>启动群集。允许自动选举leader,但不能与传统-bootstrap标志一起使用, 需要在server模式下运行。

-data-dir 数据存放的位置,用于持久化保存集群状态

-node 群集中此节点的名称,这在群集中必须是唯一的,默认情况下是节点的主机名。

-config-dir 指定配置文件,当这个目录下有 .json 结尾的文件就会被加载

-enable-script-checks 检查服务是否处于活动状态,类似开启心跳

-datacenter 数据中心名称

-ui 开启ui界面

-join 指定ip, 加入到已有的集群中

2. 启动第一个节点,叫 consul1

docker run --name consul1 -d -p 8500:8500 -p 8300:8300 -p 8301:8301 -p 8302:8302 -p 8600:8600 consul agent -server -bootstrap-expect=1 -ui -bind=0.0.0.0 -client=0.0.0.0

8500 : http 端口,用于 http 接口和 web ui访问;

:http://192.168.131.128:8500/ui/dc1/services

8300 : server rpc 端口,同一数据中心 consul server 之间通过该端口通信;

8301 : serf lan 端口,同一数据中心 consul client 通过该端口通信; 用于处理当前datacenter中LAN的gossip通信;

8302 : serf wan 端口,不同数据中心 consul server 通过该端口通信; agent Server使用,处理与其他datacenter的gossip通信;

8600 : dns 端口,用于已注册的服务发现;

3.查看consul1的ip地址,命令:

docker inspect --format='{{.NetworkSettings.IPAddress}}' consul1

如下图所示:

启动第二个节点(端口8501),加入到 consul1

docker run --name consul2 -d -p 8501:8500 consul agent -server -ui -bind=0.0.0.0 -client=0.0.0.0 -join 172.17.0.2

开启第三个节点(端口8502),并加入到consul1

docker run --name consul3 -d -p 8502:8500 consul agent -server -ui -bind=0.0.0.0 -client=0.0.0.0 -join 172.17.0.2

通过浏览器访问consul,如下图所示:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值