【2.1】Java微服务: Nacos的使用

目录

Nacos介绍

Nacos安装

下载和安装

修改端口

启动 

服务注册与发现

导入Nacos管理依赖

导入服务依赖

配置Nacos的服务地址

启动服务,查看已注册的服务

服务分级存储模型

分级存储模型介绍

具体结构

配置实例集群

同集群优先的负载均衡策略

服务权重配置

                          点击编辑

                          配置所需的权重

         

环境隔离

namespace介绍 

创建namespace

查看         


Nacos介绍

Nacoshttps://nacos.io/

        Nacos 是一个功能强大的服务发现和配置管理平台,它可以简化微服务架构中的服务注册、配置管理和服务发现等任务,提供了一致性、高可用性和可扩展性的解决方案。通过使用 Nacos,可以更好地管理和协调分布式系统中的各个组件和服务实例。

        Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。【2.1】Java微服务: Nacos的使用_第1张图片         
        

Nacos安装

  下载和安装

        下载地址:

Nacoshttps://github.com/alibaba/nacos/releases        这里展示win版的Nacos,下载过程省略,将下载好的压缩包解压,打开bin目录,可以看到Nacos的启动文件

         【2.1】Java微服务: Nacos的使用_第2张图片

修改端口

         nacos默认端口:8848(可能这就是阿里巴巴的幽默吧,成功人士的标配),如需修改,可以在conf文件下的application.properties文件中修改

                                     

  启动 

        打开命令窗口,输入启动命令

startup.cmd -m standalone

        出现如下界面,说明启动成功

【2.1】Java微服务: Nacos的使用_第3张图片         

        输入窗口中显示的控制台地址,即可进入nacos控制台登录页面,默认账号密码都是:nacos

【2.1】Java微服务: Nacos的使用_第4张图片

        进入Nacos控制台主页

【2.1】Java微服务: Nacos的使用_第5张图片

Nacos服务注册与发现

        nacos的服务注册方式大体与eureka相同,详情请查看我之前发布的:1.2 eureka注册中心,完成服务注册https://blog.csdn.net/hkzuz/article/details/132007406?spm=1001.2014.3001.5501

        在父工程导入Nacos的管理依赖


    com.alibaba.cloud
    spring-cloud-alibaba-dependencies
    2.2.6.RELEASE
    pom
    import

        在需要注册到Nacos的服务中导入服务依赖


    com.alibaba.cloud
    spring-cloud-starter-alibaba-nacos-discovery

         在需要注册到Nacos的服务中的配置文件中配置Nacos的服务地址

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址

        启动服务后,即可在Nacos的服务列表看到已注册的服务

【2.1】Java微服务: Nacos的使用_第6张图片

Nacos的服务分级存储模型

分级存储模型介绍

        一个服务可以有多个实例,在Nacos中,点击服务的详情即可查看 

【2.1】Java微服务: Nacos的使用_第7张图片        

        假如实例分布于全国各地的不同机房,Nacos就将同一机房内的实例 划分为一个集群。一个服务可以包含多个集群。

具体结构

【2.1】Java微服务: Nacos的使用_第8张图片

        微服务互相访问时,应该尽可能访问同集群实例,因为本地访问速度更快。当本集群内不可用时,才访问其它集群。

配置实例集群

        配置集群操作,只需要在对应服务配置文件中修改即可

 cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: USER1 #集群名称

         重新启动服务,在Nacos中可以看到实例在不同的集群(在重启服务后,若看到Nacos中存在空集群或默认集群且为空时,可以重启Nacos,或许可以解决)

        在服务列表可以看到当前user服务具有3个集群

        点击详情可查看 

【2.1】Java微服务: Nacos的使用_第9张图片

 

同集群优先的负载均衡策略

        

        此为Nacos的同集群优先访问的负载均衡规则,同集群内随机访问

userservice: #要做配置的服务名称
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

服务权重配置

        实际部署中,有这样的情况,不同服务器有性能差异,因此要为不同的服务器配置访问权重来控制访问频率,在Nacos中可以选择服务实例直接配置

        点击编辑按钮

                          【2.1】Java微服务: Nacos的使用_第10张图片 

        

        配置所需的权重

                        如下图,配置权重为0.1,和别的实例的访问频率就会是1:10

                        【2.1】Java微服务: Nacos的使用_第11张图片

         

环境隔离

namespace介绍

Nacos不仅是注册中心,还是数据中心,

        Nacos提供了namespace来实现环境隔离功能。

  •                 nacos中可以有多个namespace
  •                 namespace下可以有group、service等
  •                 不同namespace之间相互隔离,例如不同namespace的服务互相不可见

        

创建namespace

        在nacos的命名空间中,可以查看已有空间及其ID,点击添加命名空间按钮可以创建新空间

【2.1】Java微服务: Nacos的使用_第12张图片

        输入空间名和描述,即可创建成功

【2.1】Java微服务: Nacos的使用_第13张图片

        将服务放置到空间中,在配置文件中添加配置

spring:
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        cluster-name: USER1
        namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID

         在服务列表可以查看空间并选择

【2.1】Java微服务: Nacos的使用_第14张图片

查看         

        重启服务,查看空间内是否有对应服务。选择USER空间,可以看到对应的服务

【2.1】Java微服务: Nacos的使用_第15张图片

你可能感兴趣的:(微服务,nacos,springcloud,java)