今天也来点Docker,Consul服务(自动发现的Docker架构)

2023-05-16

文章目录

  • 一、Consul 理论概述
    • 1.1 简介
    • 1.2 使用场景
    • 1.3 优势
    • 1.4 consul 端口
  • 二、基于Docker的Consul服务搭建
    • 2.1 部署环境
    • 2.2 部署Consul服务
    • 2.3 容器服务自动加入nginx集群
    • 2.4 验证consul 的服务发现功能

一、Consul 理论概述

1.1 简介

Consul 是一个支持多数据中心分布式高可用的 服务发现 和 配置共享 的服务软件,由 HashiCorp 公司用 Go 语言开发,基于 Mozilla Public License 2.0 的协议进行开源。
主要特性:

  • Consul 支持健康检查,并允许 HTTP 、GRPC 和 DNS 协议调用 API 存储键值对。
  • 一致性协议采用 Raft 算法,用来保证服务的高可用。
  • 使用 GOSSIP 协议管理成员和广播消息, 并且支持 ACL 访问控制。
  • consul的实例叫agent,agent有两种运行模式:server和client 。
  • 官方建议每个Consul Cluster数据中心至少有3个或以上的运行在Server Mode的Agent,Client节点不限。

1.2 使用场景

  • Docker 容器的注册与配置共享
  • Coreos 实例的注册与配置共享
  • SaaS 应用的配置共享、服务发现和健康检查。
  • vitess 集群
  • 与 confd 服务集成,动态生成 nginx 和 haproxy 配置文件

1.3 优势

市面现在有很多类似的软件比如:zookeeper 、Etcd、doozerd、eureka,Consul 相比这些软件的优势:

  • 使用 Raft 算法来保证一致性,比复杂的 Paxos 算法更直接。相比较而言,zookeeper 采用的是 Paxos,而 etcd 使用的则是 Raft。
  • 支持 多数据中心,内外网的服务采用不同的端口进行监听。 多数据中心集群可以避免单数据中心的单点故障,而其部署则需要考虑网络延迟,分片等情况等. zookeeper 和 etcd 均不提供多数据中心功能的支持。
  • 支持 健康检查。 etcd 不提供此功能。
  • 支持 HTTP、DNS 和 GPRS 协议接口。 zookeeper 的集成较为复杂,etcd 只支持 http 协议。
  • 官方提供 WEB管理界面,etcd 无此功能。

1.4 consul 端口

端口说明
TCP/83008300端口用于服务器节点,客户端通过该端口RPC协议调用服务端节点。
TCP/UDP/83018301端口用于单个数据中心所有节点之间的互相通信,即对LAN池信息的同步。它使得整个数据中心能够自动发现服务器地址,分布式检测节点故障,事件广播。
TCP/UDP/83028302端口用于单个或多个数据中心之间的服务器节点的信息同步,即对WAN池信息的同步。它针对互联网的高延迟进行了优化,能够实现跨数据中心请求。
85008500端口基于HTTP协议,用于API接口或WEB UI访问。
86008600端口作为DNS服务器,它使得我们可以通过节点名查询节点信息

二、基于Docker的Consul服务搭建

2.1 部署环境

服务器IP地址安装软件
Consul20.0.0.50Docker-ce、Consul、Consul-template模板、nginx服务
容器20.0.0.60Docker-ce

2.2 部署Consul服务

#关闭防火墙和核心保护
[root@consul ~]# systemctl stop firewalld
[root@consul ~]# setenforce 0

#创建consul目录,放入所需安装包
[root@consul ~]# mkdir /root/consul
[root@consul ~]# cd consul/
[root@consul consul]# ll
总用量 13588
-rw-r--r--. 1 root root 10233177 12月  1 13:49 consul_0.9.2_linux_amd64.zip
-rw-r--r--. 1 root root  2694811 12月  1 16:21 consul-template_0.19.3_linux_amd64.zip
-rw-r--r--. 1 root root   980831 12月  1 16:25 nginx-1.12.0.tar.gz

#解压consul并移动到bin,使consul 命令可以在任何目录下识别
[root@consul consul]# unzip consul_0.9.2_linux_amd64.zip
[root@consul consul]# mv consul /usr/bin

#创建consul代理agent
[root@consul consul]# consul agent \
-server \
-bootstrap \
-ui \
-data-dir=/var/lib/consul-data \
-bind=20.0.0.50 \
-client=0.0.0.0 \
-node=consul-server01 &> /var/log/consul.log &

