Docker 单节点部署 Consul

news2025/1/11 23:01:30

Docker 单节点部署Consul

  • 1 Docker 拉取 Consul 镜像
  • 2 Docker 创建 Consul 容器
  • 3 启动 Consul 容器

CAP 原则是由计算机科学家 Eric Brewer 提出的,用于描述分布式系统中的一致性、可用性和分区容忍性之间的权衡关系,CAP 是三个概念的首字母缩写。

原则作用
一致性(Consistency)所有节点在同一时刻具有相同的数据视图。在一个具有多个节点的分布式系统中,当一个节点对数据进行了更新,所有其他节点在后续的访问中都能够看到这个更新。
可用性(Availability)每个非故障节点在有限时间内都能够返回有效的响应。即系统保证对每个请求都会收到一个非错误的响应,不保证是否包含最新的数据。
分区容忍性(Partition Tolerance)系统在网络分区的情况下仍然能够正常运行。分区容忍性是指在分布式系统中,即使由于网络故障导致节点之间无法通信,系统仍能够继续运行。

Consul 是一款由 HashiCorp 公司开发的开源工具,用于实现分布式系统的服务发现、健康检查、配置中心和分布式锁等功能。Consul 提供了一个简单而强大的界面,允许开发人员在分布式环境中轻松地注册和发现服务。

Consul 是一个分布式系统的服务发现和配置工具,它在设计上遵循了 CAP 原则,即一致性(Consistency)、可用性(Availability)、分区容忍性(Partition Tolerance)。以下是 Consul 在 CAP 方面的实现:

一致性(Consistency)

一致性协议: Consul 使用 Raft 协议作为一致性协议。Raft 是一种强一致性的分布式一致性算法,确保在集群中的节点之间达成一致的状态。

强一致性: Consul 的一致性保证是强一致性,即任何时刻对 Consul 集群的读写操作都能获得最新的、一致的状态。

一致性级别: Consul 提供强一致性,这意味着在进行读操作时,所有节点都能够返回相同的数据。

可用性(Availability)

多数据中心支持: Consul 具有跨多个数据中心的支持,允许在全球范围内构建具有高可用性和弹性的系统。

健康检查: Consul 允许服务注册和进行健康检查,当服务出现故障时,Consul 能够将其标记为不可用。这有助于确保只有健康的服务被路由到,提高系统的可用性。

服务发现: 通过 Consul 的服务发现功能,应用程序能够自动发现和调用其他服务,提高了整个系统的可用性。

分区容忍性(Partition Tolerance)

分布式架构: Consul 的设计考虑了分布式系统的特性,它可以在面临网络分区的情况下继续运行。

Raft 协议: Raft 协议本身具有分区容忍性,即使在网络分区的情况下,Consul 仍然能够保持一致性。

总体而言,Consul 在 CAP 方面的实现是一致性和可用性的权衡,通过使用 Raft 协议等技术实现了强一致性,并提供了多数据中心支持以增强可用性。在网络分区的情况下,Consul 通过分布式架构和一致性协议来维持系统的正常运行。需要注意的是,当发生网络分区时,可能会导致一些节点无法通信,但 Consul 会根据 Raft 协议维护尽可能多的一致性。

以下是 Consul 的主要功能:

服务发现: Consul 允许服务在注册时提供元数据,并使用 DNS 或 HTTP 接口进行服务发现。这使得服务能够在分布式环境中自动发现彼此。

健康检查: Consul 支持对服务进行健康检查,通过定期的心跳检查服务的健康状态,并在服务出现故障时将其标记为不可用。这有助于确保只有健康的服务被路由到。

分布式 KV 存储: Consul 提供了一个分布式键值存储(Key-Value Store),用于存储配置信息、控制开关等。这使得配置管理变得更加容易。

多数据中心: Consul 具有跨多个数据中心的支持,允许在全球范围内构建具有高可用性和弹性的系统。

事件: Consul 支持事件系统,允许应用程序对服务注册、健康状态变化等事件进行监听,从而执行相应的操作。

Consul 优点:

简单易用: Consul 提供简洁而直观的用户界面,容易上手。它的设计目标之一是提供一个易于使用的服务发现和配置管理工具。

多功能性: Consul 不仅提供服务发现,还包括健康检查、配置中心和分布式锁等功能。这使得它成为构建和管理分布式系统的全面解决方案。

灵活性: Consul 提供了多种配置选项和部署模式,可以根据特定需求进行灵活配置和定制。

