JHipster技术栈定制 - JHipster Registry消息总线配置
本文说明了如何定制化JHipster-Registry,增加消息总线功能。
实现的效果就是修改配置中心的文件后,通过消息队列主动推送给微服务而无需重启微服务,实现配置内容热加载。
1 整体规划
1.1 拓扑架构
1.2 基础设置
编号 | 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 |
1.3 相关组件
组件名 | 说明 | 版本 |
---|---|---|
Jhipster Registry | 基于eureka和spring cloud config的基础服务。 | v4.0.0 |
Spring Cloud Bus | 消息总线组件,通过maven依赖引入。 | 1.3.1 |
RabbitMQ | 消息中间件,已部署在预研环境中。 | 3 |
myClient | 一个客户端服务,用于测试消息总线效果。 | 1.0 |
GitLab配置库 | JHipster-Registry引用的配置中心。所有服务的配置文件所在地。 |
2 JHipster Registry定制
2.1 下载源码
Github上下载jhipster-jhipster源码。
https://github.com/jhipster/jhipster-registry/releases
2.2 提交到GitLab
保存到本地Gitlab源码库
2.3 配置文件定制
pom.xml
<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
management:
security:
enabled: false
context-path: /management # 消息总线的url,这个前缀要加在 /bus/refresh 前面
application-prod.conf
spring:
rabbitmq:
host: rmqha_proxy
port: 56729
username: guest
password: guest
publisher-confirms: true # 生产者消息确认
addresses: rmqha_proxy # 客户端访问server地址, 作为发送者,配置和host一致
2.4 项目构建
在安装了jdk,maven, yarn,nodejs的centos7服务器上执行命令
yarn && yarn install #前端资源配置生成
mvn -Pprod clean package dockerfile:build #项目构建并打包成docker镜像,版本号为3.0
2.5 服务启动
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
3 客户端服务定制
3.1 创建项目
通过jhipster生成一个微服务,名为my-client。
3.2 提交到GitLab
保存到gitLab库git@gitlab.yourcompany.com:root-cloud/mycloud-monitor.git
3.3 配置文件定制
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 {
......
}
3.4 添加测试代码
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()));
}
}
3.5 项目构建
在安装了jdk,maven, yarn,nodejs的centos7服务器上执行命令
$ mvn -Pprod clean package dockerfile:build #项目构建并打包成docker image
3.6 服务启动
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
4 测试效果
4.1 第1次查询配置项
http://<IP>:18081/management/mq/property
http://yourcompany.com/2017 # 返回值
4.2 修改配置项
application:
domain: http://yourcompany.com/2018 # 把2017改成了2018
4.3 第2次查询配置项
http://<IP>:18081/management/mq/property
http://yourcompany.com/2017 # 返回值没有改变
4.4 通知消息总线
$ curl -X POST http://<IP>:8761/management/bus/refresh
4.5 第3次查询配置项
http://<IP>:<port>/management/mq/property
http://yourcompany.com/2018 # 返回值已经更新为2018
JHipster技术栈定制 - JHipster Registry消息总线配置的更多相关文章
- JHipster技术栈定制 - JHipster Registry配置信息加密
本文说明了如何开启和使用JHipster-Registry的加解密功能. 1 整体规划 1.1 名词说明 名词 说明 备注 对称加密 最快速.最简单的一种加密方式,加密(encryption)与解密( ...
- JHipster技术栈定制 - 基于UAA的微服务之间安全调用
本文通过代码实例演示如何通过UAA实现微服务之间的安全调用. uaa: 身份认证服务,同时也作为被调用的资源服务.服务端口9999. microservice1: 调用uaa的消费者服务,服务端口80 ...
- JHipster技术栈理解 - UAA原理分析
本文简要分析了UAA的认证机制和部分源码功能. UAA全称User Account and Authentication. 相关源码都是通过Jhipster生成,包括UAA,Gateway,Ident ...
- jhipster技术栈研究
背景: 公司新的微服务项目都用jhipster脚手架来开发,这篇博客是jhipster里面涉及到技术的汇总目录 一.官方文档中涉及到的技术栈 前端技术栈 Angular / React / Vue R ...
- JHipster技术简介
本文简单介绍Jhipster是什么,为什么用Jhipster,怎么用Jhipster. WHAT - 技术栈 JHipster是什么 JHipster是一个开发平台,用于生成,开发,部署Spring ...
- 如何使用Microsoft技术栈
Microsoft技术栈最近有大量的变迁,这使得开发人员和领导者都想知道他们到底应该关注哪些技术.Microsoft自己并不想从官方层面上反对Silverlight这样的技术,相对而言他们更喜欢让这种 ...
- Java 技术栈
JAVA是一个面向对象的编程语言,由SUN公司的程序员所开发.它不仅吸收了C++的各种优点,而且还撇弃了C++中难以理解的概念,如多继承.指针等:因此JAVA语言具有功能强大且简单易用两个特征, JA ...
- Elastic 技术栈之 Logstash 基础
title: Elastic 技术栈之 Logstash 基础 date: 2017-12-26 categories: javatool tags: java javatool log elasti ...
- Vuejs技术栈知识点小结
前言 上家公司的项目主要是使用jQuery和Angular1,然后自己学了React,没想到来到这家公司突然开始做vue,不过vue还是挺容易上手的.下面是vue技术栈的一些总结,都是来自官网,主要是 ...
随机推荐
- [Swift]LeetCode246.对称数 $ Strobogrammatic Number
A strobogrammatic number is a number that looks the same when rotated 180 degrees (looked at upside ...
- [Swift]LeetCode674. 最长连续递增序列 | Longest Continuous Increasing Subsequence
Given an unsorted array of integers, find the length of longest continuous increasing subsequence (s ...
- [Swift]LeetCode824. 山羊拉丁文 | Goat Latin
A sentence S is given, composed of words separated by spaces. Each word consists of lowercase and up ...
- [Swift]LeetCode961. 重复 N 次的元素 | N-Repeated Element in Size 2N Array
In a array A of size 2N, there are N+1 unique elements, and exactly one of these elements is repeate ...
- Python 创建递归文件夹
# 创建递归文件夹 def createfiles(filepathname): try: os.makedirs(filepathname) except Exception as err: pri ...
- CDN边缘节点容器调度实践(上)
又拍云容器云是基于 Docker 的分布式计算资源网,节点分散在全国各地及海外,提供电信.联通.移动和多线网络,融合微服务.DevOps 理念,满足精益开发.运维一体化,大幅降低分布式计算资源构建复杂 ...
- Android--Task和BackStack高级
前言 之前的博客讲到了Android下Activity的启动模式,涉及到了Task和BackStack的内容,对这些不熟悉的朋友,可以先去看看:Android--Activity的启动模式.这篇博客主 ...
- 基于Spring cloud Ribbon和Eureka实现客户端负载均衡
前言 本案例将基于Spring cloud Ribbon和Eureka实现客户端负载均衡,其中Ribbon用于实现客户端负载均衡,Eureka主要是用于服务注册及发现: 传统的服务端负载均衡 常见的服 ...
- Java开发需掌握的常用Linux命令(持续更新)
linux命令是对Linux系统进行管理的命令.对于Linux系统来说,无论是中央处理器.内存.磁盘驱动器.键盘.鼠标,还是用户等都是文件,Linux系统管理的命令是它正常运行的核心,与之前的DOS命 ...
- linux下(fdisk,gdisk,parted)三种分区工具比较
1 2种分区结构简介 MBR分区 硬盘主引导记录MBR由4个部分组成 主引导程序(偏移地址0000H--0088H),它负责从活动分区中装载,并运行系统引导程序. 出错信息数据区,偏移地址0089H- ...