Hyperf微服务——二、Consul的安装与使用

由于本人的开发环境为mac,所以一下安装流程是基于mac环境的docker安装。

一、Docker拉取镜像

1.进入终端,执行命令拉取consul镜像到本地

`docker pull consul`
出现下面图片内容表示镜像拉取成功
![在这里插入图片描述](https://img-blog.csdnimg.cn/53cf1503d1484e1ab694ea66baf4d695.png#pic_center)

2.执行命令查看本地镜像,发现consul镜像。

docker images

在这里插入图片描述

二、运行单节点consul

1.基于consul镜像生成consul容器

docker run --name consul -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

2.查看consul容器

docker ps

在这里插入图片描述

3.打开地址如下:http://127.0.0.1:8500/ ,界面展示如下图则表示成功

在这里插入图片描述

三、运行集群Consul

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

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

备注:第一个节点容器创建并运行后,会报错,因为命令中参数-bootstrap-expect 为2 ,代表集群数量为2 如果为1 则为单机部署,集群部署的情况下,现在回报错提示找不到leader,再创建其他节点容器后解决该报错。
请添加图片描述

2.查看容器ip地址

查看consul1的ip地址
docker inspect --format=‘{{.NetworkSettings.IPAddress}}’ consul1
假如 输出172.17.0.3 下一步将用到

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

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

4.启动第三个consul服务(端口8502):consul3, 并加入consul1(使用join命令)

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

5.查看consul集群信息

docker exec -it consul1 consul members
请添加图片描述

6.查看所有容器信息

请添加图片描述

7.通过访问8500/8501/8502端口查看web界面

http://localhost:8500
请添加图片描述
至此,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, 加入到已有的集群中

五、端口说明

  • 8500 : http 端口,用于 http 接口和 web ui访问;
  • 8300 : server rpc 端口,同一数据中心 consul server 之间通过该端口通信;
  • 8301 : serf lan 端口,同一数据中心 consul client 通过该端口通信; 用于处理当前datacenter中LAN的gossip通信;
  • 8302 : serf wan 端口,不同数据中心 consul server 通过该端口通信; agent Server使用,处理与其他datacenter的gossip通信;
  • 8600 : dns 端口,用于已注册的服务发现;
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
安装使用Consul,您可以按照以下步骤进行操作: 1. 首先,您可以访问Consul的官方网站https://www.consul.io/,根据您的操作系统选择最新的Consul版本。例如,如果您使用的是Windows 64位操作系统,可以下载并安装最新的Consul版本(目前是1.13.1)。 2. 安装完成后,您可以在系统中找到Consul的可执行文件。在Windows系统中,通常是一个名为"consul.exe"的文件。 3. 打开命令提示符(CMD)或终端,并导航到Consul可执行文件所在的目录。 4. 启动Consul代理以管理服务。在命令行中输入以下命令并执行:consul agent -dev 。这将启动一个本地开发模式的Consul代理,该代理将在本地计算机上运行,并模拟一个Consul集群。 5. 一旦Consul代理启动成功,您可以通过访问http://localhost:8500/来访问Consul的服务管理界面。这是Consul的默认页面,用于显示已注册到Consul的服务。您将看到一个名为"consul"的服务,这是Consul代理本身。 现在,您已经成功安装和启动了Consul,并可以使用其服务管理界面来管理和监控您的服务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【超详细】Consul安装使用附多环境配置(傻瓜式教程)](https://blog.csdn.net/weixin_46099455/article/details/126351145)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Justin-D

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值