Nacos的注册和使用

程序浅谈 工具 2022-08-24

1.服务注册导入Nacos依赖

<!-- SpringCloudAlibaba有关依赖 -->
<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>

复制代码

客户端导入依赖,如果有eureka的依赖得先注掉

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


复制代码

Nacos的注册和使用

1.1 修改配置文件

# 注册cloud
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos 服务地址
复制代码

Nacos的注册和使用到后台在配置文件中查看Nacos的注册和使用

2.NacosRule负载均衡

2.1.配置集群属性

Nacos的注册和使用Nacos的注册和使用

在配置文件cloud的属性下中添加cluster-name 设置集群昵称,就会自动分配Nacos的注册和使用

Nacos的注册和使用

2.2 根据集群配置负载均衡

Nacos的注册和使用

NFLoadBalancerRuLeClassName 同个集群下有多个服务时会采用随机的方式来负载均衡。

添加以下配置文件

spring:
userservice: #要做配置的微服务名称
	ribbon:
		NFLoadBalancerRuLeClassName: 配置负载均衡的规则

复制代码

Nacos的注册和使用出现跨集群访问时,控制台会输出警告信息,提示运维人员。Nacos的注册和使用

2.3 根据权重负载均衡

Nacos的注册和使用Nacos的注册和使用

3.环境隔离

Nacos的注册和使用在没有设置空间下节点默认都是放在命名空间的public默认空间Nacos的注册和使用

3.1 新建空间

Nacos的注册和使用

命名空间后会发现多出来了一个空间ID,在会到服务列表会看到我们新增的一个命名空间Nacos的注册和使用

3.2 代码对接命名空间

Nacos的注册和使用在配置文件中添加namespace:后面跟着命名空间的idNacos的注册和使用

4.和Eureka的区别

Nacos的注册和使用Eureka通过主动询问来判断服务是否还存活,Nacos是通过心跳的来判断。Nacos的注册和使用

5.Nacos配置管理

5.1 创建配置文件实现热更新

新增配置Nacos的注册和使用配置文件昵称必须是要唯一的用于统一管理,Nacos的注册和使用配置内容是把有热更新需求的放进来,如固定格式的配置不需要更新的就不需要填写。Nacos的注册和使用Nacos的注册和使用

5.2 微服务配置拉取

Nacos的注册和使用Nacos的注册和使用** 添加管理依赖 **

    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        <version>2.2.5.RELEASE</version>
    </dependency>
复制代码

Nacos的注册和使用** 新建一个bootstrap.yml配置文件 写入三要素**

spring:
  application:
    name: userservice
  profiles:
    active: dev # 环境
  cloud:
    nacos:
      server-addr: nacos:8848 # nacos地址
      config:
        file-extension: yaml # 文件后缀名
复制代码

** 在把之前application.yml配置文件中重复的内容给删掉**Nacos的注册和使用** 测试拉取配置**

// 获取配置文件的值
     @Value("${pattern.dateformat}")
     private String dateformat;
     
复制代码
// 获取时间格式化
    @GetMapping("now")
    public String now(){
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat	));
    }
    
复制代码

Nacos的注册和使用Nacos的注册和使用

Apipost 私有化火热进行中

评论