1、統(tǒng)一配置管理

1、在nacos中添加配置信息

2、在彈出表單中填寫配置信息

3、配置獲取的步驟如下

4、引入nacos的配置管理客戶端依賴
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
5、在order-server中的resource目錄添加一個(gè)bootstrap.yml文件,這個(gè)文件是引導(dǎo)文件,優(yōu)先級(jí)高于application.yml
spring:
application:
name: order-server
profiles:
active: dev
cloud:
nacos:
server-addr: localhost:8848
config:
file-extension: yaml
6、在order-service中將pattern.dateformat這個(gè)屬性注入到OrderController中做測(cè)試
@RestController
@RequestMapping("order")
public class OrderController {
@Autowired
IOrderService orderService;
@Value("${pattern.dateformat}")
private String format;
@GetMapping("now")
public String now(){
return LocalDateTime.now().format(DateTimeFormatter.ofPattern(format, Locale.CHINA));}
@PostMapping("list")
public R list(@RequestBody Map<String, Object> params) {
PageUtils page = orderService.pageList(params);
return R.ok().setData(page);
}
}
7、總結(jié)
將配置交給Nacos管理的步驟:
1、在Nacos中添加配置文件
2、在微服務(wù)中引入nacos的config依賴
3、在微服務(wù)中添加bootstrap.yml,配置nacos地址、當(dāng)前環(huán)境、服務(wù)名稱、文件 后綴名。這些決定了程序啟動(dòng)時(shí)去nacos讀取哪個(gè)文件
2、配置熱更新(自動(dòng)刷新)
Nacos中的配置文件變更后,微服務(wù)無需重啟就可以感知。不過需要通過下面兩種配置實(shí)現(xiàn):
方式一:在@Value注入的變量所在類上添加注解@RefreshScope
@RestController
@RequestMapping("order")
@RefreshScope
public class OrderController {
方式二:使用@ConfigurationProperties注解
@Data
@Component
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
private String dateformat;
}
@RestController
@RequestMapping("order")
public class OrderController {
@Autowired
IOrderService orderService;
@Autowired
PatternProperties properties;
@GetMapping("now")
public String now(){
return LocalDateTime.now().format(DateTimeFormatter.ofPattern(properties.getDateformat(), Locale.CHINA));}
}
總結(jié):
Nacos配置更改后,微服務(wù)可以實(shí)現(xiàn)熱更新,方式:
1、通過@Value注解注入,結(jié)合@RefreshScope來刷新
2、通過@ConfigurationProperties注入,然后在Controller中引入并使用即可實(shí)現(xiàn)自動(dòng)刷新。
注意事項(xiàng):
1、不是所有的配置都適合放到配置中心,維護(hù)起來比較麻煩
2、建議將一些關(guān)鍵參數(shù),需要運(yùn)行時(shí)調(diào)整的參數(shù)放到nacos配置中心,一般都是自定義配置
3、多環(huán)境配置共享
1、微服務(wù)啟動(dòng)時(shí)會(huì)從nacos讀取多個(gè)配置文件:
(1)[spring.application.name]-[spring.profiles.active].yaml,
例如:userservice-dev.yaml
(2)[spring.application.name].yaml,例如:userservice.yaml
無論profile如何變化,[spring.application.name].yaml這個(gè)文件一定會(huì)加載,因此多環(huán)境共享配置可以寫入這個(gè)文件

2、多種配置的優(yōu)先級(jí):

微服務(wù)會(huì)從nacos讀取的配置文件:
[服務(wù)名]-[spring.profile.active].yaml,環(huán)境配置
[服務(wù)名].yaml,默認(rèn)配置,多環(huán)境共享
優(yōu)先級(jí):
[服務(wù)名]-[環(huán)境].yaml >[服務(wù)名].yaml > 本地配置
3、多服務(wù)共享配置
不同微服務(wù)之間可以共享配置文件,通過下面的兩種方式來指定:
方式一:
spring:
application:
name: order-server
profiles:
active: dev
cloud:
nacos:
server-addr: localhost:8848
config:
file-extension: yaml
extension-configs: #多微服務(wù)間共享的配置列表
- dataId: extend.yaml #要共享的配置文件id
方式二
spring:
application:
name: order-server
profiles:
active: dev
cloud:
nacos:
server-addr: localhost:8848
config:
file-extension: yaml
shared-configs: #多微服務(wù)間共享的配置列表
- dataId: extend.yaml #要共享的配置文件id
4、多種配置的優(yōu)先級(jí)

微服務(wù)默認(rèn)讀取的配置文件:
[服務(wù)名]-[spring.profile.active].yaml,默認(rèn)配置
[服務(wù)名].yaml,多環(huán)境共享
不同微服務(wù)共享的配置文件:
通過shared-configs指定
通過extension-configs指定
優(yōu)先級(jí):
環(huán)境配置 >服務(wù)名.yaml > extension-config > extension-configs > shared-configs > 本地配置