赞
踩
本次讲解使用spring boot整合nacos,实现注册中心和配置中心。这次是一个入门级别的demo,会建立一个父项目,在父项目中指定依赖的版本。建立两个子模块,用于充当生产者(producer)和消费者(consumer)。(生产者可以通过openfeign进行远程调用消费者,这里我们不做过多的讲解)
版本对照很重要,不同的spring boot版本与nacos之间有可能是不兼容的,可以在官网上找到它们之间的对照关系。
本次我们使用spring boot3,jdk17,spring cloud Alibaba2022.0.0.0-RC2 nacos版本v2.2.2
注意一点:有两个nacos版本要修改一下配置文件,不然无法启动:
环境准备:
1、下载nacos:我使用的是docker下载,下载之后创建容器即可使用:
# 拉取镜像
docker pull nacos/nacos-server:v2.2.2# 创建容器
docker run --name nacos -e MODE=standalone -p 8848:8848 -p 9848:9848 -d nacos/nacos-server:v2.2.2# nacos2.x的版本新增了一个客户端与服务端的gRpc的通讯端口号9848
2、进入到nacos的控制台:
http://ip地址:8848/nacos
进入nacos的控制台,如图所示:
3、新建一个父项目nacosTest,并管理对应的依赖版本。
<dependencyManagement> <dependencies> <!-- springcloud--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>2022.0.0</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2022.0.0.0-RC1</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
4、在父项目下建立两个子模块,生产者(producer)和消费者(consumer),将来我们要将这两个子模块都注册到nacos中。
在两个子模块中都引入nacos注册中心的依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- macos注册中心--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>
在配置文件中配置nacos的连接信息:
consumer:
server: port: 8888 spring: application: name: consumer #微服务的名称 cloud: nacos: discovery: server-addr: 192.168.231.110:8848
producer:
server: port: 9999 spring: application: name: producer #微服务的名称 cloud: nacos: discovery: server-addr: 192.168.231.110:8848
启动两个微服务,可以在nacos的控制台中查看两个微服务有没有注册到nacos中:
可以看到,在nacos的控制台中引入了两个服务器。
引入nacos配置中心的依赖:
<!--nacos配置中心--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency>
注意引入了nacos的配置中心,一定要表明引入的配置文件,不然会报错:
server: port: 8888 spring: application: name: consumer cloud: nacos: discovery: server-addr: 192.168.231.110:8848 config: server-addr: 192.168.231.110:8848 #配置中心地址 config: import: - nacos:test.yml #配置文件名称
在控制台中创建相应的配置文件,注意名称要保持一致。
在配置文件中写点东西进行测试,看我们的项目能不能读取到这些自定义配置:
在项目中,写一个配置类进行接收,并在测试类中进行打印,看能否输出我们在nacos中写的配置:
@ConfigurationProperties("student") @Component @Data public class StudentProperties { private String name; private String age; }
在测试文件中进行输出。如下所示:
运行结果:
这表明我们是可以读取到nacos中的配置文件的,并且是动态的读取。如果你的项目已经上线,那么你在nacos中修改配置文件中的属性,相应的我们项目中的配置文件也会改变;
(注意这是使用@ConfigurationProperties直接进行映射才有的效果,如果你是使用@Value()进行的读取,那么是不会进行热更新的需要重启项目才行,如果想要进行热更新,可以在使用@Value注解的类上加入@RefreshScope注解(实现热更新)才行)
注意:
在较早的版本之前,有可能还使用bootstarp作为spring boot的引导程序。但是在spring boot2.5版本之后,官方就取消了对spring-cloud-starter-bootstrap 默认依赖的支持。但是如果还想使用的话,可以自行引入spring-cloud-starter-bootstrap< 的依赖坐标还能正常使用。
在这里简单介绍一下bootstrap.yml和application.yml的区别与联系:
application.yml是用户级的资源配置项
bootstrap.yml是系统级的,优先级更高
Spring Cloud会创建一个“Bootsrap Context”,作为Spring应用的“Application Context”的父上下文。初始化项目的时候,“Bootsrap Context”负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的“Environment”
Bootsrap 属性有高优先级,默认情况下,它们不会被本地配置覆盖。“Bootsrap Context”和“Application Context”有着不同的约定,所以新增了一个‘bootstrap.yml’文件,保证“Bootsrap Context” 和“Application Context”配置的分离。
你可以直接将application.yml文件直接改为bootstrap.yml文件,然后在bootstrap.yml文件中指定外部源的用户级资源配置项 ;或者两个并存,这都是可以的
当两者并存时:两者的加载顺序是有规定的,bootstrap.yml
优先于application.yml
加载,确保了应用程序在启动时先加载一些必要的配置信息。
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bootstrap</artifactId> </dependency>
引入依赖之后,在资源目录下再加上bootstrap.yml的引导文件,并在bootstrap.yml引导文件中加入nacos的配置信息,
使用bootstrap.yml拉取nacos的配置文件,启动流程如下:
springcloud 启动流程(只有关nacos配置)
启动--->加载bootstrap.yml-->拉取nacos中的配置文件--->初始化ApplicationContext--->加载application.yml文件--->合并配置(这里加载了三个依赖,bootstrap.yml,nacos配置文件,application.yml文件;这里如果有相同的配置属性,那么后加载的会覆盖先加载的)--->初始化ApplicationContext
在spring boot2.5之后,取消了bootstrap的配置,要使用需加入依赖spring-cloud-starter-bootstrap。
bootstrap.yml形式的配置:
spring: cloud: nacos: config: server-addr: 192.168.231.110:8848 file-extension: yml shared-dataids: test.yml
这里只是进行了非常简单的入门,让你能够使用nacos作为注册中心和配置中心,如果还想了解nacos更多详细的配置的话,可以查看nacos的官网
这是国人写的框架,所以文档还是比较能看懂的。
以上所示,就是nacos的入门了。
下一篇,我应该会写使用Openfeign来调用nacos中的服务。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。