总结之SpringCloud之配置中心——config

拼搏现实的明天。 2023-07-24 05:42 83阅读 0赞

config简介

  • Spring Cloud Config 支持服务端与客户端
  • 是一个分布式配置中心
  • 提供配置信息多环境切换
  • 配置信息更新,实时同步

实现步骤

  • GitHub创建存放配置信息的config-repository目录与配置信息config-client-dev.properties、config-another-client-test.properties,可通过demo中的config-repository模块关联GitHub上的配置。
  • 实现config-server:关键是启动Spring Cloud Config Server功能,指定配置仓库的配置信息
  • 实现config-client:从配置仓库读取配置信息
  • 实现config-repository:放置配置信息

config-server

config-server实现步骤

pom.xml引入spring-cloud-config-server
application.yml指定配置仓库连接信息
启动类使用注解启动类使用注解@EnableConfigServer开启配置服务功能

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-config-server</artifactId>
  4. </dependency>
  5. spring:
  6. application:
  7. name: config-server
  8. cloud:
  9. config:
  10. server:
  11. git:
  12. uri: https://github.com/000000/config
  13. searchPaths: config-repository
  14. username:000000
  15. password:000000
  16. label: dev-20180827

启动项

  1. mport org.springframework.boot.SpringApplication;
  2. import org.springframework.boot.autoconfigure.SpringBootApplication;
  3. import org.springframework.cloud.config.server.EnableConfigServer;
  4. @EnableConfigServer
  5. @SpringBootApplication
  6. public class ConfigServerApplication {
  7. public static void main(String[] args) {
  8. SpringApplication.run(ConfigServerApplication.class, args);
  9. }
  10. }

config-client

实现步骤

  • pom.xml文件中引入依赖spring-cloud-starter-config
  • bootstrap.yml中指定Config Server连接信息以及需要访问配置中心的具体配置信息
  • ConfigClientApplication常规Spring Boot启动类
  • spring:
    application:

    1. name: config-client

    cloud:

    1. config:
    2. label: dev-20180827
    3. profile: dev
    4. uri: http://localhost:8769/

    server:
    port: 8771

config-repository

保存的配置文件,把它上传到github中
如下:

  1. #\u670d\u52a1\u540d
  2. cloud.application.name=spring-cloud-op-data-service
  3. #\u670d\u52a1\u7aef\u53e3
  4. spring.server.port=8884
  5. #\u6570\u636e\u5e93\u914d\u7f6e
  6. spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
  7. spring.datasource.driver-class-name=com.mysql.jdbc.Driver
  8. spring.datasource.url=jdbc:mysql://127.0.0.1:3306/paascloud_uac?characterEncoding=UTF-8&autoReconnect=true&useUnicode=true&useSSL=false
  9. spring.datasource.username=root
  10. spring.datasource.password=123456
  11. #spring.datasource.publickey=MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAKhMXHchtHKmZGRlf1e5290MJ8DFDkQ/D+sgdxX5JNe4njexg07TZivfsOKl1leFEoPH5KVnfKDmA3sljNIrE6MCAwEAAQ==
  12. spring.datasource.initialSize=5
  13. spring.datasource.minIdle=5
  14. spring.datasource.maxActive=20
  15. spring.datasource.maxWait=60000
  16. spring.datasource.timeBetweenEvictionRunsMillis=60000
  17. spring.datasource.minEvictableIdleTimeMillis=300000
  18. spring.datasource.validationQuery=SELECT 1 FROM DUAL
  19. spring.datasource.testWhileIdle=true
  20. spring.datasource.testOnBorrow=false
  21. spring.datasource.testOnReturn=false
  22. spring.datasource.poolPreparedStatements=true
  23. spring.datasource.maxOpenPreparedStatements=20
  24. spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
  25. #spring.datasource.filters=stat,wall,log4j,config
  26. #spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000;config.decrypt=true;config.decrypt.key=${spring.datasource.publickey}
  27. spring.enable.swagger=true
  28. #sop
  29. spring.swagger.host = 10.237.55.148
  30. #Hystrix timeout config
  31. hystrix.command.default.execution.timeout.enabled=true
  32. #\u4e3a\u4e86\u6d4b\u8bd5Hystrix\u7684fallback\u6548\u679c\uff0c\u6b64\u5904\u5c06\u8d85\u65f6\u65f6\u95f4\u8bbe\u7f6e\u62101\u6beb\u79d2
  33. hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=100000
  34. ##\u5e76\u53d1\u6267\u884c\u7684\u6700\u5927\u7ebf\u7a0b\u6570\uff0c\u9ed8\u8ba410
  35. hystrix.threadpool.default.coreSize=coreSize
  36. ##BlockingQueue\u7684\u6700\u5927\u961f\u5217\u6570
  37. hystrix.threadpool.default.maxQueueSize=1000
  38. ##\u5373\u4f7fmaxQueueSize\u6ca1\u6709\u8fbe\u5230\uff0c\u8fbe\u5230queueSizeRejectionThreshold\u8be5\u503c\u540e\uff0c\u8bf7\u6c42\u4e5f\u4f1a\u88ab\u62d2\u7edd
  39. hystrix.threadpool.default.queueSizeRejectionThreshold=500
  40. hystrix.command.default.circuitBreaker.requestVolumeThreshold=400
  41. lock.mysql.expireTime=7200000
  42. #redis cluster
  43. spring.redis.hostName=10.237.55.188
  44. spring.redis.port=6379
  45. spring.redis.password=
  46. spring.redis.pool.maxActive=8
  47. #spring.redis.pool.maxWait=-1
  48. spring.redis.pool.maxIdle=8
  49. spring.redis.pool.minIdle=0
  50. #spring.redis.timeout=0
  51. #spring.redis.pool.maxTotal=200
  52. #spring.redis.pool.maxActive=300
  53. spring.redis.pool.maxWaitMillis=10000
  54. redis.sale.saleDatabase=1
  55. redis.normal.normalDatabase=0

服务端通过@Value可以去查看远程配置文件信息

  1. @Value("${xxxx}")
  2. private String xxxx;

如何读取远程配置的

启动之后可以根据指定规则访问远程配置完整信息,/{name}/{profile}/{label}
name:spring.application.name
profile:spring.application.profile,即 application-{profile}.yml中的profile值,如application-dev.yml文件的profile是dev。
label:application.yml配置文件中spring.cloud.config.label的值,这里是dev
查看config-client的bootstrap.properties信息可知,其对应的远程配置文件为https://github.com/000000/config-repository/config-client-dev.properties

发表评论

表情:
评论列表 (有 0 条评论,83人围观)

还没有评论,来说两句吧...

相关阅读