微服务之Nacos注册管理

举报
哥的时代 发表于 2023/11/29 11:06:56 2023/11/29
【摘要】 服务调用尽可能选择本地集群的服务,跨集群调用延迟较高本地集群不可访问时,再去访问其它集群spring:cloud:nacos:server-addr: localhost:8848 #nacos服务地址discovery:cluster-name: HZ #集群名称,这里HZ代指杭州我们可以根据Nacos控制台的实例编辑功能来修改实例的权重:当我们给权重设为0时,此时实例则不会被访问。Nacos中

一、Nacos安装步骤

1.安装地址

博主是在windows下进行安装的,所以如果想在Linux下安装请看官方详细教程

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

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

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

2.安装版本

博主这边采用的nacos版本是1.4.1的,其他版本请看官网详细教程

image.png

3.目录说明

注意:请解压至无中文目录的文件夹内

目录说明:

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

image.png

4.端口配置

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

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

image.png

5.启动

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

image.png

windows下的启动命令

startup.cmd -m standalone

-m:表示模式
standalone:表示单机启动

执行效果图如下:

image.png

点击链接输入用户名:nacos,密码:nacos,即可进入nacos控制台

image.png

二、Nacos服务注册

1.Nacos依赖

父工程

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.5.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

客户端:

<!-- nacos客户端依赖包 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

2.客户端修改配置文件

修改客户端项目中的application.yml文件,注释eureka地址,添加nacos地址:

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

3.启动效果图

image.png

4.总结

image.png

三、Nacos服务集群属性

1.服务跨集群调用问题

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

image.png

2.服务集群属性

修改客户端服务者的application.yml文件,添加如下内容:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: HZ #集群名称,这里HZ代指杭州

分别启动UserApplication1和UserApplicattion2,然后修改cluster-name的名字改为SH,接着启动UserApplication3,即可得到两个集群:

image.png

3.总结

image.png

四、Nacos根据集群负载均衡

1.修改配置文件

修改客户端服务消费者中的application.yml,设置集群为HZ:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: HZ #集群名称,这里HZ代指杭州

2.设置集群服务类型

然后在客户端服务消费者中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务:

userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

3.跨集群访问

当我们HZ集群内的实例都没被启动,但SH集群的实例启动时,会出现跨集群访问,此时我们可以在控制台的日志中查看到一个跨集群访问的提示:

image.png

4.总结

image.png

五、Nacos根据权重负载均衡

1.编写操作

我们可以根据Nacos控制台的实例编辑功能来修改实例的权重:

image.png

image.png

当我们给权重设为0时,此时实例则不会被访问。

2.总结

image.png

六、Nacos环境隔离-namespace

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

image.png

1.命名空间创建操作

在Nacos控制台可以创建namespace,用来隔离不同环境

image.png

然后填写一个新的命名空间信息:

image.png

保存后会在控制台看到这个命名空间的id:

image.png

修改客户端服务消费者的application.yml,添加namespace:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/cloud_order?useSSL=false
    username: root
    password: SHIyb021010
    driver-class-name: com.mysql.jdbc.Driver
  application:
    name: orderservice #user服务的服务名称
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: HZ #集群名称,这里HZ代指杭州
        namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID

重启客户端服务消费者后,再来查看控制台:

image.png

image.png

此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错:

image.png

2.总结

image.png

七、Nacos临时实例和非临时实例

image.png

1.配置临时实例和非临时实例

服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置:

spring:
  cloud:
    nacos:
      discovery:
        ephemeral: false #设置非临时实例

临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会

2.总结

image.png

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。