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支持三种部署模式
- 单机模式 - 用于测试和单机试用。
- 集群模式 - 用于生产环境,确保高可用。
- 多集群模式 - 用于多数据中心场景。
- 单机部署:
解压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添加到启动类头 不用给每个使用配置属性的类都加