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,这三个是不同实例不同设置的,
这样,我们的同一个微服务就只有一套配置文件,部署多少是实例都不需要变动,只需要在启动实例时传入设置即可;