consul简介:

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

consul的实例叫agent
agent有两种运行模式:server和client
每个数据中心至少要有一个server,一般推荐3-5个server(避免单点故障)
client模式agent是一个轻量级进程,执行健康检查,转发查询请求到server。
服务service是注册到consul的外部应用,比如spring web server

consul架构:

1. 在docker上安装consul(默认安装最新版本)

  1. docker pull consul

2. 启动第一个consul服务:consul1

  1. docker run --name consul1 -d -p : -p : -p : -p : -p : consul:1.2. agent -server -bootstrap-expect -ui -bind=0.0.0.0 -client=0.0.0.0

8500 http 端口,用于 http 接口和 web ui
8300 server rpc 端口,同一数据中心 consul server 之间通过该端口通信
8301 serf lan 端口,同一数据中心 consul client 通过该端口通信
8302 serf wan 端口,不同数据中心 consul server 通过该端口通信
8600 dns 端口,用于服务发现
-bbostrap-expect 2: 集群至少两台服务器,才能选举集群leader
-ui:运行 web 控制台
-bind: 监听网口,0.0.0.0 表示所有网口,如果不指定默认未127.0.0.1,则无法和容器通信
-client : 限制某些网口可以访问

3. 获取 consul server1 的 ip 地址

  1. docker inspect --format '{{ .NetworkSettings.IPAddress }}' consul1

输出是:172.17.0.2

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

  1. docker run --name consul3 -d -p : consul agent -server -ui -bind=0.0.0.0 -client=0.0.0.0 -join 172.17.0.2

5. 启动第三个consul服务:consul3,并加入consul1

  1. docker run --name consul3 -d -p : consul agent -server -ui -bind=0.0.0.0 -client=0.0.0.0 -join 172.17.0.2

6. 目前我启动了5个consul服务,然后stop掉了两个,详情如下图所示:

7. 宿主机浏览器访问:http://localhost:8500 或者 http://localhost:8501 或者 http://localhost:8502

(由于我一开始启动了5个consul服务,然后stop掉了两个,所以我的控制台如下所示)

8. 任意stop掉其中一个consul,只要剩余consul数目大于等于两个,宿主机就能正常访问对应的链接;

9. 创建test.json文件,以脚本形式注册服务到consul:

test.json文件内容如下:

  1. {
  2. "ID": "test-service1",
  3. "Name": "test-service1",
  4. "Tags": [
  5. "test",
  6. "v1"
  7. ],
  8. "Address": "127.0.0.1",
  9. "Port": ,
  10. "Meta": {
  11. "X-TAG": "testtag"
  12. },
  13. "EnableTagOverride": false,
  14. "Check": {
  15. "DeregisterCriticalServiceAfter": "90m",
  16. "HTTP": "http://zhihu.com",
  17. "Interval": "10s"
  18. }
  19. }

通过 http 接口注册服务(端口可以是8500. 8501, 8502等能够正常访问consul的就行):

  1. curl -X PUT --data @test.json http://localhost:8500/v1/agent/service/register

控制台如下所示:

10. 宿主机浏览器访问以下链接可以看到所有通过健康检查的可用test-server1服务列表

(任意正常启动consul的端口皆可):

  1. http://localhost:8501/v1/health/service/test-server1?passing

输出json格式的内容,如下所示:

其它应用程序可以通过这种方式轮询获取服务列表,这就是微服务能够动态知道其依赖微服务可用列表的原理。

11. 解绑定:

  1. curl -i -X PUT http://127.0.0.1:8501/v1/agent/service/deregister/test-server1

12. 集群方式需要至少启动两个consul server,本机调试web应用时,为了方便可以用 -dev 参数方式仅启动一个consul server

  1. docker run --name consul0 -d -p : -p : -p : -p : -p : consul:1.2. agent -dev -bind=0.0.0.0 -client=0.0.0.0

docker上搭建consul集群全流程的更多相关文章

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

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

  2. Docker 容器部署 Consul 集群

    Docker 容器部署 Consul 集群 一.docker安装与启动1.1安装docker[root@localhost /]# yum -y install docker-io 1.2更改配置文件 ...

  3. Linux下搭建tomcat集群全记录

    (转) Linux下搭建tomcat集群全记录 2011-10-12 10:23 6133人阅读 评论(1) 收藏 举报 tomcatlinuxapacheinterceptorsession集群 1 ...

  4. nginx的简单使用和使用nginx在windows上搭建tomcat集群

    nginx是一款轻量级的web服务器,常用的作用为服务器/反向代理服务器以及电子邮件(IMAP/POP3)代理服务器 1.为什么我们要使用Nginx? 反向代理: 反向代理(Reverse Proxy ...

  5. 在windows上搭建redis集群

    一 所需软件 Redis.Ruby语言运行环境.Redis的Ruby驱动redis-xxxx.gem.创建Redis集群的工具redis-trib.rb 二 安装配置redis redis下载地址   ...

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

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

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

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

  8. Docker实战之Consul集群

    前言 最近参加了几场 Java 面试,发现大多数的微服务实践还是 Eureka 偏多,鉴于笔者的单位选型 Consul,这里对 Consul 做简单总结. 该篇是 Docker 实战系列的第三篇.传送 ...

  9. 搭建 consul 集群

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

随机推荐

  1. js格式化数字

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. 查看selinux与关闭方法

    查看当前用户selinux 状态 [root@o- ~]# getenforce Disabled [root@o- ~]# setenforce usage: setenforce [ Enforc ...

  3. Python编程--类的分析

    一.类的概念 python是面向对象的编程语言,详细来说,我们把一类相同的事物叫做类,其中用相同的属性(其实就是变量描述),里面封装了相同的方法,比如:汽车是一个类,它包括价格.品牌等属性.那么我们如 ...

  4. os、os.path模块(文件/目录方法)

    1.模块的概念:模块是一个包含所有定义的变量.函数的文件,模块可以被其余模块调用. 2.利用OS模块实现对系统文件的. os模块中常见的方法: gercwd()     返回当前工作目录 chdir( ...

  5. 什么是Maven项目

    1.通俗理解Maven:https://blog.csdn.net/shuzhe66/article/details/45009175 个人总结: Maven项目会有pom文件! 当前的项目需要依赖其 ...

  6. How Region Split works in Hbase

    A region is decided to be split when store file size goes above hbase.hregion.max.filesize or accord ...

  7. spring(二、bean生命周期、用到的设计模式、常用注解)

    spring(二.bean生命周期.用到的设计模式.常用注解) Spring作为当前Java最流行.最强大的轻量级框架,受到了程序员的热烈欢迎.准确的了解Spring Bean的生命周期是非常必要的. ...

  8. CORS(跨域资源共享)的防御机制

    一.为什么会出现CORS: 浏览器的同源策略给WEB开发人员带来了巨大的痛苦,信息的交互共享本来就是网络的意义.所以妥协之后出现了CORS. 二.技术原理: 1.简单跨域: (1)方法要求:只能是GE ...

  9. 磁盘操作系统 cmd命令

    DOS CMD :磁盘操作系统 不区分大小写 **cd \ 根目录 cls 清空屏幕 dir 显示目录 d: 进入D盘 cd 进入目录命令 dir 查看当前目录的文件与目录 del 删除文件 del ...

  10. PTA——蠕虫爬井

    PTA 7-46 爬动的蠕虫 #include<stdio.h> int main() { ; scanf("%d%d%d",&N,&U,&D) ...