微信公众号:bugstack虫洞栈 沉淀、分享、成长,专注于原创专题案例,以最易学习编程的方式分享知识,让自己和他人都能有所收获。目前已完成的专题有;Netty4.x实战专题案例、用Java实现JVM、基于JavaAgent的全链路监控、手写RPC框架、架构设计专题案例[Ing]等。
在实际开发中经常会有一个叫做配置中心的服务,这个服务经过变更参数来动态刷新线上业务数据行为配置。比如;行为开关、活动数据、黑白名单、本地/预发/线上环境切换等等,这些配置信息往往需要在我们不重启系统的时候就可以被更新执行。那么我们一般会使用具备此类属性在分布式系统中适合的组件进行开发配置中心,像是zookeeper、redis发布订阅、或者http定时轮许拉取,他们都可以做成统一配置中心服务。而在Spring Cloud Config 中,默认采用 Git 来存储配置信息,所以使用 Spring Cloud Config 构建的配置服务器,天然就支持对微服务应用配置信息的版本管理,在加上Github的Webhook钩子服务,可以在我们push等行为操作的时候,自动执行我们的http行为,以达到自动刷新配置服务。
通过在个人Git创建配置服务工程,开启Webhooks服务添加回调钩子http://xxx:port/actuator/refresh在更新配置后自动刷新服务配置内容,如图;
itstack-demo-springcloud-06 ├── itstack-demo-springcloud-config-client │ └── src │ └── main │ ├── java │ │ └── org.itstack.demo │ │ ├── web │ │ │ └── ConfigClientController.java │ │ └── ConfigClientApplication.java │ └── resources │ ├── application.yml │ └── bootstrap.yml └── itstack-demo-springcloud-config-server └── src └── main ├── java │ └── org.itstack.demo │ └── ConfigServerApplication.java └── resources └── application.yml 复制代码
web/ConfigClientController.java & 添加注解@RefreshScope自动刷新配置
/** * 微信公众号:bugstack虫洞栈 | 沉淀、分享、成长,专注于原创专题案例 * 论坛:http://bugstack.cn * Create by 付政委 on @2019 */ @RestController @RefreshScope public class ConfigClientController { @Value("${info.profile:error}") private String profile; @GetMapping("/config") public Mono<String> config() { return Mono.justOrEmpty(profile); } } 复制代码
ConfigClientApplication.java & 普通配置即可
/** * 微信公众号:bugstack虫洞栈 | 沉淀、分享、成长,专注于原创专题案例 * 论坛:http://bugstack.cn * Create by 付政委 on @2019 */ @SpringBootApplication public class ConfigClientApplication { public static void main(String[] args) { SpringApplication.run(ConfigClientApplication.class, args); } } 复制代码
application.yml & 需要配置endpoints,这样才可以暴漏刷新服务
spring: application: name: itstack-demo-springcloud-config-client server: port: 9001 # /actuator/refresh 这个 Endpoint 暴露出来 management: endpoints: web: exposure: include: refresh 复制代码
bootstrap.yml & 配置中心服务配置, http://localhost:7397
spring: cloud: config: uri: http://localhost:7397 # 配置中心的具体地址;itstack-demo-springcloud-config-server name: config-client # 对应 {application} 部分,例如;config-client-dev = 只取最后一个符号'-'之前的 profile: dev # 对应 {profile} 部分 label: master # 对应 {label} 部分,即 Git 的分支。如果配置中心使用的是本地存储,则该参数无用 #配置文件会被转换成 Web,访问规则如下; #/{application}/{profile}[/{label}] #/{application}-{profile}.yml #/{label}/{application}-{profile}.yml #/{application}-{profile}.properties #/{label}/{application}-{profile}.properties 复制代码
ConfigServerApplication.java & 添加注解@EnableConfigServer设置成配置服务中心
/** * 微信公众号:bugstack虫洞栈 | 沉淀、分享、成长,专注于原创专题案例 * 论坛:http://bugstack.cn * Create by 付政委 on @2019 */ @SpringBootApplication @EnableConfigServer public class ConfigServerApplication { public static void main(String[] args) { SpringApplication.run(ConfigServerApplication.class, args); } } 复制代码
application.yml &
server: port: 7397 spring: application: name: itstack-demo-springcloud-config cloud: config: server: git: uri: https://github.com/fuzhengwei/itstack-demo-config # 换成自己的配置Git仓库的地址,如果没有可以新建工程地址,也可以克隆我的 search-paths: config-repo # Git仓库地址下的底层配置文件名称,如果配置多个用逗号','分割。 # 如果配置中心需要访问权限,则开启配置 # spring.cloud.config.server.git.username:Github账户 # spring.cloud.config.server.git.password:Github密码 复制代码
准备好自己Github的配置仓库,也可以克隆我的Git; github.com/fuzhengwei/… {有一组配置配置文件}
配置Webhooks,在https://github.com/换你自己的fuzhengwei/换你自己的itstack-demo-netty/settings/hooks/new
分别启动服务
访问配置服务,端口7397; http://localhost:7397/config-client/dev
{ "name": "config-client", "profiles": [ "dev" ], "label": null, "version": "ea0b1a1017595d542aa01b8b2bda68f9620dd81a", "state": null, "propertySources": [ { "name": "https://github.com/fuzhengwei/itstack-demo-config/config-repo/config-client-dev.yml", "source": { "info.profile": "dev bus" } } ] } 复制代码
info: profile: dev bus 复制代码
访问使用配置的客户端,端口9001; http://localhost:9001/config {可以提交配置代码反复刷新测试}
dev bus 复制代码