Nacos(替代Eureka)注册中心
Nacos初步学习
Nacos 是一个开源的服务注册和配置中心,它允许您注册、注销和发现服务实例,并提供了配置管理的功能。下面是Nacos的最基础用法:
1. 服务注册和发现:
首先,您需要将您的应用程序或服务注册到Nacos中。这可以通过配置应用程序的Nacos客户端来完成。通常,您需要提供服务的名称、主机名和端口等信息,以便其他应用程序可以发现并访问您的服务。
# Nacos注册配置示例
spring:application:name: my-servicecloud:nacos:discovery:server-addr: localhost:8848
然后,其他应用程序可以使用Nacos的客户端来发现并访问您的服务。这允许了动态的、基于服务的通信
@Service
public class MyService {@Autowiredprivate DiscoveryClient discoveryClient;public String discoverService() {List<ServiceInstance> instances = discoveryClient.getInstances("my-service");if (instances.isEmpty()) {return "No service instances available.";}// 选择一个服务实例并进行通信ServiceInstance serviceInstance = instances.get(0);String serviceUrl = serviceInstance.getUri().toString();// 发送请求到服务// ...return "Response from service: " + serviceUrl;}
}
2. 配置管理:
Nacos还允许您将配置信息存储在其配置中心中,以便动态管理和更新配置。您可以将配置信息存储在Nacos中,并在需要时在应用程序中获取和使用它。
# Nacos配置示例
spring:cloud:nacos:config:server-addr: localhost:8848namespace: your-namespacegroup: your-group
然后,您可以使用Nacos的配置客户端来获取配置信息。
@RefreshScope
@RestController
public class MyController {@Value("${my.property}")private String myProperty;@GetMapping("/getMyProperty")public String getMyProperty() {return "My Property: " + myProperty;}
}
3.分级存储模型
与Eureka区别
在生产者-消费者-注册中心模型中,nacos对生产者的非临时实例会主动询问,对消费者的主动推送消息,
采用临时实例时,nacos和Eureka都是遵循AP原则;采用非临时实例时,nacos遵循CP原则
CAP原则
CAP 原则,又称 CAP 定理,是分布式计算领域的一个重要原则,它描述了在分布式系统中三个核心特性之间的权衡关系。这三个特性分别是一致性(Consistency)、可用性(Availability)、分区容忍性(Partition Tolerance)。CAP 原则指出,在一个分布式系统中,不能同时满足这三个特性,只能在它们之间进行权衡选择。以下是对 CAP 原则各个部分的详细解释:
一致性(Consistency):
一致性要求在分布式系统的所有节点上,对于同一个数据操作的结果必须是一致的。也就是说,如果一个节点在某个时刻对数据进行了修改,那么其他节点在后续读取该数据时应该看到修改后的值。
一致性强调数据的强一致性,即任何时间点都能读取到最新的数据,但这可能需要在分布式系统中增加通信和延迟。
可用性(Availability):
可用性要求分布式系统在任何时刻都应该对客户端请求做出响应,即系统能够提供服务。
可用性强调系统的可靠性和可访问性,不管是否有节点出现故障或网络问题,系统都应该继续提供服务。
分区容忍性(Partition Tolerance):
分区容忍性要求分布式系统能够在网络分区或通信故障的情况下继续运行。分区指的是将网络划分为多个不连通的子网络,其中一些子网络之间可能出现通信故障。
分区容忍性强调系统能够处理网络故障和节点之间的通信问题,确保系统的稳定性。
根据 CAP 原则,分布式系统只能在一致性、可用性和分区容忍性中选择两个,无法同时满足所有三个。这被称为 CAP 原则的三角权衡。具体来说:
如果系统追求强一致性和可用性,那么在分区发生时,系统可能会停止响应请求。这种情况下,系统会牺牲分区容忍性。
如果系统追求分区容忍性和可用性,那么系统可能会在某些情况下返回不一致的数据,即牺牲了一致性。
如果系统追求一致性和分区容忍性,那么在分区发生时,系统可能会牺牲可用性,即暂时停止对请求的响应,直到分区问题解决。
分区容忍性(Partition Tolerance)和可用性(Availability)确实都涉及系统在面对问题时继续提供服务,但它们关注的方面略有不同,可以通过以下方式进行区分:
分区容忍性:
**分区容忍性关注的是系统在面对网络分区(Partition)或通信故障时的能力。**分区指的是将网络划分为多个不连通的子网络,其中一些子网络之间可能出现通信故障。
分区容忍性强调系统能够在分区发生时继续运行,即使部分节点无法与其他节点通信。它确保了系统在分区情况下不会因为通信问题而完全停止工作。
分区容忍性通常考虑了分布式系统中的网络延迟、丢包以及节点之间的通信失败。
可用性:
可用性关注的是系统在任何时刻都能够对客户端请求做出响应,即系统能够提供服务。
可用性强调系统的可靠性和可访问性,确保即使没有发生网络分区,系统仍然能够正常运行,不会出现长时间的不可用情况。
可用性通常考虑了系统的健康状况、硬件故障、软件错误以及其他可能导致系统停止响应的问题。
相关文章:

Nacos(替代Eureka)注册中心
Nacos初步学习 Nacos 是一个开源的服务注册和配置中心,它允许您注册、注销和发现服务实例,并提供了配置管理的功能。下面是Nacos的最基础用法: 1. 服务注册和发现: 首先,您需要将您的应用程序或服务注册到Nacos中。…...

FHRP首跳冗余的解析
首跳冗余的解析 个人简介 HSRP hot standby router protocol 热备份路由协议 思科设备上 HSRP VRRP 华为设备上 VRRP HSRP v1 version 1 HSRP v2 version 2 虚拟一个HSRP虚拟IP地址 192.168.1.1 开启HSRP的抢占功能 通过其他参数 人为调整谁是主 谁是从 &a…...

垂直分表为什么能够加快查询效率?
前言 垂直分表是分库分表中分表操作上一个重要的实现方式,利用垂直分表可以提高数据的处理效率和查询速度,本节主要围绕 垂直分表为什么能够加快查询速度 展开说明,以mysql查询的底层流程为例。 垂直分表是将一张表按列分为多张表,…...

Linux网络基础知识全面总结
文章目录 linux网络基础知识1.1 IP地址和子网掩码1.2 网关和路由1.3 域名系统 (DNS)1.4 端口和协议 Linux网络配置2.1 ifconfig命令2.2 网络接口配置文件2.3 DHCP自动获取IP地址2.4 静态IP地址配置2.5 网络重启和应用配置3. 网络工具和命令3.1 ping命令3.2 traceroute和mtr命令…...

【arm实验2】按键中断事件控制实验
设置按键中断,按键1按下,LED亮,再次按下,灭 按键2按下,蜂鸣器叫,再次按下,停 按键3按下,风扇转,再次按下,停 主函数: linuxlinux:~/study/08-c$…...

【数据结构-栈 二】【单调栈】每日温度、接雨水
废话不多说,喊一句号子鼓励自己:程序员永不失业,程序员走向架构!本篇Blog的主题是【单调栈的应用】,使用【栈】这个基本的数据结构来实现,这个高频题的站点是:CodeTop,筛选条件为&am…...

基于Keil a51汇编 —— 控制语句
ALIGN ALIGN expression ALIGN 语句将位置计数器设置为下一个地址模 2^表达式。 这可用于确保下一条语句在 2^n 边界上对齐。例如,对齐缓存行中的代码或数据。如有必要,汇编程序会创建一个间隙。间隔字节的内容因各个部分而异: 在data中未定…...

单目标优化算法:火鹰优化算法(Fire Hawk Optimizer,FHO)求解23个函数--提供MATLAB代码
一、火鹰优化算法FHO 火鹰优化算法(Fire Hawk Optimizer,FHO)由Mahdi Azizi等人于2022年提出,该算法性能高效,思路新颖。 单目标优化:火鹰优化算法(Fire Hawk Optimizer,FHO&#…...

数据集笔记:分析OpenCellID 不同radio/ create_time update_time可视化
1 读取数据 (以新加坡的cellID为例) import geopandas as gpd import pandas as pdopencellidpd.read_csv(OpenCellID_SG.csv,headerNone,names[radio,mcc,net,area,cell,unit,lon,lat,range,samples,changeable1,created1,updated,AveSignal]) opence…...

【特纳斯电子】血氧饱和度监测仪设计-实物设计
视频及资料链接:血氧饱和度监测仪设计-实物设计 - 电子校园网 编号: T5662203M-SW 设计简介: 本设计是基于STM32的血氧饱和度监测仪系统,主要实现以下功能: 1. STM32单片机作为微处理器 2. MAX30102进行心率血氧检…...

雪花算法生成ID传到前端之后精度丢失问题
第一种:使用注解解决 使用方便简单,粒度高,适用于部分字段需要单独转换的场景,灵活度高 // 两种注解,选其一即可 // JsonFormat(shape JsonFormat.Shape.STRING) JsonSerialize(using ToStringSerializer.class) pri…...

Windows 10 - 适用于各种服务(Redis、MySQL)的文件迁移到其他目录后,导致的各种服务找不到的问题 - 注册服务 - 关闭服务 - 重启服务
目录 一、MySQL 服务找不到问题二、Redis 服务找不到问题Tips 三、PostgreSQL 服务找不到问题参考链接 必须要用管理员打开 doc 窗口,然后才进行以下操作。 通用命令 先关闭 xxx 服务 sc query xxx服务名,如 redis 服务 sc query redis sc query 删除…...

Java 串行接口调用优化
准备面试总结下 1.CompletableFuture static ThreadPoolExecutor poolExecutor new ThreadPoolExecutor(10, 20, 1000L, TimeUnit.MICROSECONDS, new ArrayBlockingQueue<>(100));public static void main(String[] args) throws ExecutionException, InterruptedExcep…...

【Java 进阶篇】JavaScript `typeof` 操作符详解
JavaScript是一种弱类型语言,这意味着变量的数据类型通常是灵活的。为了更好地理解和操作数据,JavaScript提供了typeof操作符,它可以用来确定一个值的数据类型。在本篇博客中,我们将详细讨论typeof操作符,包括它的用法…...

electron之进程间通信
Electron进程间通信 使用electron编写程序时经常遇到下面这种场景: 当用户点击一个按钮时,需要将页面输入的信息保存到本地电脑上; 或者是点击菜单时,需要页面窗口做出响应。 用户点击的按钮和窗口展示的内容是运行在渲染进程中&…...

Linux网络编程:UDP协议和TCP协议
目录 一. 对于端口号的理解 1.1 网络通信五元组 1.2 端口号的划分策略 二. 网络通信中常用的指令 2.1 netstat指令 2.2 pidof指令 三. udp协议 3.1 udp的概念及特点 3.2 udp协议端格式 3.3 对于面向数据报及应用层发送与读取数据的理解 四. tcp协议的概念及特点 五.…...

【SCS-CN】SCS-CN模型中CN值的确定
目录 一、说明二、SWAT三、HEC-HMS四、CN值转换公式五、确定CN25.1 ArcSWAT 2009用户指南5.2 SWAT plus Document5.3 National Engineering Handbook5.4 HEC-HMS水文建模系统原理方法应用5.5 Technical Release 55 (TR-55) 六、确定水文土壤单元(HSG)6.1…...

【C++】继承 ① ( 面向对象特点 | 类之间的关系 | 单继承与多继承 | 继承关系特性 )
文章目录 一、面向对象相关概念1、面向对象特点2、类之间的关系 二、继承概念1、名词说明2、单继承与多继承单继承多继承 3、继承关系特性 一、面向对象相关概念 1、面向对象特点 面向对象的 4 4 4 大特点 : 抽象 : 只关注对象的功能和行为 , 而不过问实现的具体细节 ;封装 :…...

虹科方案 | 虹科ATTO加速虚拟存储管理
虹科方案 | 虹科ATTO加速虚拟存储管理 文章来源:虹科网络安全 点此阅读原文:https://mp.weixin.qq.com/s/SYruurSQSodUvyhZBr-BMQ 1 方案背景 企业越来越多地转向服务器虚拟化,以有效利用硬件资源、降低运营成本,并为维护和灾难恢…...

Docker项目部署lnmp+wordpress
一.项目环境 公司在实际的生产环境中,需要使用Docker 技术在一台主机上创建LNMP服务并运行Wordpress网站平台。然后对此服务进行相关的性能调优和管理工作。 1.1 环境描述 主机 操作系统 IP地址 主要软件 Docker C…...

leetcode 121. 买卖股票的最佳时机、122. 买卖股票的最佳时机 II
121. 买卖股票的最佳时机 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从…...

系统架构设计:5 论软件的可靠性设计
目录 一 可靠性设计 1 可靠性 2 影响可靠性的因素 3可靠性设计技术 (1)避错技术...

03 独立看门狗 hal库 stm32cubemx
1.设置配置参数 > 2.初始化 IWDG_HandleTypeDef hiwdg;/* IWDG init function */ void MX_IWDG_Init(void) //Tout((42^prer) rlr) /40 // IWDG_PRESCALER_8 (42^prer) 8/40 *5*2000 64/40 *4095 ---6s {/* USER CODE BEGIN IWDG_Init 0 *//* USER CODE END IWDG_…...

大数据学习(6)-hive底层原理Mapreduce
&&大数据学习&& 🔥系列专栏: 👑哲学语录: 承认自己的无知,乃是开启智慧的大门 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言📝支持一下博>主哦&#x…...

SQLite:TIMESTAMP类型使用
SQLite:CURRENT_TIMESTAMP是以GMT时区为准,而不是本地机器的时区 在本文中,我们将介绍SQLite数据库中的一个特性:CURRENT_TIMESTAMP。在SQLite中,我们可以使用CURRENT_TIMESTAMP函数来获取当前时间戳。然而࿰…...

迅镭激光GI系列高功率激光切割机成功中标覆铜板龙头企业HZ公司
新材料被称为“发明之母”和“产业粮食”,是现代科技发展的基础,和信息技术、生物技术一起并称为最重要和最具发展潜力的三大领域,它是我国先进制造业发展的支撑和保障,对推动技术创新、促进制造业优化升级、保障国家安全等具有重…...

基于SSM的网络安全宣传网站设计与实现
末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…...

k8s修改集群IP--重置集群
原来IP地址 192.168.10.138 k8s-master 192.168.10.139 k8s-node1 192.168.10.140 k8s-node2 新IP地址 192.168.10.148 k8s-master 192.168.10.149 k8s-node1 192.168.10.150 k8s-node2 cp -Rf /etc/kubernetes/ /etc/kubernetes-bak pki 证书目录保留下来: rm -rf …...

记录:R语言生成热图(非相关性)
今天解决了一个困扰了我很久的问题,就是如何绘制不添加相关性的热图。一般绘制热图是使用corrplot包画相关性图,但是这样有一个前提,就是输入的数据集必须进行相关性分析。那么如果我不需要进行相关性分析,而是直接绘制能够反应数…...

第55篇-某did滑块流程分析-滑动验证码【2023-10-12】
声明:该专栏涉及的所有案例均为学习使用,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!如有侵权,请私信联系本人删帖! 文章目录 一、前言二、滑块流程分析三、参数分析1.verifyParam参数分析2.c参数分析四、captchaToken激活五、流程整理一、前言 我…...