学习Docker Consul工具一篇就够了!!!

一、Consul 理论知识

1.1、Consul 简介

Consul 是一个支持多数据中心分布式高可用的 服务发现 和 配置共享 的服务软件,由 HashiCorp 公司用 Go 语言开发,基于 Mozilla Public License 2.0 的协议进行开源。
主要特性:

  • Consul 支持健康检查,并允许 HTTP 、GRPC 和 DNS 协议调用 API 存储键值对。
  • 一致性协议采用 Raft 算法,用来保证服务的高可用。 使用 GOSSIP 协议管理成员和广播消息, 并且支持 ACL 访问控制。
    在这里插入图片描述

consul的实例叫agent,agent有两种运行模式:server和client 。
官方建议每个Consul Cluster数据中心至少有3个或以上的运行在Server Mode的Agent,Client节点不限。

1.2、Consul 使用场合

  • Docker 容器的注册与配置共享
  • Coreos 实例的注册与配置共享
  • SaaS 应用的配置共享、服务发现和健康检查。
  • vitess 集群
  • 与 confd 服务集成,动态生成 nginx 和 haproxy 配置文件

1.3、Consul 优势

  • 使用 Raft 算法来保证一致性,比复杂的 Paxos 算法更直接。相比较而言,zookeeper 采用的是 Paxos,而 etcd
    使用的则是 Raft。
  • 支持 多数据中心,内外网的服务采用不同的端口进行监听。
    多数据中心集群可以避免单数据中心的单点故障,而其部署则需要考虑网络延迟,分片等情况等. zookeeper 和 etcd
    均不提供多数据中心功能的支持。
  • 支持 健康检查。 etcd 不提供此功能。
  • 支持 HTTP、DNS 和 GPRS 协议接口。 zookeeper 的集成较为复杂,etcd 只支持 http 协议。
  • 官方提供 WEB管理界面,etcd 无此功能。

1.4、consul 端口

端口 说明
TCP/8300 8300
TCP/UDP/8301 8301端口用于单个数据中心所有节点之间的互相通信,即对LAN池信息的同步。它使得整个数据中心能够自动发现服务器地址,分布式检测节点故障,事件广播(如领导选举时间)。
TCP/UDP/8302 8302端口用于单个或多个数据中心之间的服务器节点的信息同步,即对WAN池信息的同步。它针对互联网的高延迟进行了优化,能够实现跨数据中心请求。
8500 8500端口基于HTTP协议,用于API接口或web UI访问
8600 8600端口作为DNS服务器,它使得我们可以通过节点名查询节点信息

二:基于Docker的Consul服务搭建

2.1、环境准备

在这里插入图片描述

主机 主机IP 安装工具
consul服务器 192.168.158.10 Docker、Consul、Consul-template模板、nginx代理服务
容器服务器 192.168.158.20 Docker、registrator、nginx容器

2.2、部署Consul服务

//先创建一个目录 
mkdir /root/consul
cd /root/consul
[root@server1 consul]# ls
consul-template_0.19.3_linux_amd64.zip
consul_0.9.2_linux_amd64.zip  nginx-1.12.2.tar.gz
unzip consul_0.9.2_linux_amd64.zip

//使 consul 命令可以在任何目录下识别 
mv consul /usr/bin

[root@server1 consul]# consul agent \
-server \
-bootstrap \
-ui \
-data-dir=/var/lib/consul-data \
-bind=192.168.158.10 \
-client=0.0.0.0 \
-node=consul-server01 &> /var/log/consul.log &
[1] 19458

[root@server1 consul]# netstat -natp | grep 8500
tcp6       0      0 :::8500                 :::*                    LISTEN      19458/consul  
#consul服务已经启动   
#查看群集信息
[root@server1 consul]# consul members
Node             Address              Status  Type    Build  Protocol  DC
consul-server01  192.168.158.10:8301  alive   server  0.9.2  2         dc1
[root@server1 consul]# consul info | grep leader
	leader = true
	leader_addr = 192.168.158.10:8300

2.3:通过 httpd api 可以获取集群信息:

[root@localhost consul]# curl 127.0.0.1:8500/v1/status/peers       ##查看群集server成员
[root@localhost consul]# curl 127.0.0.1:8500/v1/status/leaders     ##群集中 Raf leader
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/services   ##注册的所有服务
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/nodes      ##群集节点详细信息
[root
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值