【微服务】服务治理(Nacos注册中心)

embedded/2024/10/20 22:35:44/

服务治理

  • 服务治理
    • 注册中心
    • Nacos注册中心
      • 服务注册
      • 服务发现

服务治理

RestTemplate进行服务间的相互调用是非常有问题的,如果服务备份多个服务器,进行集群服务,而且在开发阶段,我们也不知道其它服务器的地址,那这时我们将如何进行服务器之间的相互调用,我们就需要用到注册中心技术

  • 服务治理中的三个角色

服务提供者:暴露服务接口,供其他服务调用
服务消费者:调用其它服务提供的接口
注册中心:记录并监控微服务各个实例状态,推送变更信息

注册中心

服务提供者会在启动的时候注册自己信息到注册中心,消费者可以从注册中心订阅和拉取服务信息

我的理解:在现在一个服务备份多个分布在多台服务器上,当多个服务启动就将自己挂到注册中心,共消费者选择,起到一个公共黑板墙的作用

  • 消费者符合得知服务状态变更

服务提供者通过心跳机制向注册中心报告自己的健康状态,当心跳异常时注册中心会将异常服务剔除,并通知订阅了该服务的消费者

  • 多个实例,消费者如何选择

消费者可以通过负载均衡算法,从多个实例中选择一个

那么如何实现注册中心,下面提到注册中心技术Nacos

Nacos注册中心

Nacos是目前国内企业中占比最多的注册中心组件,它是阿里巴巴的产品,目前已经存在于SpirngCloudAlibaba中

服务注册

如何将服务注册到注册中心当中:

  1. 引入依赖nacos discovery
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  1. 配置Nacos地址
spring:application:name: 服务名称(项目名)cloud:nacos:server-addr: 192.168.75.135:端口 #nacos地址

服务发现

消费者需要连接nacos以拉取和订阅服务

  1. 引入nacos discovery依赖
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  1. 配置nacos地址
spring:application:name: 服务名称(项目名)cloud:nacos:server-addr: 192.168.75.135:端口 #nacos地址
  1. 服务发现
private final DiscoveryClient discoveryClient;
private void handleCartItems(List<CartVO> vos){//根据服务名称,拉取服务的实例列表List<ServiceInstance> instances =discoveryClient.getInstances("服务名称");//负载均衡,挑选一个实例ServiceInstance instance=instances.get(RandomUtil.randomInt(instances.size()));//获取实例的IP和端口URI uri=instance.getUri();//拿到位置之后再通过RestTemplate进行访问
}

http://www.ppmy.cn/embedded/32632.html

相关文章

奈氏准则和香农定理

一、奈奎斯特和香农 哈里奈奎斯特&#xff08;Harry Nyquist&#xff09;(左) 克劳德艾尔伍德香农&#xff08;Claude Elwood Shannon&#xff09;(右) 我们应该在心里记住他们&#xff0c;记住所有为人类伟大事业做出贡献的人&#xff0c;因为他们我们的生活变得越来越精彩&…

Colab - Introduction to Object Detection using TensorFlow Hub

Colab - Introduction to Object Detection using TensorFlow Hub 1. 源由2. TensorFlow Hub3. 目标检测3.1 举例 - EfficientDet/D4 COCO 20173.2 下载示例图像3.2.1 显示部分样本3.2.2 定义一个将类别ID映射到类别名称和颜色的字典 3.3 加载模型3.4 单张照片执行推理3.4.1 推…

VBA 批量处理Excel文件

目录 一. 批量创建Excel文件1.1 VBA的方式1.2 Powershell方式 二. 批量删除文件 一. 批量创建Excel文件 1.1 VBA的方式 Sub CreateFiles()Dim strPath As String, strFileName As StringDim i As Long, rDim pathSeparator As StringOn Error Resume Next 用户选择文件夹路径…

karpathy Let‘s build GPT

1 introduction 按照karpathy的教程&#xff0c;一步步的完成transformer的构建&#xff0c;并在这个过程中&#xff0c;加深对transformer设计的理解。 karpathy推荐在进行网络设计的过程中&#xff0c;同时利用jupyter notebook进行快速测试和python进行主要的网络的构建。 …

2024年第11届生物信息学研究与应用国际会议(ICBRA 2024)即将召开!

2024年第11届生物信息学研究与应用国际会议&#xff08;ICBRA 2024&#xff09;将于2024年9月13-15日在意大利米兰举行。生物信息学&#xff0c;作为连接生物学与信息技术的桥梁&#xff0c;正日益成为探索生命奥秘、推动生命科学发展的重要力量。ICBRA 2024的召开&#xff0c;…

Redis---------实现商品秒杀业务,包括唯一ID,超卖问题,分布式锁

订单ID必须是唯一 唯一ID构成&#xff1a; 代码生成唯一ID&#xff1a; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component; import java.time.LocalDateTime; import java.time.ZoneOffset; import java.tim…

【OpenNJet下一代云原生之旅】

OpenNJet下一代云原生之旅 1、OpenNJet的定义OpenNJet架构图 2、OpenNJet的特点性能无损动态配置灵活的CoPilot框架支持HTTP/3支持国密企业级应用高效安全 3、OpenNJet的功能特性4、OpenNJet的安装使用编译安装配置yum源创建符号连接修改配置编译 5、通过 OpenNJet 部署 WEB SE…

error: Execution was interrupted, reason: signal SIGABRT

c json解析时&#xff0c; error: Execution was interrupted, reason: signal SIGABRT const Json::Value points root["shapes"]; if (points.isArray()) { for (unsigned int i 0; i < points.size(); i) { std::cout << " - [" <<…