搭建consul 集群
1. 准备工作
a) 启动三台虚拟机
s1:10.1.7.141
s2:10.1.7.139
s3:10.1.7.138
b) 每台机器上在 /home新建文件夹
mkdir /home/consul mkdir /home/consul/data
c) 下载consul,并将其考入到/home/consul中
下载地址:https://www.consul.io/downloads.html
2. 启动server agent
a) 进入consul目录中
cd /home/consul
b) 执行:
./consul agent -server -bootstrap-expect 2 -data-dir=data -node=n1 -bind=10.1.7.141 &
注:
i. server: 以server身份启动。
ii. bootstrap-expect:集群要求的最少server数量,当低于这个数量,集群即失效。
iii. data-dir:data存放的目录,更多信息请参阅consul数据同步机制
iv. node:节点id,在同一集群不能重复。
v. bind:监听的ip地址。
vi. &:在后台运行,此为linux脚本语法
vii. 更多参数及配置说明见consul官方说明文档。
c) 修改node和bind信息,分别在另外两台机器中执行。
d) 在s2、s3中分别执行:
./consul join 10.1.7.141
e) 到这里整个consul server 集群就算完成了,可以利用consul members查看集群中包含的node信息。
f) 使用consul info命令可以查看当前节点状态,包括是否在集群中,是否为leader(主)。
3. 注册服务
已redis为例
a) 启动新的虚拟机
s4:10.1.7.142
b) 启动redis服务(这里不在赘述)
c) 新建文件夹/home/consul/config,在这个文件中放置consul的配置信息。
mkdir /home/consul/config
d) 编写redis注册及健康检查方法,每一个服务都写成一个文件,文件格式为:.json
vi /home/consul/config/redis.json
e) Redis的注册与检查脚本:
{
"services": [ #服务数组,这里只写一个redis服务,建议一个服务写一个文件
{
"id": "redis/node1", #服务ID
"name": "redis ", #服务名称,在发现服务时可以用该名称找到所有服务提供者
"tags": [],
"address": "10.17. 142", #服务的IP,这里配置的是本机的内网地址
"port": 6379, #服务端口,redis配置的端口为6379
"checks": [
{
#检测redis存活的脚本,consul也提供http命令来检测服务的健康状态
"script": "redis-cli -h 127.0.0.1 -p 6379 info | grep role:master || exit 2",
#检测频率,这里定义的是5秒
"interval": "5s"
}
]
}
]
}
f) 启动consul 代理
./consul agent -data-dir data -node=n4 -bind=10.1.7.142 -config-file=/home/consul/config
g) 加入到集群中
./consul join 10.1.7.142
4. 搭建管理工具
a) 下载consul web ui,和本机中的consul放到同级目录。
b) 在本机启动consul
consul agent -node=local1abc -bind=10.1.7.167 -ui-dir=web_ui
c) 加入到集群中
consul join 10.1.7.142
d) 打开浏览器,数据地址http://127.0.0.1:8500。即可看到consul的配置信息和已注册的服务信息。
搭建consul 集群的更多相关文章
- 庐山真面目之十二微服务架构基于Docker搭建Consul集群、Ocelot网关集群和IdentityServer版本实现
庐山真面目之十二微服务架构基于Docker搭建Consul集群.Ocelot网关集群和IdentityServer版本实现 一.简介 在第七篇文章<庐山真面目之七微服务架构Consul ...
- vagrant+docker搭建consul集群开发环境
HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...
- 搭建 consul 集群
=============================consul 命令行工具=============================consul 支持 Windows/Linux 等多种平台, ...
- Docker学习-Docker搭建Consul集群
1.环境准备 Linux机器三台 网络互通配置可以参考 https://www.cnblogs.com/woxpp/p/11858257.html 192.168.50.21 192.168.50.2 ...
- CentOS7 搭建 Consul 集群
环境准备: ssh shell工具: 远程连接 三个CentOS示例: 部署集群 配置好各个实例之间的网络访问,以及ssh免密登录. 下载&上传: 1.下载 Consul: Download ...
- docker上搭建consul集群全流程
consul简介: consul是提供服务发现.简单配置管理.分区部署的服务注册发现解决方案.主要特性:服务发现\健康检查\基于Key-Value的配置\支持TLS安全通讯\支持多数据中心部署 con ...
- 使用Docker搭建consul集群+registrator实现服务自动注册。
准备工作:10.173.16.83 master10.172.178.76 node110.171.19.139 node210.162.204.252 node3 一.安装consul-cluste ...
- 微服务之:从零搭建ocelot网关和consul集群
介绍 微服务中有关键的几项技术,其中网关和服务服务发现,服务注册相辅相成. 首先解释几个本次教程中需要的术语 网关 Gateway(API GW / API 网关),顾名思义,是企业 IT 在系统边界 ...
- Linux中Consul集群部署
分配三台虚拟机: 192.168.5.125 192.168.5.128 192.168.5.129 在每台虚拟机上创建 /usr/consul 文件件 命令: mkdir /usr/consul ...
随机推荐
- [No000099]软件版本命名规范
软件版本阶段说明 Base: 此版本表示该软件仅仅是一个假页面链接,通常包括所有的功能和页面布局,但是页面中的功能都没有做完整的实现,只是做为整体网站的一个基础架构. Alpha: 此版本表示该软件在 ...
- java 静态内部类小总结
内部类是指在一个外部类的内部再定义一个类.内部类作为外部类的一个成员,并且依附于外部类而存在的.内部类可为静态,可用protected和private修饰(而外部类只能使用public和缺省的包访问权 ...
- [LeetCode] Longest Substring Without Repeating Characters 最长无重复子串
Given a string, find the length of the longest substring without repeating characters. For example, ...
- ConcurrentHashMap内存泄漏问题
问题背景 上周,同事写了一段ConcurrentHashMap的测试代码,说往map里放了32个元素就内存溢出了,我大致看了一下他的代码及运行的jvm参数,觉得很奇怪,于是就自己捣鼓了一下.首先上一段 ...
- [开源].NET高性能框架Chloe.ORM-完美支持SQLite
扯淡 这是一款轻量.高效的.NET C#数据库访问框架(ORM).查询接口借鉴 Linq(但不支持 Linq).借助 lambda 表达式,可以完全用面向对象的方式就能轻松执行多表连接查询.分组查询. ...
- Less的使用
Less为css预处理器 首先先去下载一个koala编译器软件,然后运行打开 新建一个项目目录,在css文件夹中新建一个后缀为less的文件,然后拉入koala软件中,然后运行 ,你的css文件夹中就 ...
- AngularJs的$http发送POST请求,php无法接收Post的数据解决方案
最近在使用AngularJs+Php开发中遇到php后台无法接收到来自AngularJs的数据,在网上也有许多解决方法,却都点到即止.多番摸索后记录下解决方法:tips:当前使用的AngularJ ...
- ajax实现局部刷新
<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...
- JS for循环
正常的for循环代码: var arr = ['Apple', 'Google', 'Microsoft']; var i, x; for (i=0; i<arr.length; i++) { ...
- MYSQL远程登录权限设置 ,可以让Navicat远程连接服务器的数据库
Mysql默认关闭远程登录权限,如下操作允许用户在任意地点登录: 1. 进入mysql,GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY ...