docker consul集群

网友投稿 344 2022-09-13

docker consul集群

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

8500 端口,用于 接口和 web ui 8300 server rpc 端口,同一数据中心 consul server 之间通过该端口通信 8301 serf lan 端口,同一数据中心 consul client 通过该端口通信 8302 serf wan 端口,不同数据中心 consul server 通过该端口通信 8600 dns 端口,用于服务发现 -bbostrap-expect 2: 集群至少两台服务器,才能选举集群leader -ui:运行 web 控制台 -bind: 监听网口,0.0.0.0 表示所有网口,如果不指定默认未127.0.0.1,则无法和容器通信 -client : 限制某些网口可以访问

3. 获取 consul server1 的 ip 地址

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

输出是:172.17.0.2

4. 启动第二个consul服务:consul2, 并加入consul1(使用join命令)

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

5. 启动第三个consul服务:consul3,并加入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

6. 目前我启动了5个consul服务,然后stop掉了两个,详情如下图所示:

7. 宿主机浏览器访问:或者 或者 任意stop掉其中一个consul,只要剩余consul数目大于等于两个,宿主机就能正常访问对应的链接;

9. 创建test.json文件,以脚本形式注册服务到consul:

test.json文件内容如下:

{ "ID": "test-service1", "Name": "test-service1", "Tags": [ "test", "v1" ], "Address": "127.0.0.1", "Port": 8000, "Meta": { "X-TAG": "testtag" }, "EnableTagOverride": false, "Check": { "DeregisterCriticalServiceAfter": "90m", "HTTP": " "Interval": "10s" }}

通过 接口注册服务(端口可以是8500. 8501, 8502等能够正常访问consul的就行):

curl -X PUT --data @test.json 宿主机浏览器访问以下链接可以看到所有通过健康检查的可用test-server1服务列表

(任意正常启动consul的端口皆可):

解绑定:

curl -i -X PUT 集群方式需要至少启动两个consul server,本机调试web应用时,为了方便可以用 -dev 参数方式仅启动一个consul server

docker run --name consul0 -d -p 8500:8500 -p 8300:8300 -p 8301:8301 -p 8302:8302 -p 8600:8600 consul:1.2.2 agent -dev -bind=0.0.0.0 -client=0.0.0.0

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:php接入was s3相关问题记录
下一篇:SkyWalking 针对 gRPC 的负载均衡和自动扩容实践
相关文章

 发表评论

暂时没有评论,来抢沙发吧~