Nacos的注册和使用

1.服务注册导入Nacos依赖

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

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

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

复制代码

Nacos的注册和使用_第1张图片

1.1 修改配置文件

注册cloud

cloud:

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

复制代码

Nacos的注册和使用_第2张图片

到后台在配置文件中查看

Nacos的注册和使用_第3张图片

2.NacosRule负载均衡
2.1.配置集群属性

Nacos的注册和使用_第4张图片

Nacos的注册和使用_第5张图片

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

Nacos的注册和使用_第6张图片

Nacos的注册和使用_第7张图片

2.2 根据集群配置负载均衡

Nacos的注册和使用_第8张图片

NFLoadBalancerRuLeClassName 同个集群下有多个服务时会采用随机的方式来负载均衡。
添加以下配置文件
spring:
userservice: #要做配置的微服务名称

ribbon:
    NFLoadBalancerRuLeClassName: 配置负载均衡的规则

复制代码

Nacos的注册和使用_第9张图片

出现跨集群访问时,控制台会输出警告信息,提示运维人员。

Nacos的注册和使用_第10张图片

2.3 根据权重负载均衡

Nacos的注册和使用_第11张图片

Nacos的注册和使用_第12张图片

3.环境隔离

Nacos的注册和使用_第13张图片

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

3.1 新建空间

Nacos的注册和使用_第15张图片

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

Nacos的注册和使用_第16张图片

3.2 代码对接命名空间

Nacos的注册和使用_第17张图片

在配置文件中添加namespace:后面跟着命名空间的id

图片

4.和Eureka的区别

Nacos的注册和使用_第18张图片

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

Nacos的注册和使用_第19张图片

5.Nacos配置管理
5.1 创建配置文件实现热更新
新增配置

Nacos的注册和使用_第20张图片

配置文件昵称必须是要唯一的用于统一管理,

Nacos的注册和使用_第21张图片

配置内容是把有热更新需求的放进来,如固定格式的配置不需要更新的就不需要填写。

Nacos的注册和使用_第22张图片

Nacos的注册和使用_第23张图片

5.2 微服务配置拉取

Nacos的注册和使用_第24张图片

Nacos的注册和使用_第25张图片

添加管理依赖


    com.alibaba.cloud
    spring-cloud-starter-alibaba-nacos-config
    2.2.5.RELEASE

复制代码

Nacos的注册和使用_第26张图片

新建一个bootstrap.yml配置文件 写入三要素
spring:
application:

name: userservice

profiles:

active: dev # 环境

cloud:

nacos:
  server-addr: nacos:8848 # nacos地址
  config:
    file-extension: yaml # 文件后缀名

复制代码
在把之前application.yml配置文件中重复的内容给删掉

Nacos的注册和使用_第27张图片

测试拉取配置
// 获取配置文件的值

 @Value("${pattern.dateformat}")
 private String dateformat;
 

复制代码
// 获取时间格式化

@GetMapping("now")
public String now(){
    return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat    ));
}

复制代码

Nacos的注册和使用_第28张图片

Nacos的注册和使用_第29张图片

你可能感兴趣的:(nacos)