文档地址
https://github.com/alibaba/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/nacos-example/nacos-config-example/readme-zh.md
1、 下载nacos-server
https://github.com/alibaba/nacos/releases
2、启动nacos-server 默认使用nacos nacos 登录
Linux/Unix/Mac
启动命令(standalone代表着单机模式运行,非集群模式):
sh startup.sh -m standalone
如果您使用的是ubuntu系统,或者运行脚本报错提示[[符号找不到,可尝试如下运行:
bash startup.sh -m standalone
Windows
启动命令:
cmd startup.cmd
或者双击startup.cmd运行文件。
3、将微服务注册到nacos
1)、首先修改pom.xml文件,引入nacos Discovery Starter
<!-- 配置中心来做配置管理-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2)、 在应用的 /src/main/resources/bootstrap.properties 配置文件中配置 Nacos Config 元数据
spring.application.name=nacos-config-example
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
3)、 完成上述两步后,应用会从 Nacos Config 中获取相应的配置,并添加在 Spring Environment 的 PropertySources 中。这里我们使用 @Value 注解来将对应的配置注入到 SampleController 的 userName 和 age 字段,并添加 @RefreshScope 打开动态刷新功能
在nacos 配置中心新址应用名字命名的propertise
java取值
@RefreshScope
@RequestMapping("coupon/coupon")
public class CouponController {
@Autowired
private CouponService couponService;
@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;
@RequestMapping("/test")
public R test(){
return R.ok().put("name",name).put("age",age);
}
总结:
/**
- 1、如何使用Nacos作为配置中心统一管理配置
- 1)、引入依赖,
-
<dependency>
-
<groupId>com.alibaba.cloud</groupId>
-
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
-
</dependency>
- 2)、创建一个bootstrap.properties。
-
spring.application.name=gulimall-coupon
-
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
- 3)、需要给配置中心默认添加一个叫 数据集(Data Id)gulimall-coupon.properties。默认规则,应用名.properties
- 4)、给 应用名.properties 添加任何配置
- 5)、动态获取配置。
-
@RefreshScope:动态获取并刷新配置
-
@Value("${配置项的名}"):获取到配置。
-
如果配置中心和当前应用的配置文件中都配置了相同的项,优先使用配置中心的配置。
- 2、细节
- 1)、命名空间:配置隔离;
-
默认:public(保留空间);默认新增的所有配置都在public空间。
-
1、开发,测试,生产:利用命名空间来做环境隔离。
-
注意:在bootstrap.properties;配置上,需要使用哪个命名空间下的配置,
-
spring.cloud.nacos.config.namespace=9de62e44-cd2a-4a82-bf5c-95878bd5e871
-
2、每一个微服务之间互相隔离配置,每一个微服务都创建自己的命名空间,只加载自己命名空间下的所有配置
- 2)、配置集:所有的配置的集合
- 3)、配置集ID:类似文件名。
-
Data ID:类似文件名
- 4)、配置分组:
-
默认所有的配置集都属于:DEFAULT_GROUP;
-
1111,618,1212
- 项目中的使用:每个微服务创建自己的命名空间,使用配置分组区分环境,dev,test,prod
- 3、同时加载多个配置集
- 1)、微服务任何配置信息,任何配置文件都可以放在配置中心中
- 2)、只需要在bootstrap.properties说明加载配置中心中哪些配置文件即可
- 3)、@Value,@ConfigurationProperties。。。
- 以前SpringBoot任何方法从配置文件中获取值,都能使用。
- 配置中心有的优先使用配置中心中的,
*/
@EnableDiscoveryClient
@SpringBootApplication
public class GulimallCouponApplication {
public static void main(String[] args) {
SpringApplication.run(GulimallCouponApplication.class, args);
}
}