微服务-服务治理

注册中心

在微服务远程调用的过程中,包括两个角色:

  • 服务提供者:提供接口供其它微服务访问,比如item-service

  • 服务消费者:调用其它微服务提供的接口,比如cart-service

在大型微服务项目中,服务提供者的数量会非常多,为了管理这些服务就引入了注册中心的概念。

三大角色:

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

消费者如何知道提供者的地址:

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

消费者如何得知服务状态变更:

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

当提供者有多个实例,消费者该选择哪个:

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

Nacos注册中心

虚拟机内配置nacos镜像;

在pom文件内配置依赖;

XML 复制代码
<!--nacos 服务注册发现-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

配置.yaml文件;

XML 复制代码
spring:
  application:
    name: item-service # 服务名称
  cloud:
    nacos:
      server-addr: 192.168.66.130:8848 # nacos地址

服务发现

消费者需要连接nacos拉取和订阅服务,因此服务发现的前两步与服务注册是一样,后面再加上服务调用即可:

① 引入nacos discovery依赖

② 配置nacos地址

③ 服务发现,依靠 :private DiscoveryClient discoveryClient;

java 复制代码
//        1.获取商品id
        Set<Long> itemIds = vos.stream().map(CartVO::getItemId).collect(Collectors.toSet());

//        2.查询商品
//        2.1 利用RestTemplate 发起http请求,得到http的响应
        List<ServiceInstance> instances = discoveryClient.getInstances("item-service");
        if(CollUtils.isEmpty(instances)){
            return;
        }
        //2.2 手写负载均衡,从服务列表中挑选一个实例
        ServiceInstance instance = instances.get(RandomUtil.randomInt(instances.size()));

        //2.3 利用RestTemplate发起http请求,得到http响应
        ResponseEntity<List<ItemDTO>> response = restTemplate.exchange(
                instance.getUri() + "/items?ids={ids}",
                HttpMethod.GET,
                null,
                new ParameterizedTypeReference<List<ItemDTO>>() {},
                Map.of("ids", CollUtils.join(itemIds, ","))
        );
相关推荐
攻心的子乐4 分钟前
Flyweight(享元)设计模式 软考 享元 和 代理属于结构型设计模式
java·开发语言
设计师小聂!12 分钟前
Seata分布式事物案例及详解
java·spring·spring cloud
编程乐学(Arfan开发工程师)13 分钟前
16、最佳实践-SpringBoot应用如何编写
java·spring boot·后端
取个好名称28 分钟前
适合初学者的 Blender 第二部分
java·前端·blender
君的名字31 分钟前
怎么判断一个Android APP使用了Qt 这个跨端框架
android·开发语言·qt
xuanjiong34 分钟前
苍穹外卖day1实战,Idea中Lombok编译时“找不到符号”,更改JDK版本最全流程,作者亲身尝试
java·ide·intellij-idea
不秃的开发媛40 分钟前
JFace中MVC的表的单元格编辑功能的实现
java·开发语言·mvc
好奇的菜鸟1 小时前
MyBatis-Plus 中 QueryWrapper 的 Limit 实现
java·tomcat·mybatis
_Tenk_1 小时前
Java SpringBoot 扣子CozeAI SseEmitter流式对话完整实战 打字机效果
java·spring boot·语言模型·ai编程·智能体·coze扣子
努力学习的小廉1 小时前
我爱学算法之—— 二分查找(中)
开发语言·c++·算法