#看到consul的8500端口服务已经启动
[root@consul consul]# netstat -natp | grep 8500
tcp6       0      0 :::8500                 :::*                    LISTEN      48140/consul

#查看集群信息
[root@consul consul]# consul members
Node             Address         Status  Type    Build  Protocol  DC
consul-server01  20.0.0.50:8301  alive   server  0.9.2  2         dc1
[root@consul consul]# consul info | grep leader
	leader = true
	leader_addr = 20.0.0.50:8300
  • 使用浏览器访问
    在这里插入图片描述

2.3 容器服务自动加入nginx集群

[root@node ~]#  docker run -d \
--name=registrator \
--net=host \
-v /var/run/docker.sock:/tmp/docker.sock \
--restart=always \
gliderlabs/registrator:latest \
-ip=20.0.0.60 \
consul://20.0.0.50:8500

[root@node ~]# docker ps -a
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS              PORTS               NAMES
287f08f49e16        gliderlabs/registrator:latest   "/bin/registrator -i…"   15 seconds ago      Up 14 seconds                           registrator

#创建两个容器,测试consul服务发现功能
[root@node ~]# docker run -itd -p:83:80 --name test-01 -h test01 nginx
[root@node ~]# docker run -itd -p:84:80 --name test-02 -h test02 nginx
[root@node ~]# docker ps -a
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS              PORTS                NAMES
03bca01167d4        nginx                           "/docker-entrypoint.…"   3 seconds ago       Up 2 seconds        0.0.0.0:84->80/tcp   test-02
ecaf03f3eca5        nginx                           "/docker-entrypoint.…"   45 seconds ago      Up 44 seconds       0.0.0.0:83->80/tcp   test-01
287f08f49e16        gliderlabs/registrator:latest   "/bin/registrator -i…"   6 minutes ago       Up 6 minutes                             registrator

2.4 验证consul 的服务发现功能

在这里插入图片描述

  • 或者通过命令查看consul服务器
    在这里插入图片描述
  • 删除一个nginx容器查看变化
[root@node ~]# docker stop 03bca01167d4
03bca01167d4
[root@node ~]# docker rm 03bca01167d4
03bca01167d4

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

今天也来点Docker,Consul服务(自动发现的Docker架构) 的相关文章

