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数据库存储数据方式。

springboot2.X集成nacos实现注册中心和配置中心_第1张图片

复制执行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代表着单机模式运行,非集群模式

springboot2.X集成nacos实现注册中心和配置中心_第2张图片

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

springboot2.X集成nacos实现注册中心和配置中心_第3张图片

Nacos配置

命名空间 

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

springboot2.X集成nacos实现注册中心和配置中心_第4张图片

资源配置 

springboot2.X集成nacos实现注册中心和配置中心_第5张图片

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天,可以根据历史记录看到每次更新的内容。还可以让指定的记录文件回滚至上一个版本。

springboot2.X集成nacos实现注册中心和配置中心_第6张图片

 监听查询

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

springboot2.X集成nacos实现注册中心和配置中心_第7张图片

2.集群部署:

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

springboot2.X集成nacos实现注册中心和配置中心_第8张图片

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

  启动即可。

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

  • pom文件添加依赖
  
    2.1.0.RELEASE
    2.1.9.RELEASE
  
  
  

      
        org.springframework.boot
        spring-boot-dependencies
        ${spring-boot.version}
        pom
        import
      
    
    
      com.alibaba.cloud
      spring-cloud-alibaba-dependencies
      ${spring.cloud.alibaba.version}
      pom
      import
    
  
  


    
    
      com.alibaba.cloud
      spring-cloud-starter-alibaba-nacos-config
    
    
    
      com.alibaba.cloud
      spring-cloud-starter-alibaba-nacos-discovery
    
    
    
      org.springframework.boot
      spring-boot-starter-web
    
    
    org.springframework.boot
    spring-boot-starter-actuator
    
  
  • 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添加到启动类头  不用给每个使用配置属性的类都加

你可能感兴趣的:(nacos)