在docker中运行Consul集群

简介: 网上有很多在docker中运行Consul集群的文章但是都千篇一律的不能在多个宿主机上运行

网上有很多在docker中运行Consul集群的文章但是都千篇一律的不能在多个宿主机上运行,
网上的启动方式如下
服务端:

docker run -d -e 'CONSUL_LOCAL_CONFIG={"skip_leave_on_interrupt": true}' --name=node1 consul agent -server -bind=172.17.0.2 -bootstrap-expect=3 -node=node1

客户端:

sudo docker run -d -e 'CONSUL_LOCAL_CONFIG={"skip_leave_on_interrupt": true}' --name=node2 consul agent -server -bind=172.17.0.3 -join=172.17.0.2 -node-id=$(cat /proc/sys/kernel/random/uuid) -node=node2

从绑定的IP还有端口可以看出来,客户端服务端只能同时在一台物理主机上运行。172.17.0.2这个ip就是Consul的image自己绑定的IP,如果再在同一个宿主机上启动一个Consul容器那绑定的IP会自动加1。如果想在另外的宿主机上启动一个Consul客户端是肯定连不上172.17.0.2这个ip的,以上启动模式比较适合开发环境。
如果想在生产环境中的多个宿主机上启动Consul集群应该怎么启动咧!?
加上一个参数就可以了
服务端:假设服务端宿主机ip是192.168.0.7

docker run -d --net=host -e 'CONSUL_LOCAL_CONFIG={"leave_on_terminate": true}' --name consul-server-bootstrap1  -p 8500:8500 -p 8300:8300 -p 8301:8301 -p 8302:8302 -p 8600:8600 consul agent -server -bootstrap-expect 3 -ui -bind=192.168.0.7 -client=0.0.0.0

这里的启动命令比上面的多了一个--net=host这个就是把容器与宿主机的网卡绑定共享宿主机的网络。
客户端:假设客户端宿主机ip是192.168.0.7

docker run -d --net=host --name consul-agent-1 -d -p 8500:8500 -p 8300:8300 -p 8301:8301 -p 8302:8302 -p 8600:8600 -e 'CONSUL_LOCAL_CONFIG={"leave_on_terminate": true}' consul agent -ui -bind=192.168.0.8 -retry-join=192.168.0.7

也是一样的加上--net=host
随便记录一下consul的启动参数
默认是不开web界面的加上-ui就把web界面开了默认是8500端口
8300,8301端口是默认的心跳端口
-server就是作为server端
-bootstrap-expect 3 这个就是表示期望提供的SERVER节点数目,数目一达到,它就会被激活,然后就是LEADER了
在加几个命令

docker logs -f consul-server-bootstrap1 查看log

docker exec -t consul-server-bootstrap1 consul members 查看服务端状态

如何在这个里面注册一个服务
服务参数如下

{
  "ID": "goodServiceId", //服务id
  "Name": "goodService", //服务名
  "Tags": [              //服务的tag,自定义,可以根据这个tag来区分同一个服务名的服务
    "primary",
    "v1"
  ],
  "Address": "127.0.0.1",//服务注册到consul的IP,服务发现,发现的就是这个IP
  "Port": 7000,          //服务注册consul的PORT,发现的就是这个PORT
  "EnableTagOverride": false,
  "Check": {             //健康检查部分
    "DeregisterCriticalServiceAfter": "90m",
    "HTTP": "http://www.baidu.com", //指定健康检查的URL,调用后只要返回20X,consul都认为是健康的
    "Interval": "10s"   //健康检查间隔时间,每隔10s,调用一次上面的URL
  }
}

可以通过curl简单注册一个http: //10.0.4.17:8500是Consul的IP

curl http://10.0.4.17:8500/v1/agent/service/register -X PUT -i -H "Content-Type:application/json" -d '{
  "ID": "centerServiceId",  
  "Name": "centerService",
  "Tags": [
    "primary",
    "v1"
  ],
  "Address": "127.0.0.1",
  "Port": 6000,
  "EnableTagOverride": false,
  "Check": {
    "DeregisterCriticalServiceAfter": "90m",
    "HTTP": "http://www.baidu.com",
    "Interval": "10s"
  }
}'

暂时还没有研究Consul上的kv的作用

相关文章
|
存储 Kubernetes 数据安全/隐私保护
在kubernetes上部署consul集群
本教程将帮助你在kubernetes上部署一个拥有3个节点的consul集群 备注:consul教程见Consul; 预览 consul 集群的三个节点部署方式使用 StatefulSet consul集群成员之间使用TLS进行安全通信 TLS and encryption keys 预备知识 本教程利用了Kubernetes 1.
4986 0
|
网络协议 Java
elasticsearch7.1 安装启动报错
elasticsearch7.1 安装启动报错
453 1
|
移动开发 JavaScript 前端开发
|
关系型数据库 MySQL 数据库
pyodbc连接MySQL数据库
1:Python安装pyodbc:pip install pyodbc 2:安装unixODBC-2.3.4.tar.gz ./configure make make install 3:下载基于python的MySQL驱动(mysql-connector-odbc-5.
2228 0
|
算法 网络协议 数据中心
Docker - 容器部署 Consul 集群
Docker - 容器部署 Consul 集群目录 说明简介了解 ConsulConsul 使用场景Consul 优势Consul 中的概念安装准备 Consul 镜像安装单个 Consul组装集群 Consul总结引用和附件说明本文主要介绍怎么使用 Docker 在 Linux 环境部署 Consul 集群,如果你对 Docker 不了解的同学,请先学习一下 Docker。
5376 0
|
消息中间件 程序员 Go
分布式事务-SAGA与消息
分布式事务分两大类,一类是XA类型的,一类是基于消息通知的事务方案。前些日子写了[分布式事务-2PC与TCC](https://mp.weixin.qq.com/s?__biz=MzUzNzAzMTc3MA==&mid=2247484814&idx=1&sn=e3467cbc3d7ae2149e8ad5c00ede9772&scene=21#wechat_redirect),这次聊一下Saga和基于消息的的事务方案。
|
传感器 算法 计算机视觉
单目测距(yolo目标检测+标定+测距代码)上
单目测距(yolo目标检测+标定+测距代码)
59Echarts - 饼图(Nested Pies)
59Echarts - 饼图(Nested Pies)
150 0
|
机器学习/深度学习 计算机视觉 编解码
谷歌提出新型卷积网络EfficientNet:推理速度提升5.1倍,参数减少88%(附论文&代码)
谷歌提出了一种新型CNN网络EfficientNet,该网络具备极高的参数效率和速度。
2461 0
|
开发工具 git Python
Python 的软件开发实践:如何使用 Git 在团队中协同开发 Python 项目?
Python 的软件开发实践:如何使用 Git 在团队中协同开发 Python 项目?
457 1

热门文章

最新文章