naco(替代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;}
}

在这里插入图片描述

与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)或通信故障时的能力。**分区指的是将网络划分为多个不连通的子网络,其中一些子网络之间可能出现通信故障。
分区容忍性强调系统能够在分区发生时继续运行,即使部分节点无法与其他节点通信。它确保了系统在分区情况下不会因为通信问题而完全停止工作。
分区容忍性通常考虑了分布式系统中的网络延迟、丢包以及节点之间的通信失败。
可用性:

可用性关注的是系统在任何时刻都能够对客户端请求做出响应,即系统能够提供服务。
可用性强调系统的可靠性和可访问性,确保即使没有发生网络分区,系统仍然能够正常运行,不会出现长时间的不可用情况。
可用性通常考虑了系统的健康状况、硬件故障、软件错误以及其他可能导致系统停止响应的问题。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot-黑马程序员-学习笔记(三)

目录 30.springboot整合MyBatis-plus 32.SSM整合 38.MP中的条件查询 小知识&#xff1a;许多放在类前面的注解&#xff0c;比如Mapper,Service都是将该类定义成一个Bean&#xff0c;交给spring管理 39.Service模块 30.springboot整合MyBatis-plus 1.创建普通springboot项目…

设计模式 - 行为型模式考点篇:观察者模式(概述 | 案例实现 | 优缺点 | 使用场景)

目录 一、行为型模式 1.1、观察者模式 1.1.1、概述 1.1.2、案例实现 1.1.3、优缺点 1.1.4、使用场景 一、行为型模式 1.1、观察者模式 1.1.1、概述 观察者模式又称为 发布 - 订阅 模式.&#xff0c;就是让多个观察者对象同时监听同一个主题对象. 这个主题对象在变化的同…

子组件跳转父组件

描述&#xff1a;父组件Form.vue 点击关联&#xff0c;弹出子组件importForm.vue 选中一条数据之后&#xff0c;点击确定按钮&#xff0c;关闭子组件importForm.vue&#xff0c;将子组件的内容显示在父组件Form.vue中 选中第一条数据&#xff0c;点击确定 父组件对应的工作内容…

【深度学习】Chinese-CLIP 使用教程,图文检索,跨模态检索,零样本图片分类

代码&#xff1a;https://github.com/OFA-Sys/Chinese-CLIP/blob/master/deployment.md 文章目录 安装环境和onnx推理转换所有模型为onnx测试所有onnx模型的脚本onnx cpu方式执行docker镜像 安装环境和onnx推理 安装环境&#xff0c;下载权重放置到指定目录&#xff0c;进行on…

Kubernetes革命:云原生时代的应用编排和自动化

文章目录 什么是Kubernetes以及为何它备受欢迎&#xff1f;云原生应用和K8s的关系Kubernetes的核心概念&#xff1a;Pods、Services、ReplicaSets等部署、扩展和管理应用程序的自动化容器编排的演进&#xff1a;Docker到Kubernetes实际用例&#xff1a;企业如何受益于K8s的应用…

相机坐标系之间的转换

一、坐标系之间的转换 一个有4个坐标系&#xff1a;图像坐标系、像素坐标系、相机坐标系、世界坐标系。 1.图像坐标系和像素坐标系之间的转换 图像坐标系和像素坐标系在同一个平面&#xff0c;利用平面坐标系之间的转换关系可以之知道两个坐标系变换的公式&#xff0c;并且该…

MFC文本输出学习

void CTxttstView::OnDraw(CDC* pDC) {CTxttstDoc* pDoc GetDocument();ASSERT_VALID(pDoc);// TODO: add draw code for native data hereCString str1;pDC->SetBkColor(RGB(0,0,0));pDC->TextOut(50, 50, "一段文字");pDC->SetBkColor(RGB(255,255,255))…

关于 打开虚拟机出现“...由VMware产品创建,但该产品与此版VMwareWorkstateion不兼容,因此无法使用” 的解决方法

文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/133678951 红胖子(红模仿)的博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结…

超低延时直播技术演进之路-进化篇

一、概述 网络基础设施升级、音视频传输技术迭代、WebRTC 开源等因素&#xff0c;驱动音视频服务时延逐渐降低&#xff0c;使超低延时直播技术成为炙手可热的研究方向。实时音视频业务在消费互联网领域蓬勃发展&#xff0c;并逐渐向产业互联网领域加速渗透。经历了行业第一轮的…

Spark 9:Spark 新特性

Spark 3.0 新特性 Adaptive Query Execution 自适应查询(SparkSQL) 由于缺乏或者不准确的数据统计信息(元数据)和对成本的错误估算(执行计划调度)导致生成的初始执行计划不理想&#xff0c;在Spark3.x版本提供Adaptive Query Execution自适应查询技术&#xff0c;通过在”运行…

Kafka集群架构设计原理详解

从 Zookeeper 数据理解 Kafka 集群工作机制 这一部分主要是理解 Kafka 的服务端重要原理。但是 Kafka 为了保证高吞吐&#xff0c;高性能&#xff0c;高可扩展的三高架构&#xff0c;很多具体设计都是相当复杂的。如果直接跳进去学习研究&#xff0c;很快就会晕头转向。所以&am…