随机推荐

  • makefile教程

    Makefile是一种用于构建软件项目的自动化工具 xff0c 通过定义一系列规则和依赖关系 xff0c 可以自动化构建 编译 测试和安装软件项目 在本篇教程中 xff0c 我将介绍如何编写一个简单的Makefile xff0c 并解释Ma
  • 原来制作数据可视化大屏这么简单,这三步就能完成

    不知道大家在对数据进行可视化处理的时候 xff0c 有没有碰到过以上问题 xff1f 身为一位经常需要整理数据 可视化处理的数据人 xff0c 我真的心有体会 随着越来越多的头部企业启动数据大屏展示公司的年度 战绩 xff0c 以数据大屏为
  • VirtualBox主机ping不通虚拟机

    问题 xff1a 虚拟机可以ping通主机 xff0c 主机无法ping通虚拟机 1 检查虚拟机是否配置好NAT网络连接 xff0c 从而能够ping通外网 2 配置主机ping虚拟机 xff0c 创建桥接网卡 3 检查虚拟机是否出现新建桥
  • MATLAB“在当前文件夹或MATLAB路径中未找到文件“的小“坑”

    更新 xff1a 似乎找到了官方依据 另外 xff0c 这个问题在MATLAB2020中似乎已经得到了修复 MATLAB文件夹的相关问题 新手使用matlab会遇到文件夹的问题 xff1a 第一 xff0c 新建一个脚本 xff0c Ctr
  • Ubuntu18.04下PX4+gazebo+QGC实现无人机在仿真环境下的房屋巡视

    前言 xff1a 老师给我布置了在仿真环境下模拟带摄像头的无人机在仿真环境下的巡视任务 xff0c 在完成任务的过程中 xff0c 遇到了很多问题 xff0c 查阅了许多博主的资料 xff0c 有些关键环节只是被一带而过 xff0c 导致安
  • 双系统下ubuntu18.04装拓展显示屏血泪史

    1 背景 xff1a 买了块新显示器 xff0c 想在ubuntu18 04下使用 xff0c 得装驱动 xff0c 刚开始按网上的一个教程 xff0c 直接把内核装坏了 xff0c 后来重装过系统才最终完成拓展屏的功能实现 xff0c 特
  • ROS工作空间、功能包创建,编译相关的C++/python程序详解

    有关工作空间的结构 xff1a WorkSpace 自定义的工作空间 build xff1a 编译空间 xff0c 用于存放CMake和catkin的缓存信息 配置信息和其他中间文件 devel xff1a 开发空间 xff0c 用于存放编
  • VScode配置ROS环境下Debug调试

    参考 xff1a VScode debug ROS cpp程序设置 断点调试 ABC Orange的博客 CSDN博客 poll failed with error interrupted system call Get Started w
  • C++速成(封装、继承和多态)

    前前言 xff1a 如果有时间 xff0c 搜一个完整的教程看 xff0c 用到啥学啥 xff0c 这样可能可以省更多的时间 61 61 前言 xff1a C 43 43 的命名规范 C 43 43 命名规范 ajioy的博客 CSDN博客
  • 神经网络与深度学习课程总结二

    深度学习平台介绍 1 1PyTorch是一个Python的深度学习库 它最初由Facebook人工智能研 究小组开发 xff0c 而优步的Pyro软件则用于概率编程 1 1 1PyTorch基本使用 基本概念 张量 xff08 Tensor
  • 神经网络与深度学习课程总结三

    一 数据集与评价指标 算法评估 xff1a P R曲线 mAP计算 二 目标检测与YOLO 目标检测问题 xff1a 目标检测是在给定的图片中精确找到物体所在位置 并标注出物体的类别 物体的尺寸变化范围很大 摆放物体的角度 姿态不定 而且可
  • 神经网络与深度学习课程总结四

    一 数据处理基础 1 1特征编码 xff1a 第1列表示年龄 xff0c 是一个数值特征 第2列表示性别 xff0c 是一个只有一位 xff08 0 xff0c 1 xff09 的特征 0 gt Male 1 gt Female 第3列表示
  • 高大上的数据可视化图表,只需6步就能完成

    一份高质量的数据可视化图表 xff0c 能够让你清晰 全面地传达出数据信息 xff0c 成为你工作 学习 竞赛的助推器 xff01 因此 xff0c 一款功能强大的可视化软件显得尤为重要 xff01 最近博主在用的百度 Sugar BI x
  • 从零开始的MySQL学习,完全备份、增量备份和备份恢复

    文章目录 一 数据备份的重要性二 数据库备份的分类从物理与逻辑的角度从数据库的备份策略角度 三 完全备份完全备份的优点完全备份的缺点 四 mysqldump备份库备份单个库备份多个库备份所有库备份表 五 备份恢复source命令恢复mysq
  • 【错误归纳】rsync远程同步:报错password file must not be other-accessible

    实验场景 xff1a rsync远程同步 故障现象 xff1a 做rsync远程同步时 xff0c 当时在发起端输入了以下命令 调用了免密方式同步文件 rsync span class token operator span az span
  • Linux就该这么学,GlusterFS分布式原理和架构

    文章目录 一 GlusterFS概述GlusterFS的简介GlusterFS的特点GlusterFS的相关用语模块化堆栈式架构 二 GlusterFS工作原理GlusterFS工作流程弹性hash算法 三 GlusterFS的卷类型分布式
  • 【错误归纳】创建GlusterFS卷:报错Mount failed. Please check the log file for more details

    实验场景 xff1a 创建GlusterFS复制卷 故障现象 xff1a 创建GlusterFS复制卷 客户端挂载时出错 root 64 client mount glusterfs node1 rep vol hyc rep vol Mo
  • 【归纳总结】MySQL5.6与5.7区别

    文章目录 一 编译安装区别下载软件带boost的mysql源码安装不带boost的mysql源码安装 二 初识化时的区别三 功能和特性的区别 一 编译安装区别 Mysql5 7版本更新后有很多变化 xff0c 比如json等 xff0c 连
  • 今天也来点Docker,端口映射与容器互联

    文章目录 一 端口映射1 1 概述1 2 随机端口1 3 映射指定端口 二 容器互联 一 端口映射 1 1 概述 在启动容器的时候 xff0c 如果不指定对应的参数 xff0c 在容器外部是无法通过网络来访问容器内部的网络应用和服务的 当容
  • 今天也来点Docker,Consul服务(自动发现的Docker架构)

    文章目录 一 Consul 理论概述1 1 简介1 2 使用场景1 3 优势1 4 consul 端口 二 基于Docker的Consul服务搭建2 1 部署环境2 2 部署Consul服务2 3 容器服务自动加入nginx集群2 4 验证