SpringCloud-02-Nacos服务注册

一、Nacos介绍

SpringCloud-02-Nacos服务注册_第1张图片

  • Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。
  • 相比于Eureka功能更加丰富,在国内受欢迎程度较高
  • Nacos 是一个更易于帮助构建云原生应用的动态服务发现配置服务管理平台
  • Nacos 的命名是由 3 部分组成:
    组成部分 全称 描述
    Na naming/nameServer 即服务注册中心,与 Spring Cloud Eureka 的功能类似。
    co configuration 即配置中心,与 Spring Cloud Config+Spring Cloud Bus 的功能类似。
    s service 即服务,表示 Nacos 实现的服务注册中心和配置中心都是以服务为核心的。
  • 可以将 Nacos 理解成服务注册中心配置中心的组合体,
  • 它可以替换 Eureka 作为服务注册中心,实现服务的注册与发现;
  • 还可以替换 SpringCloud Config 作为配置中心,实现配置的动态刷新。
  • Nacos 作为服务注册中心具有简单易用稳定可靠性能卓越等优点,
  • 可以帮助用户更敏捷容易地构建管理微服务应用

二、安装

1.1.下载安装包

在Nacos的GitHub页面,提供有下载链接,可以下载编译好的Nacos服务端或者源代码:

GitHub主页:https://github.com/alibaba/nacos

GitHub的Release下载页:https://github.com/alibaba/nacos/releases

1.2.解压

将这个包解压到任意非中文目录下,如图:

SpringCloud-02-Nacos服务注册_第2张图片

目录说明:

  • bin:启动脚本
  • conf:配置文件

1.3.端口配置

Nacos的默认端口是8848,如果你电脑上的其它进程占用了8848端口,请先尝试关闭该进程。

如果无法关闭占用8848端口的进程,也可以进入nacos的conf目录,修改配置文件中的端口:

SpringCloud-02-Nacos服务注册_第3张图片

修改其中的内容:

SpringCloud-02-Nacos服务注册_第4张图片

1.4.启动

启动非常简单,进入bin目录,结构如下:

SpringCloud-02-Nacos服务注册_第5张图片

然后执行命令即可:

windows命令:

 startup.cmd -m standalone

 SpringCloud-02-Nacos服务注册_第6张图片

1.5.访问

在浏览器输入地址:http://127.0.0.1:8848/nacos即可:

SpringCloud-02-Nacos服务注册_第7张图片

 默认的账号和密码都是nacos,进入后:

SpringCloud-02-Nacos服务注册_第8张图片

 三、Nacos快速入门

注意:如果之前使用eureka,需要将相关的依赖注释或删掉

  • 在父工程中引入nacos的管理依赖

     com.alibaba.cloud
     spring-cloud-alibaba-dependencies
     2.2.5.RELEASE
     pom
     import
  •  要进行注册服务的模块添加 nacos客户端依赖


   com.alibaba.cloud
   spring-cloud-starter-alibaba-nacos-discovery
  •  配置文件进行配置
spring:
  application:
    name: userservice
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
  • 启动服务

SpringCloud-02-Nacos服务注册_第9张图片

  • 查看注册中心

 SpringCloud-02-Nacos服务注册_第10张图片

四、Nacos服务多级存储模型

1. 服务多级存储模型,结构图

SpringCloud-02-Nacos服务注册_第11张图片

  •  一级是服务,具体提供某种业务功能。例如:提供用户功能
  •  二级是集群,按照区域划分为一个整体。  例如:上海、杭州等
  •  三级是实例,集群内部具体的服务器 ,例如:上海布置的某台提供用户功能的服务器

2. 服务跨集群调用问题

  • 服务调用尽可能选择本地集群服务,跨集群调用延迟高
  • 本地集群不可访问时,再去访问其他集群

五、 Nacos的负载均衡

1. 服务集群属性设置

  • 未设置之前,集群默认名称为:DEFAULT

SpringCloud-02-Nacos服务注册_第12张图片

  •  通过配置文件,设置集群
spring:
 cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
    discovery:
      cluster-name: SX # 配置集群名称,也就是机房位置,例如 SX ,陕西
spring:
 cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
    discovery:
      cluster-name: GZ # 配置集群名称,也就是机房位置,例如 GZ ,广州
  • 配置好之后启动服务

SpringCloud-02-Nacos服务注册_第13张图片

  •  配置之后的注册中心管理界面

  •  此时集群的名称,和具体的实例所属那个集群

SpringCloud-02-Nacos服务注册_第14张图片

2.  负载均衡访问对应集群

  •  服务消费者配置对应所属的集群,每次请求优先调用本地集群内的服务器

SpringCloud-02-Nacos服务注册_第15张图片

  •  设置服务消费者的负载均衡规则为NacosRule,这个规则优先会寻找与自己同集群的服务
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
  •  多次请求调用 

 8081端口和8082端口所属集群为  SX  与服务消费者所属同一集群因此被调用

 8083端口所属集群为 GZ 与服务消费者不同集群,只有消费者本地集群全不可用,此时才会调用8083端口服务器

3.  根据权重负载均衡

  • 实际部署种会出现这样的场景:服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求
  • Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高

 

SpringCloud-02-Nacos服务注册_第16张图片

SpringCloud-02-Nacos服务注册_第17张图片

  •  Nacos控制台可以设置实例的权重值,0~1之间
  • 同集群内的多个实例,权重越高被访问的频率越高
  • 权重设置为0则完全不会被访问

4. 环境隔离

  • Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来最外层隔离

SpringCloud-02-Nacos服务注册_第18张图片

  • 新建命名空间 

SpringCloud-02-Nacos服务注册_第19张图片

SpringCloud-02-Nacos服务注册_第20张图片

SpringCloud-02-Nacos服务注册_第21张图片

 SpringCloud-02-Nacos服务注册_第22张图片

  •  通过配置文件,设置服务属于那个命名空间
spring:
  application:
    name: orderservice
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        cluster-name: SX # 集群名称,这里  SX 代指广州
        namespace: 2b0e35e5-5fcb-4df0-b563-f839e504f6d1 # 命名空间id
  • 运行服务,此时命名空间dev 里边的服务有 

SpringCloud-02-Nacos服务注册_第23张图片

注意:dev环境下与public环境无法相互访问。即不同命名空间服务不可见 

 命名空间总结:

  • namespace用来做环境隔离
  • 每个namespace都有唯一id
  • 不同namespace下的服务不可见

 六、Nacos和Eureka的区别

Nacos临时实例的设置

  • 默认情况下是临时实例

SpringCloud-02-Nacos服务注册_第24张图片

  •  通过配置文件将服务设置称非临时实例
  • spring:
      application:
        name: orderservice
      cloud:
        nacos:
          server-addr: localhost:8848 # nacos服务地址
          discovery:
            cluster-name: SX # 集群名称,这里  SX 代指广州
            namespace: 2b0e35e5-5fcb-4df0-b563-f839e504f6d1
            ephemeral: false # 是否是临时实例

    SpringCloud-02-Nacos服务注册_第25张图片

共同点:

  • 都支持服务注册和服务拉取
  • 都支持服务提供者心跳方式做健康检测

不同点:

  • Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式
  • 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式

你可能感兴趣的:(SpringCloud,spring,cloud,eureka,java)