• Nacos Discovery服务治理


    1、服务治理基本概念

    服务治理是微服务架构中最核心最基本的模块。用于实现各个微服务的自动化注册与发现

    服务注册:在服务治理框架中,都会构建一个注册中心,每个服务单元向注册中心登记自己提供服

    务的详细信息。并在注册中心形成一张服务的清单,服务注册中心需要以心跳30s  90s的方式去监测清单中 的服务是否可用,如果不可用,需要在服务清单中剔除不可用的服务。

    服务发现:服务调用方向服务注册中心咨询服务,并获取所有服务的实例清单,实现对具体服务实

    例的访问。

    通过上面的调用图会发现,除了微服务,还有一个组件是服务注册中心,它是微服务架构非常重要

    的一个组件,在微服务架构里主要起到了协调者的一个作用

    注册中心一般包含如下几个功能:

    1. 服务发现:

    服务注册:保存服务提供者和服务调用者的信息

    服务订阅:服务调用者订阅服务提供者的信息,注册中心向订阅者推送提供者的信息

    2. 服务配置:

    配置订阅:服务提供者和服务调用者订阅微服务相关的配置

    配置下发:主动将配置推送给服务提供者和服务调用者

    3. 服务健康检测

    检测服务提供者的健康情况,如果发现异常,执行服务剔除

    2、常见的注册中心

    Zookeeper

    zookeeper是一个分布式服务框架,是Apache Hadoop 的一个子项目,它主要是用来解决分布式

    应用中经常遇到的一些数据管理问题,如:统一命名服务、状态同步服务、集群管理、分布式应用

    配置项的管理等。

    Eureka 

    EurekaSpringcloud Netflix中的重要组件,主要作用就是做服务注册和发现。但是现在已经

     ,停更不停用。

    Consul

    Consul是基于GO语言开发的开源工具,主要面向分布式,服务化的系统提供服务注册、服务发现

    和配置管理的功能。Consul的功能都很实用,其中包括:服务注册/发现、健康检查、Key/Value

    存储、多数据中心和分布式一致性保证等特性。Consul本身只是一个二进制的可执行文件,所以

    安装和部署都非常简单,只需要从官网下载后,在执行对应的启动脚本即可。

    Nacos (服务治理  配置中心)

    Nacos是一个更易于构建云原生应用的动态服务发现配置管理服务管理平台。它是 Spring

    Cloud Alibaba 组件之一,负责服务注册发现服务配置,可以这样认为nacos=eureka+config

    3、nacos简介

    Nacos 致力于帮助我们发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助我们快速实现动态服务发现、服务配置、服务元数据及流量管理。 

    从上面的介绍就可以看出,nacos的作用就是一个注册中心,用来管理注册上来的各个微服务。

    4、nacos实战

    4.1 搭建nacos环境

    第一步:安装nacos

    下载地址:Releases · alibaba/nacos · GitHub

    可以选择下载Windows版本也可以下载Linux版本,这里使用的是Windows版本

    这里需要注意,nacos的版本要和自己的springboot,springcloud,springcloud alibaba的版本相对应

    下载zip格式的安装包,然后进行解压缩操作

     第二步:启动nacos

    #切换目录

    cd nacos/bin

    #命令启动

    startup.cmd -m standalone

    第三步:访问nacos

    打开浏览器输入http://localhost:8848/nacos,即可访问服务, 默认密码是nacos/nacos

    4.2 将商品微服务注册到nacos

    4.2.1 在pom.xml中添加nacos依赖

    1. <dependency>
    2. <groupId>com.alibaba.cloudgroupId>
    3. <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
    4. dependency>

    4.2.2 在配置文件中加上nacos的相关配置

    1. # 指定注册中心的地址
    2. spring.cloud.nacos.discovery.server-addr=localhost:8848
    3. # 微服务的名字
    4. spring.application.name=springcloud-product

    4.2.3 启动服务,观察nacos的控制面板

    4.3 将订单微服务注册到nacos

    4.2.1 在pom.xml中添加nacos依赖

    1. <dependency>
    2. <groupId>com.alibaba.cloudgroupId>
    3. <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
    4. dependency>

    4.2.2 在配置文件中加上nacos的相关配置

    1. # 指定注册中心的地址
    2. spring.cloud.nacos.discovery.server-addr=localhost:8848
    3. # 订单微服务从注册中心调用注册的微服务,不注册到注册中心
    4. spring.cloud.nacos.discovery.register-enabled=false
    5. # 微服务的名字
    6. spring.application.name=springcloud-order

    4.2.3 启动服务,观察nacos的控制面板

    4.2.4 修改OrderController代码

    1. @RestController
    2. @RequestMapping("order")
    3. public class OrderController {
    4. @Autowired
    5. private OrderService orderService;
    6. @Autowired
    7. private RestTemplate restTemplate;
    8. @Autowired
    9. private DiscoveryClient discoveryClient;
    10. @GetMapping("buy/{pid}/{num}")
    11. public CommonResult buy(@PathVariable Integer pid,@PathVariable Integer num){
    12. //从注册中心获取商品微服务实例
    13. List instances = discoveryClient.getInstances("springcloud-product");
    14. //获取商品微服务的ip和端口号
    15. String path = instances.get(0).getUri().toString();
    16. CommonResult result = restTemplate.getForObject(path+"/product/getOne/" + pid, CommonResult.class);
    17. Product product = JSON.parseObject(JSON.toJSONString(result.getData()), Product.class);
    18. //System.out.println(product);
    19. Order order = new Order(2, "饺子皮", product.getPid(), product.getPname(), product.getPprice(), num);
    20. Integer addOrder = orderService.addOrder(order);
    21. if (addOrder>0){
    22. return new CommonResult(2000,"购买成功",addOrder);
    23. }
    24. return new CommonResult(5000,"购买失败",null);
    25. }
    26. }

    4.2.5 运行订单微服务,观察能否正常下单

  • 相关阅读:
    Java 泛型 T,E,K,V,?
    车载电子电器架构 —— 售后诊断开发
    YOLOv5 PyQt5 | PyQt5快速入门 | 2/3
    考研英语不熟悉的词义(List11-List15)
    EasyNLP中文文图生成模型带你秒变艺术家
    黑盒测试与白盒测试
    计算机毕业设计ssm计算机类图书管理系统ln698系统+程序+源码+lw+远程部署
    Redis持久化
    RSA加密解密详解
    C++前缀和算法的应用:分割数组的最多方案数 原理源码测试用例
  • 原文地址:https://blog.csdn.net/Dumpling_skin/article/details/126428298