springboot2.X集成nacos实现注册中心和配置中心

nacos官方手册https://nacos.io/zh-cn/docs/what-is-nacos.html

1.预备环境准备

本文使用springboot2.1.9.RELEASE,nacos1.3.2 ,JDK 1.8+ ,mysql5.6.5+    本文采用Windows部署环境

2.下载源码或者安装包

你可以通过源码和发行包两种方式来获取 Nacos。

1、从 Github 上下载源码方式  2、下载编译后压缩包方式

本文方便起见采用下载zip包形式解压即可用。 地址: 最新稳定版本 下载 nacos-server-$version.zip 包。

3.启动服务器

Nacos支持三种部署模式

  • 单机模式 - 用于测试和单机试用。
  • 集群模式 - 用于生产环境,确保高可用。
  • 多集群模式 - 用于多数据中心场景。
  1. 单机部署:

解压nacos-server-1.3.2.zip包 ,进入nacos\conf下,我们可以看到有mysql初始化脚本,关于nacos数据存储方式选择可以参考https://blog.csdn.net/thinkingcao/article/details/105444718,由于本文采用单机部署,为了数据查看方便,使用mysql数据库存储数据方式。

复制执行nacos-mysql.sql脚本创建初始化数据库。修改application.properties配置文件配置数据库连接信息


#*************** Config Module Related Configurations ***************#
### If use MySQL as datasource:
spring.datasource.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://localhost:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user=root
db.password=root

 nacos默认是集群启动的,可以修改startup.cmd配置文件为单机启动模式:standalone代表着单机模式运行,非集群模式

 双击startup.cmd启动nacos服务端。访问http://localhost:8848/nacos/index.html ,登陆默认账号 : nacos,密码:nacos

Nacos配置

命名空间 

nacos使用namespace进行环境隔离,可以指定不同的环境,更好的管理开发、测试、生产的配置文件管理

资源配置 

Data ID

Data ID的格式如下:

参考:https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

${prefix}-${spring.profile.active}.${file-extension}

  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。

  • spring.profile.active 即为当前环境对应的 profile。 注意:当 spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}

  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension来配置。目前只支持 properties 和 yaml 类型。

    Group

    默认为DEFAULT_GROUP,可以对不同类型的微服务配置文件进行分组管理。配置文件通过spring.cloud.nacos.config.group=AAA来指定。

 配置内容

配置文件格式支持一下几种TEXT、JSON、XML、YAML、HTML、Properties

历史版本

资源文件每次修改都会记录一个历史版本,历史记录默认保存时间为30天,可以根据历史记录看到每次更新的内容。还可以让指定的记录文件回滚至上一个版本。

 监听查询

可以监听每个具体资源文件由哪些ip进行访问

2.集群部署:

修改配置文件cluster.conf.example 重命名为cluster.conf  并修改内容

 注意:Windows部署需要填写ip 。  

  启动即可。

 4、springboot整合nacos作为注册中心和配置中心

  • pom文件添加依赖
  <properties>
    <spring.cloud.alibaba.version>2.1.0.RELEASE</spring.cloud.alibaba.version>
    <spring-boot.version>2.1.9.RELEASE</spring-boot.version>
  </properties>
  <dependencyManagement>
  <dependencies>

      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>${spring-boot.version}</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    <!--Spring cloud alibaba 2.1.0.RELEASE-->
    <dependency>
      <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-alibaba-dependencies</artifactId>
      <version>${spring.cloud.alibaba.version}</version>
      <type>pom</type>
      <scope>import</scope>
    </dependency>
  </dependencies>
  </dependencyManagement>

<dependencies>
    <!--nacos-config-->
    <dependency>
      <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
    <!--nacos-discovery-->
    <dependency>
      <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!--web + actuator-->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
  </dependencies>
  • resources目录下新建bootstrp.properties文件 

注:bootstrap由父Spring ApplicationContext加载。父ApplicationContext被加载到使用application的之前。当使用 Spring Cloud 的时候,配置信息一般是从 config server 加载的,为了取得配置信息(比如密码等),你需要一些提早的或引导配置。因此,把 config server 信息放在 bootstrap,用来加载真正需要的配置信息。

# nacos配置
spring:
  application:
    #之所以需要配置 spring.application.name ,是因为它是构成 Nacos 配置管理 dataId字段的一部分。spring.application.name也可以不用配置在bootstrap.yml中 ,配置在application.yml中也可以
    name: nacos-config
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848 #Nacos服务注册中心地址
        namespace: e5b58bd9-88b8-4acd-a81f-55c0e53426b4  # 不指定namespace时默认public命名空间
      config:
        server-addr: 127.0.0.1:8848 #Nacos作为配置中心地址
        file-extension: yaml #指定yaml格式的配置
        group: DEFAULT_GROUP
        namespace: e5b58bd9-88b8-4acd-a81f-55c0e53426b4 # 不指定namespace时默认public命名空间

# 在Nacos中配置文件的命名规则
# ${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
# nacos-config-client-dev.yaml 该文件名为在Nacos新增配置文件的文件名

 *在使用时发现application.yml和bootstrap.yml存在属性覆盖问题,即相同属性在俩配置文件都配置时  application配置会覆盖掉bootstrap属性值,这个在配置时多留意尽量岔开不重复配置。

  • 启动类添加注解信息 @EnableDiscoveryClient
@SpringBootApplication
@EnableDiscoveryClient
public class Application {
    public static void main(String [] args){
        SpringApplication.run(Application.class, args);
    }
}

 要实现配置文件实时生效需要加注解:@RefreshScope

@RequestMapping("/testNacosControlle")
@RestController
@RefreshScope
public class TestNacosControlle {

}

也可将@RefreshScope添加到启动类头  不用给每个使用配置属性的类都加

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Spring Boot 2.x中整合Nacos配置服务,可以通过Nacos提供的Spring Cloud Config支持类来实现配置获取和刷新。 首先,在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> ``` 然后,在application.properties(或application.yml)文件中配置Nacos的服务器地址、命名空间、应用名、配置信息等: ```properties spring.cloud.nacos.config.server-addr=127.0.0.1:8848 spring.cloud.nacos.config.namespace=xxx spring.cloud.nacos.config.group=xxx spring.cloud.nacos.config.prefix=xxx spring.cloud.nacos.config.file-extension=properties ``` 其中,server-addr是Nacos服务器的地址,namespace是命名空间,group是配置分组,prefix是配置前缀,file-extension是配置文件的扩展名。 然后,可以通过@Value注解来获取配置信息: ```java @Value("${xxx}") private String xxx; ``` 如果需要动态刷新配置,可以添加@RefreshScope注解,并在配置类中添加@NacosConfigListener注解监听配置变化: ```java @Configuration @RefreshScope public class Config { @Value("${xxx}") private String xxx; @NacosConfigListener(dataId = "xxx", groupId = "xxx", timeout = 5000) public void onMessage(String config) { // 重新加载配置 xxx = config; } } ``` 其中,dataId是配置信息的ID,groupId是配置分组的ID,timeout是超时时间。 这样,当Nacos配置信息发生变化时,就会触发onMessage方法重新加载配置信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值