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 集群的更多相关文章

  1. 庐山真面目之十二微服务架构基于Docker搭建Consul集群、Ocelot网关集群和IdentityServer版本实现

    庐山真面目之十二微服务架构基于Docker搭建Consul集群.Ocelot网关集群和IdentityServer版本实现 一.简介      在第七篇文章<庐山真面目之七微服务架构Consul ...

  2. vagrant+docker搭建consul集群开发环境

    HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...

  3. 搭建 consul 集群

    =============================consul 命令行工具=============================consul 支持 Windows/Linux 等多种平台, ...

  4. Docker学习-Docker搭建Consul集群

    1.环境准备 Linux机器三台 网络互通配置可以参考 https://www.cnblogs.com/woxpp/p/11858257.html 192.168.50.21 192.168.50.2 ...

  5. CentOS7 搭建 Consul 集群

    环境准备: ssh shell工具: 远程连接 三个CentOS示例: 部署集群 配置好各个实例之间的网络访问,以及ssh免密登录. 下载&上传: 1.下载 Consul: Download ...

  6. docker上搭建consul集群全流程

    consul简介: consul是提供服务发现.简单配置管理.分区部署的服务注册发现解决方案.主要特性:服务发现\健康检查\基于Key-Value的配置\支持TLS安全通讯\支持多数据中心部署 con ...

  7. 使用Docker搭建consul集群+registrator实现服务自动注册。

    准备工作:10.173.16.83 master10.172.178.76 node110.171.19.139 node210.162.204.252 node3 一.安装consul-cluste ...

  8. 微服务之:从零搭建ocelot网关和consul集群

    介绍 微服务中有关键的几项技术,其中网关和服务服务发现,服务注册相辅相成. 首先解释几个本次教程中需要的术语 网关 Gateway(API GW / API 网关),顾名思义,是企业 IT 在系统边界 ...

  9. Linux中Consul集群部署

    分配三台虚拟机: 192.168.5.125 192.168.5.128 192.168.5.129 在每台虚拟机上创建  /usr/consul 文件件  命令: mkdir /usr/consul ...

随机推荐

  1. [LeetCode] Path Sum II 二叉树路径之和之二

    Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given su ...

  2. 开发 ASP.NET vNext 初步总结(使用Visual Studio 14 CTP1)

    新特性: vNext又称MVC 6.0,不再需要依赖System.Web,占用的内存大大减少(从前无论是多么简单的一个请求,System.Web本身就要占用31KB内存). 可以self-host模式 ...

  3. 佛祖保佑 永无bug

    /* _ooOoo_ o8888888o 88" . "88 (| -_- |) O\ = /O ____/`---'\____ .' \\| |// `. / \\||| : | ...

  4. HYSBZ 2038 莫队算法

    小Z的袜子(hose) Time Limit:20000MS     Memory Limit:265216KB     64bit IO Format:%lld & %llu Submit  ...

  5. Markdown

    1. 斜体和粗体 代码: *斜体*或_斜体_ **粗体** ***加粗斜体*** ~~删除线~~ 显示效果: 这是一段斜体 这是一段粗体 这是一段加粗斜体 这是一段删除线 2. 分级标题 第一种写法: ...

  6. Javascript判断object还是list/array的类型(包含javascript的数据类型研究)

    前提:先研究javascript中的变量有几种,参考: http://www.w3school.com.cn/js/js_datatypes.asp http://glzaction.iteye.co ...

  7. phpunit 测试框架安装

    PHPUnit是一个轻量级的PHP测试框架.它是在PHP5下面对JUnit3系列版本的完整移植,是xUnit测试框架家族的一员(它们都基于模式先锋Kent Beck的设计).来自百度百科 一.下载wg ...

  8. FlowLayoutPanel

    动态生成控件  按顺序规律排列时 用panel的话 要指定特定的位置 .麻烦. 可以通过用flowLayoutPanel来解决. FlowLayoutPanel:表格布局面板,适合以表格形式规则的动态 ...

  9. ReactNative 根据scrollView/listview滑动距离动态修改NavBar颜色

    我们常见某些APP上滑的时候,NavBar颜色会从透明渐变为某种颜色 原理非常简单,根据scrollView的回调动态修改NavBar的透明度即可. 在RN中,尤其是ListView中这个回调不是很好 ...

  10. PHP 进程间通信——消息队列(msg_queue)

    PHP 进程间通信--消息队列 本文不涉及PHP基础库安装.详细安装说明,请参考官网,或期待后续博客分享. 1.消息队列函数准备 <?php//生成一个消息队列的key$msg_key = ft ...