比如:docker实例的注册与配置共享、coreos实例的注册与配置共享、vitess集群、SaaS应用的配置共享、Consul与confd服务集成,动态生成nginx和haproxy配置文件或者Consul结合nginx构建高可用可扩展的Web服务。
三、安装
我这里直接安装Consul 最新版本 1.7.2 官网地址:https://www.consul.io/
1. 下载
我这里进入我的用户目录 /home下面进行下载consul安装压缩包,命令如下:
wget https://releases.hashicorp.com/consul/1.7.2/consul_1.7.2_linux_amd64.zip
下载如下图:
下载完我们通过 ls -a 查看下目录,如下图:
2. 解压
unzip consul_1.7.2_linux_amd64.zip
3. 拷贝到usr目录下
我这里事先在usr目录中单独创建了service 文件,可以通过mkdir 命令来完成,不过不一定要安装在这个目录下面,我这里就选择安装在usr目录里
mv consul /usr/service
4. 查看 安装是否成功
./consul
查看如下图:
已经安装完成了,
现在我们开始启动
5. 启动
这是最关键的时候,安装就是为了启动
这里我整理了下启动的相关参数如下:
参数参考 可以访问 https://www.cnblogs.com/sunsky303/p/9209024.html 地址,我这里就简单的通过使用到的参数进行启动
-server 表示是server模式
-bootstrap-expect=3 表示是集群中有3台服务器 bootstrap该模式node可以指定自己作为leader ,如果是非leader可不加该参数
-data-dir=/tmp/consul 目录
-node=n2 该服务器节点名
-bind=127.0.0.1 节点绑定的ip
-ui 非必须 webui的路径 用web来管理consul
启动命令如下(默认是8500端口):
./consul agent -server -bootstrap-expect 1 -data-dir=/tmp/consul -node=n1 -bind=127.0.0.1 -client=0.0.0.0 -ui
启动后结果如下:
现在我再来访问Consul UI管理界面,如下图:
现在Consul 已经完整的启动成功了,启动成功是不是想要来试一试,我这里直接使用我之前写的一篇【.net core】电商平台升级之微服务架构应用实战(core-grpc) 文章中写的Demo 注册到Consul 中来,看看是否正常注册,如下图:
好了,正常的注册进来了,完美,现在已经搭建完成了
Consul 开机自启动
1. 路径/usr/lib/systemd/system/,新建一个service命名为,consul.service
[Unit]
Description=consul-service
After=network.target
[Service]
Type=forking
PIDFile=/run/consul-service.pid
ExecStart=/usr/service/consul.start.sh
ExecReload=/bin/kill -SIGHUP $MAINPID
ExecStop=/bin/kill -SIGINT $MAINPID
[Install]
WantedBy=multi-user.target graphical.target
上面的ExecStart 是启动的脚本,我之前把consul 是安装在/user/service 下面,
2. 创建启动脚本
我们再service 目录中创建Consul开机自启动的脚本文件consul.start.sh
#!/bin/bash
/usr/service/consul agent -server -bootstrap-expect 1 -node=127.0.0.1 -data-dir=/usr/service/data/ -log-file=/usr/service/log/consul_log-$(date +%Y-%m-%d--%H-%M) -bind=127.0.0.1
3. 重新加载配置
systemctl daemon-reload
4. 设置开机自启动
systemctl enable consul.service
Consul 启动
systemctl start consul
Consul 停止
systemctl stop consul
上面创建开机自启动脚本实践的时候大家可能会发现 通过systemctl start consul 无法启动问题,这时候可以通过status 来查询状态,命令如下
systemctl status consul
查询创建的自启动脚本执行过程中出现code=exited, status=203/EXEC
异常错误信息,这个信息一般有如下几个原因造成:
- 错误的脚本路径
- 脚本的权限无效
- 服务用户没有读取脚本的权限
- 脚本未标记为可执行
根据上面三种情况去排查解决,基本上就可以完美解决自启动脚本无法启动问题
结束语:这里Consul 介绍及安装搭建已经完成,Consul也可以搭建集群,大家可以去尝试自己搭建,比较简单,后续我会陆续把使用到的各种工具服务搭建起来,以方便后续的文章实战分享和学习,不过大佬就可以直接跳过…