nacos官方手册https://nacos.io/zh-cn/docs/what-is-nacos.html
本文使用springboot2.1.9.RELEASE,nacos1.3.2 ,JDK 1.8+ ,mysql5.6.5+ 本文采用Windows部署环境
你可以通过源码和发行包两种方式来获取 Nacos。
1、从 Github 上下载源码方式 2、下载编译后压缩包方式
本文方便起见采用下载zip包形式解压即可用。 地址: 最新稳定版本 下载 nacos-server-$version.zip
包。
解压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使用namespace进行环境隔离,可以指定不同的环境,更好的管理开发、测试、生产的配置文件管理
资源配置
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}
。
spring.cloud.nacos.config.file-extension
来配置。目前只支持 properties 和 yaml 类型。 默认为DEFAULT_GROUP,可以对不同类型的微服务配置文件进行分组管理。配置文件通过spring.cloud.nacos.config.group=AAA
来指定。
配置内容
配置文件格式支持一下几种TEXT、JSON、XML、YAML、HTML、Properties
历史版本
资源文件每次修改都会记录一个历史版本,历史记录默认保存时间为30天,可以根据历史记录看到每次更新的内容。还可以让指定的记录文件回滚至上一个版本。
监听查询
可以监听每个具体资源文件由哪些ip进行访问
2.集群部署:
修改配置文件cluster.conf.example 重命名为cluster.conf 并修改内容
注意:Windows部署需要填写ip 。
启动即可。
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
注: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属性值,这个在配置时多留意尽量岔开不重复配置。
@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添加到启动类头 不用给每个使用配置属性的类都加