本文說明了如何定製化JHipster-Registry,增長消息總線功能。
實現的效果就是修改配置中心的文件後,經過消息隊列主動推送給微服務而無需重啓微服務,實現配置內容熱加載。前端
編號 | IP | 主機名 |
---|---|---|
B | 192.168.1.102 | node02 |
C | 192.168.1.103 | node03 |
D | 192.168.1.104 | node04 |
E | 192.168.1.105 | node05 |
組件名 | 說明 | 版本 |
---|---|---|
Jhipster Registry | 基於eureka和spring cloud config的基礎服務。 | v4.0.0 |
Spring Cloud Bus | 消息總線組件,經過maven依賴引入。 | 1.3.1 |
RabbitMQ | 消息中間件,已部署在預研環境中。 | 3 |
myClient | 一個客戶端服務,用於測試消息總線效果。 | 1.0 |
GitLab配置庫 | JHipster-Registry引用的配置中心。全部服務的配置文件所在地。 |
Github上下載jhipster-jhipster源碼。
https://github.com/jhipster/jhipster-registry/releases
java
保存到本地Gitlab源碼庫node
pom.xml
mysql
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bus-amqp</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
application.yml
git
management: security: enabled: false context-path: /management # 消息總線的url,這個前綴要加在 /bus/refresh 前面
application-prod.conf
github
spring: rabbitmq: host: rmqha_proxy port: 56729 username: guest password: guest publisher-confirms: true # 生產者消息確認 addresses: rmqha_proxy # 客戶端訪問server地址, 做爲發送者,配置和host一致
在安裝了jdk,maven, yarn,nodejs的centos7服務器上執行命令web
yarn && yarn install #前端資源配置生成 mvn -Pprod clean package dockerfile:build #項目構建並打包成docker鏡像,版本號爲3.0
docker service create --name base-registry --replicas 1 --network mycloud_base-overlay --constraint node.labels.mycloud.node.type==worker --constraint node.labels.mycloud.node.env==dev --env SPRING_PROFILES_ACTIVE=prod,git --env JHIPSTER_SECURITY_AUTHENTICATION_JWT_SECRET=gdd904a2dffb3eaf28a318b49e0ab986cc51012k --publish 8761:8761 dtr.devops.mycloud.com/common/jhipster-registry:3.0
可經過以下url訪問
http://<IP>:8761
spring
經過jhipster生成一個微服務,名爲my-client。sql
保存到gitLab庫git@gitlab.yourcompany.com:root-cloud/mycloud-monitor.gitdocker
pom.xml
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bus-amqp</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
application-prod.yml
eureka: instance: prefer-ip-address: true client: service-url: # 指向eureka服務器 defaultZone: http://admin:${jhipster.registry.password}@base-registry:8761/eureka/ spring: rabbitmq: host: rmqha_proxy port: 56729 username: guest password: guest publisher-confirms: true # 生產者消息確認 addresses: rmqha_proxy # 客戶端訪問server地址, 做爲發送者,配置和host一致
bootstrap-prod.yml
spring: cloud: config: fail-fast: true retry: initial-interval: 1000 max-interval: 2000 max-attempts: 100 uri: http://admin:${jhipster.registry.password}@base-registry:8761/config # 指向配置服務器 # name of the config server's property source (file.yml) that we want to use name: mq-client profile: rd # 注意這裏是rd分支,springcloud-config.git上的rd分支 label: master # toggle to switch to a different version of the configuration as stored in git jhipster: registry: password: admin
MyClientApp.java
@(JHipster)RefreshScope # 加上這個註解 public class MyClientApp { ...... }
application-prod.yml
application: domain: http://yourcompany.com/2017 # 增長一個配置項
ApplicationProperties
@ConfigurationProperties(prefix = "application", ignoreUnknownFields = false) public class ApplicationProperties { private String domain = "http://default"; public String getDomain() { return domain; } public void setDomain(String domain) { this.domain = domain; } }
TestResource.java
@RestController @RequestMapping("/management") public class TestResource { private final ApplicationProperties appProperties; @GetMapping("/mq/property") @Timed public ResponseEntity<String> getproperty() { return ResponseUtil.wrapOrNotFound(Optional.ofNullable(appProperties.getDomain())); } }
在安裝了jdk,maven, yarn,nodejs的centos7服務器上執行命令
$ mvn -Pprod clean package dockerfile:build #項目構建並打包成docker image
docker service create --name mq-client-mysql --replicas 1 --network name=mycloud_base-overlay,alias=mq-client-mysql --constraint node.labels.mycloud.node.type==worker --constraint node.labels.mycloud.node.env==data --env MYSQL_ROOT_PASSWORD=my-secret-pw --publish 32781:3306 dtr.devops.mycloud.com/common/mysql:5 docker service create --name my-client-app --replicas 1 --network mycloud_base-overlay --constraint node.labels.mycloud.node.type==worker --constraint node.labels.mycloud.node.env==dev --env SPRING_PROFILES_ACTIVE=prod,swagger --publish 18081:8081 dtr.devops.mycloud.com/yourcompany/my-client:1.0
可經過以下url訪問
http://<IP>:18081
http://<IP>:18081/management/mq/property
http://yourcompany.com/2017 # 返回值
application: domain: http://yourcompany.com/2018 # 把2017改爲了2018
http://<IP>:18081/management/mq/property
http://yourcompany.com/2017 # 返回值沒有改變
$ curl -X POST http://<IP>:8761/management/bus/refresh
http://<IP>:<port>/management/mq/property
http://yourcompany.com/2018 # 返回值已經更新爲2018