spring cloud 微服务之 -- 配置文件拆分之道
程序员文章站
2022-06-22 10:49:56
0-前言 在spring cloud微服务架构中,基本上每个拆分的微服务都会部署多个运行实例,这些运行实例,配置基本都是一样的,不同的是少数配置,比如端口,而这些不同的配置又是必不可少的 那我们怎么来部署同一个微服务的多个不同实例呢, 总不能改改配置文件 --编译--发布一个一个来吧,几十几百个实例 ......
0-前言
在spring cloud微服务架构中,基本上每个拆分的微服务都会部署多个运行实例,这些运行实例,配置基本都是一样的,不同的是少数配置,比如端口,而这些不同的配置又是必不可少的
那我们怎么来部署同一个微服务的多个不同实例呢,
总不能改改配置文件 --编译--发布一个一个来吧,几十几百个实例那得累死头牛
也不能一个实例一个配置文件吧,那配置文件也堆成山,改一个改到累死头牛
还有些人把配置文件从jar包剥离,有改动时那也一个个改,还是累死头牛;
1-如何拆分
我们基本上都用spring cloud config server 来管理配置文件,那怎么来拆分呢,正确的做法应该是:
1、抽离共同的配置项放到spring cloud config server管理的配置文件application.yml中,
2、少数每个实例不同的配置项放在项目的bootstrap.yml中,比如:端口号、机器编号等
3、bootstrap.yml中不同的配置项作为启动参数传入:
java -jar -xms256m -xmx512m -dserver.port=8099 -dserver.workid=1 -dserver.datacenterid=1 anson.jar
上面的实例启动时,设置了不同的端口、datacenterid、workid,这三个是不同实例不同设置的,
这样,我们的同一个微服务就只有一套配置文件,部署多少是实例都不需要变动,只需要在启动实例时传入设置即可;