0


springboot3整合nacos实现注册中心和配置中心(详细入门)

   本次讲解使用spring boot整合nacos,实现注册中心和配置中心。这次是一个入门级别的demo,会建立一个父项目,在父项目中指定依赖的版本。建立两个子模块,用于充当生产者(producer)和消费者(consumer)。(生产者可以通过openfeign进行远程调用消费者,这里我们不做过多的讲解)

版本对照很重要,不同的spring boot版本与nacos之间有可能是不兼容的,可以在官网上找到它们之间的对照关系。

版本发布说明 | Spring Cloud Alibaba

本次我们使用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配置中心的依赖:

<!--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< 的依赖坐标还能正常使用。

<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的官网

https://nacos.io/

这是国人写的框架,所以文档还是比较能看懂的。

以上所示,就是nacos的入门了。

下一篇,我应该会写使用Openfeign来调用nacos中的服务。


本文转载自: https://blog.csdn.net/2301_78646673/article/details/134008051
版权归原作者 张乔24 所有, 如有侵权,请联系我们删除。

“springboot3整合nacos实现注册中心和配置中心(详细入门)”的评论:

还没有评论