【十三】Nacos 服务注册和配置中心

Nacos 初识

Nacos (Dynamic Naming and Configuration Service)是阿里巴巴开源的⼀个针对微服务架构中服务发现、配置管理和服务管理平台。

Nacos就是注册中心+配置中心的组合(Nacos=Eureka+Config+Bus)
官网:https://nacos.io 下载地址:https://github.com/alibaba/Nacos

Nacos功能特性

  • 服务发现与健康检查
  • 动态配置管理
  • 动态DNS服务
  • 服务和元数据管理(管理平台的角度,nacos也有⼀个ui页面,可以看到注册的服务及其实例信息
    (元数据信息)等),动态的服务权重调整、动态服务优雅下线,都可以去做

Nacos 服务部署

注册中心服务部署

  1. 下载解压安装包,执⾏命令启动( nacos-server-1.2.0.tar.gz)
linux/mac:sh startup.sh -m standalone
windows:cmd startup.cmd
  1. 访问nacos管理界面:http://127.0.0.1:8848/nacos/#/login(默认端口8848,账号和密码
    nacos/nacos)
    在这里插入图片描述

服务提供者注册到Nacos

在这里插入图片描述

  • 在父pom中引入SCA依赖
<dependency>
 <groupId>com.alibaba.cloud</groupId>
 <artifactId>spring-cloud-alibaba-dependencies</artifactId>
 <version>2.1.0.RELEASE</version>
 <type>pom</type>
 <scope>import</scope>
</dependency>
  • 在服务提供者工程中引入nacos客户端依赖(copy m-service-resume-8081 修改成 m-service-resume-8082-nacos)
<dependency>
 <groupId>com.alibaba.cloud</groupId>
 <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  • application.yml修改,添加nacos配置信息
server:
  port: 8082

spring:
  application:
    name: m-service-resume

  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8 &serverTimezone=UTC
    username: root
    password: root
  jpa:
    database: MySQL
    show-sql: true
    hibernate:
      naming:
        physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl  #避免将驼峰命名转换为下划线命名
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

  • 启动服务,观察nacos控制台
    在这里插入图片描述

服务消费者从Nacos获取服务

在这里插入图片描述

  • 在服务消费者工程中引入nacos客户端依赖(copy m-service-autodeliver-8092 修改成 m-service-autodeliver-8093-nacos)
<dependency>
 <groupId>com.alibaba.cloud</groupId>
 <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  • application.yml修改,添加nacos配置信息
server:
  port: 8093

spring:
  application:
    name: m-service-autodeliver
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

#针对的被调⽤⽅微服务名称,不加就是全局⽣效
m-service-autodeliver:
  ribbon:
    #请求连接超时时间
    ConnectTimeout: 2000
    #请求处理超时时间
    ReadTimeout: 5000
    #对所有操作都进⾏重试
    OkToRetryOnAllOperations: true
    ####根据如上配置,当访问到故障请求的时候,它会再尝试访问⼀次当前实例(次数由MaxAutoRetries配置),
    ####如果不⾏,就换⼀个实例进⾏访问,如果还不⾏,再换⼀次实例访问(更换次数由MaxAutoRetriesNextServer配置),
    ####如果依然不⾏,返回失败信息。
    MaxAutoRetries: 0 #对当前选中实例重试次数,不包括第⼀次调⽤
    MaxAutoRetriesNextServer: 0 #切换实例的重试次数
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #负载策略调整




# 开启Feign的熔断功能
feign:
  hystrix:
    enabled: false
  compression:
    request:
      enabled: true
      mime-types: text/html,application/xml,application/json # 设置压缩的数据类
    response:
      enabled: true

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            ##########################################Hystrix的超时时长设置
            timeoutInMilliseconds: 15000
  • 访问测试
    -在这里插入图片描述

负载均衡

  • 在服务消费者工程中引入nacos客户端依赖 新增服务 m-service-resume-8083-nacos
    在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
权重为0 ,相当于服务下线,在此访问服务,测只能访问到8082.
在这里插入图片描述

Nacos 服务详解

实列服务详情详解

在这里插入图片描述

  • 保护阈值:0~1之间的浮点数。它其实是⼀个比列值(当前服务健康实例数/当前服务总实例
    数)
    场景:
    ⼀般流程下,nacos是服务注册中心,服务消费者要从nacos获取某⼀个服务的可用实例信息,对于服
    务实例有健康/不健康状态之分,nacos在返回给消费者实例信息的时候,会返回健康实例。这个时候在
    ⼀些搞并发、⼤流量场景下会存在⼀定的问题

如果服务A有100个实例,98个实例都不健康了,只有2个实例是健康的,如果nacos只返回这两个健康
实例的信息的话,那么后续消费者的请求将全部被分配到这两个实例,流量洪峰到来,2个健康的实例
也扛不住了,整个服务A 就扛不住,上游的微服务也会导致崩溃,,,产⽣雪崩效应。

保护阈值的意义在于
当服务A健康实例数/总实例数 < 保护阈值 的时候,说明健康实例真的不多了,这个时候保护阈值会被触发(状态true)nacos将会把该服务所有的实例信息(健康的+不健康的)全部提供给消费者,消费者可能访问到不健康的实例,请求失败,但这样也比造成雪崩要好,牺牲了⼀些请求,保证了整个系统的⼀个可用。

扫描二维码关注公众号,回复: 16913608 查看本文章

猜你喜欢

转载自blog.csdn.net/u014535922/article/details/130599759