多数据中心支持: 对于需要在多个数据中心部署的大规模系统,Consul 提供了良好的支持,使得服务发现和管理更为简便。

活跃社区和支持: 由于是由 HashiCorp 公司维护的开源项目,Consul 拥有一个活跃的社区,提供了广泛的文档和支持。

Consul 缺点:

Java 客户端相对不完善: 在 Java 生态系统中,Consul 的客户端相对较新,相比其他语言的客户端可能有一些不足之处。

学习曲线: 尽管 Consul 设计简单,但在一些复杂的场景中,使用所有功能可能需要一些时间来学习。

资源占用: Consul 的一些功能可能占用较多的系统资源,特别是对于较小的部署场景来说,可能会显得过于重量级。

1 Docker 拉取 Consul 镜像

docker pull consul

2 Docker 创建 Consul 容器

docker run -d -p 8300:8300 -p 8301:8301 -p 8302:8302 -p 8500:8500 -p 8600:8600 --restart=always --name=consul consul:latest agent -server -bootstrap -ui -node=1 -client='0.0.0.0'
端口作用
8300TCP协议,用于Consul集群中各个节点相互连结通信的端口。
8301TCP或者UDP协议,用于Consul节点之间相互使用Gossip协议健康检查等交互。
8302TCP或者UDP协议,用于单个或多个数据中心之间的服务器节点的信息同步。
8500HTTP协议,用于API接口或者我们上述的网页管理界面访问。
8600TCP或者UDP协议,作为DNS服务器,用于通过节点名查询节点信息。
参数作用
agent表示启动一个Agent进程。
-server表示该节点类型为Server节点(下面会讲解集群中的节点类型)
-ui开启网页可视化管理界面。
-node指定该节点名称,注意每个节点的名称必须唯一不能重复!上面指定了第一台服务器节点的名称为n1,那么别的节点就得用其它名称。
-bootstrap-expect最少集群的Server节点数量,少于这个值则集群失效,这个选项必须指定,由于这里是单机部署,因此设定为1即可。
-advertise这里要指定本节点外网地址,用于在集群时告诉其它节点自己的地址,如果是在自己电脑上或者是内网搭建单节点/集群则不需要带上这个参数。
-client指定可以外部连接的地址,0.0.0.0表示外网全部可以连接。
–restart=alwaysDocker启动的时候自动启动。

3 启动 Consul 容器

在这里插入图片描述在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1236193.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

dolphinscheduler任务莫名重跑

dolphinscheduler运行了一段时间,忽然发现一个流程下某个任务一直在自动重跑,把工作流删了,任务删了,下线等等,都不能阻止他重复的运行,每秒1次,真是见了鬼 1、把zookeeper停掉发现不再重跑了 …

基于SSM的校内互助交易平台设计

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…

idea开发jface、swt环境搭建

背景 jface、swt很难找到合适的maven仓库来下载配套的版本idea对eclipse套件不友好eclipse的windowbuilder固然很好, 但本人更喜欢idea编程, 互相取长补短 下载套件 进入swt下载界面 以当前最新的4.29为例, 点击: 找到全部并…

02-微服务的拆分规则和基于RestTemplate的远程调用

微服务的拆分与远程调用 创建父工程 任何分布式架构都离不开服务的拆分, 微服务也是一样 , 微服务的拆分遵守三个原则 微服务需要根据业务模块拆分,不同微服务不要重复开发相同业务每个微服务都有自己独立的数据库, 不要直接访问其他微服务的数据库微服务可以将自己的业务暴…

第28期 | GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区,集成了生成预训练Transformer(GPT)、人工智能生成内容(AIGC)以及大型语言模型(LLM)等安全领域应用的知识。在这里,您可以…

多样式按钮

代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-…

使用 ClickHouse 做日志分析

原作&#xff1a;Monika Singh & Pradeep Chhetri 这是我们在 Monitorama 2022 上发表的演讲的改编稿。您可以在此处找到包含演讲者笔记的幻灯片和此处的视频。 当 Cloudflare 的请求抛出错误时&#xff0c;信息会记录在我们的 requests_error 管道中。错误日志用于帮助解…

OpenHarmony 4.1计划明年Q1发布, 5.0预计Q3发布

据HarmonyOS官方组织透露&#xff0c;OpenHarmony 4.0 版本已于 10 月 26 日正式发布&#xff0c;开发套件同步升级到 API 10。开放原子开源基金会现更新了 OpenHarmony 4.1&5.0 版本路线图。据介绍&#xff0c;OpenHarmony 4.1 Beta 版本预计将于年底完成测试并发布&#…

如何用 GPTs 帮你写科研项目申请书?

&#xff08;注&#xff1a;本文为小报童精选文章&#xff0c;已订阅小报童或加入知识星球「玉树芝兰」用户请勿重复付费&#xff09; 需求 学生们往往会觉得&#xff0c;写开题报告是个苦差事。但他们或许不知道&#xff0c;老师们写起科研项目申请书&#xff0c;压力远比他们…

RK3568平台开发系列讲解(Linux系统篇)kernel config 配置解析

🚀返回专栏总目录 文章目录 一、图形化界面的操作二、Kconfig 语法简介三、.config 配置文件介绍四、deconfig 配置文件沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 Linux 内核可以通过输入“make menuconfig”来打开图形化配置界面,menuconfig 是一套图形化的配…

Kafka 控制器(controller)

Kafka 控制器&#xff08;controller&#xff09; 在kafka集群中 会存在一个或者多个broker&#xff08;一个服务器就是一个broker&#xff09;&#xff0c;其中有一个broker会被选举为控制器 kafka controller &#xff0c;负责管理整个集群中所有副本、分区的状态&#xff0…

2021秋招-数据结构-栈、队列、数组、列表

栈、队列、数组、列表 实现方式 队列 class Queue:def __init__(self):self.items []def enqueue(self, item):self.items.append(item)def dequeue(self):return self.items.pop(0)def empty(self):return self.size() 0def size(self):return len(self.items)应用: 约瑟…

shell 脚本语句

目录 条件语句 test 命令 比较整数数值 字符串比较 命令举 条件逻辑测试操作 组合写法 举例 双中括号 ​编辑 ( ) / { } if 语句的结构 case 语句 脚本举例 识别 yes 和 no 脚本 检查磁盘使用情况脚本 新建用户以及随机设置用户密码的脚本 补充命令 [RANDOM…

Python+Qt虹膜检测识别

程序示例精选 PythonQt虹膜检测识别 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对《PythonQt虹膜检测识别》编写代码&#xff0c;代码整洁&#xff0c;规则&#xff0c;易读。 学习与应用推…

【C++进阶之路】第十一篇:C++的IO流

文章目录 1. C语言的输入与输出2. 流是什么3. CIO流3.1 C标准IO流3.2 C文件IO流 4.stringstream的简单介绍 1. C语言的输入与输出 C语言中我们用到的最频繁的输入输出方式就是scanf ()与printf()。 scanf(): 从标准输入设备(键盘)读取数据&#xff0c;并将值存放在变量中。prin…

京东数据分析(京东数据采集):2023年10月京东平板电视行业品牌销售排行榜

鲸参谋监测的京东平台10月份平板电视市场销售数据已出炉&#xff01; 根据鲸参谋电商数据分析平台的相关数据显示&#xff0c;10月份&#xff0c;京东平台上平板电视的销量将近77万&#xff0c;环比增长约23%&#xff0c;同比则下降约30%&#xff1b;销售额为21亿&#xff0c;环…

大数据Doris(二十七):Routine Load数据导入演示

文章目录 Routine Load数据导入演示 一、启动kafka集群(三台节点都启动) 二、创建topic

「MACOS限定」 如何将文件上传到GitHub仓库

介绍 本期讲解&#xff1a;如何在苹果电脑上上传文件到github远程仓库 注&#xff1a;写的很详细 方便我的朋友可以看懂操作步骤 第一步 在电脑上创建一个新目录&#xff08;文件夹&#xff09; 注&#xff1a;创建GitHub账号、新建github仓库、git下载的步骤这里就不过多赘…

数据库基本操作--------高级MySQL语句

一、高级SQL语句 1、SELECT ----显示表格中一个或数个栏位的所有资料 语法&#xff1a;SELECT “栏位” FROM “表名”; SELECT Store_Name FROM Store_Info; 2、DISTINCT ----不显示重复的资料 语法&#xff1a;SELECT DISTINCT “栏位” FROM “表名”; SELECT DISTINCT Sto…

Docker快速搭建RTMP服务(tiangolo/nginx-rtmp:Docker + Nginx+ nginx-rtmp-module)

Linux Docker快速搭建多媒体/视频流的 RTMP 服务 第一步 安装Docker 点击这里查看 第二步 拉取并运行镜像 tiangolo/nginx-rtmp/ docker pull tiangolo/nginx-rtmp docker run -d -p 1935:1935 --name nginx-rtmp tiangolo/nginx-rtmpOBS客户端测试 OBS客户端设置直播的推…