JHipster生成微服务架构的应用栈(五)- 容器编排示例
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈。
环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里)
应用栈名称:appstack
认证微服务: uaa
业务微服务:microservice1
网关微服务:gateway
实体名:role
主机IP:192.168.220.120
1 前提条件
1.1 已经生成微服务架构的应用栈
请参考这个系列的前4篇文章。
1.2 安装Docker Compose
推荐版本:1.21.2
完整安装说明,请参考这里
1.3 创建一个编排目录
在命令行,进入appstack目录,创建一个子目录docker-compose,现在整个应用栈的目录结构是这样的:
-- appstack
|-- uaa
|-- microservice1
|-- gateway
|-- docker-compose
1.4 公共镜像
预先下载openjdk:8-jre-alpine容器镜像,能提高后续工作的效率。
2 构建微服务的镜像
2.1 构建所有微服务的镜像
注意:编写本文时使用的JHipster版本为5.1.0,镜像构建命令为:'dockerfile:build';JHipster '5.4.0'及之后的版本使用新的镜像构建命令:'jib:dockerBuild'。
a, 构建uaa镜像
进入uaa目录,输入命令后回车:
$ cd uaa/
$ mvn –Pdev clean package dockerfile:build
b, 构建microservice1镜像
进入microservice1目录,输入命令后回车:
$ cd microservice1/
$ mvn –Pdev clean package dockerfile:build
c, 构建gateway镜像
进入gateway目录,输入命令后回车:
$ cd gateway/
$ mvn –Pdev clean package dockerfile:build
构建成功后,可以通过docker命令查看镜像列表:
$ docker images

3 生成编排文件
进入docker-compose目录,输入命令后回车:
$ cd docker-compose/
$ jhipster docker-compose
命令行输出jhipster:docker-compose命令启动信息

现在开始问答环节
3.1 Which type of application would you like to deploy?
选择想要部署的应用类型
这是一个单选题,有2个选项,使用上下键切换选项。
因为要部署的是一个微服务架构应用栈,这里选择Microservice application。

单击回车继续。
3.2 Which type of gateway would you like to use?
选择网关的类型
这是一个单选题,有2个选项,使用上下键切换选项。
这里选择JHipster gateway based on Netflix Zuul。

单击回车继续。
3.3 Enter the root directory where your gateway(s) and microservices are located
输入需要部署的网关和业务微服务的位置
这是一个相对于docker-compose的相对路径,默认路径是../,这也是之前生成的网关和业务微服务以及认证微服务的位置。

单击回车继续。
3.4 Which applications do you want to include in your configuration?
选择需要加入编排配置文件的微服务
这是一个多选题,使用上下键切换选项,使用空格键选中选项,使用a键全选,使用i键取消全选。
这里选择全部的微服务。

单击回车继续。
3.5 Do you want to setup monitoring for your applications ?
选择是否需要启动监控组件
这是一个单选题,有3个选项,使用上下键切换选项。
简单起见,选择No。

单击回车继续。
3.6 Enter the admin password used to secure the JHipster Registry
输入JHipster Registry的admin账号的密码
默认值是admin,这也是之前启动的JHipster Registry的密码。

单击回车继续。
问答结束,开始生成工程代码
这个过程通常需要1-2分钟。

完成后,在目录下看到所有生成的文件。
修改配置文件
打开docker-compose.yml文件
$ vi docker-compose
加入数据库密码和端口映射的配置
gateway-mysql:
image: mysql:5
environment:
- MYSQL_ROOT_PASSWORD=my-secret-pw # 加入数据库密码配置
ports:
- 32800:3306 # 加入端口映射配置
......
......
microservice1-mysql:
image: mysql:5
environment:
- MYSQL_ROOT_PASSWORD=my-secret-pw # 加入数据库密码配置
ports:
- 32700:3306 # 加入端口映射配置
......
......
uaa-mysql:
image: mysql:5
environment:
- MYSQL_ROOT_PASSWORD=my-secret-pw # 加入数据库密码配置
ports:
- 32900:3306 # 加入端口映射配置
把Profile配置中的prod改成dev
gateway-app:
image: gateway
environment:
- SPRING_PROFILES_ACTIVE=dev,swagger # 如果这里是prod,改成dev
检查所有镜像的Tag是否和本地的镜像一致
特别是mysql和jhipster-registry这2个镜像的Tag,这样避免启动容器的时候,临时去下载镜像。
4 通过容器编排启动微服务应用栈
进入docker-compose目录,输入命令后回车:
$ docker-compose up -d
命令行输出所有微服务容器启动信息

所有容器和容器内的微服务启动,需要大概3-5分钟。
启动完成后,就可以访问JHipster Registry和gateway的Web UI,默认用户名和密码都是admin:
http://192.168.220.120:8761
http://192.168.220.120:8080
其它docker-compose命令
$ docker-compose scale microservice1=5 # 将microservice1的容器实例扩展到5个
$ docker-compose stop # 停止所有编排中的容器
$ docker-compose down # 停止并且删除所有编排中的容器
系列文章
JHipster生成微服务架构的应用栈(一)- 准备工作
JHipster生成微服务架构的应用栈(二)- 认证微服务示例
JHipster生成微服务架构的应用栈(三)- 业务微服务示例
JHipster生成微服务架构的应用栈(四)- 网关微服务示例
JHipster生成微服务架构的应用栈(五)- 容器编排示例
JHipster生成微服务架构的应用栈(五)- 容器编排示例的更多相关文章
- JHipster生成微服务架构的应用栈(一)- 准备工作
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...
- JHipster生成微服务架构的应用栈(二)- 认证微服务示例
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...
- JHipster生成微服务架构的应用栈(三)- 业务微服务示例
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...
- JHipster生成微服务架构的应用栈(四)- 网关微服务示例
本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...
- 庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群
庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群 一.简介 前面的两篇文章,我们已经介绍了Net Core项目基于Docker容器部署在Linux服 ...
- .Net 微服务架构技术栈的那些事
一.前言 大家一直都在谈论微服务架构,园子里面也有很多关于微服务的文章,前几天也有一些园子的朋友问我微服务架构的一些技术,我这里就整理了微服务架构的技术栈路线图,这里就分享出来和大家一起探讨学习,同时 ...
- 使用jhipster搭建微服务--简单demo
简介 jhipster简单来说是一个基于nodejs+yeoman的java代码生成器.往大了说是基于java的一套微服务解决方案.请注意是一整套的微服务解决方案.jhipster在整个程序架构上都做 ...
- .NET Core微服务架构学习与实践系列文章索引目录
一.为啥要总结和收集这个系列? 今年从原来的Team里面被抽出来加入了新的Team,开始做Java微服务的开发工作,接触了Spring Boot, Spring Cloud等技术栈,对微服务这种架构有 ...
- 开篇有益-解析微软微服务架构eShopOnContainers(一)
为了推广.Net Core,微软为我们提供了一个开源Demo-eShopOnContainers,这是一个使用Net Core框架开发的,跨平台(几乎涵盖了所有平台,windows.mac.linux ...
随机推荐
- (转)python异步编程--回调模型(selectors模块)
原文:https://www.cnblogs.com/zzzlw/p/9384308.html#top 目录 0. 参考地址 1. 前言 2. 核心类 3. SelectSelector核心函数代码分 ...
- mybatis框架(2)---mapper代理方法
mapper代理方法 在我们在写MVC设计的时候,都会写dao层和daoimp实现层,但假如我们使用mapper代理的方法,我们就可以不用先daoimp实现类 当然这得需要遵守一些相应的规则: (1) ...
- linux取IP的几个方法
ifconfig eth0|grep " inet add"|cut -d":" -f2|cut -d " " -f1 ifconfig e ...
- stack源码
stack概述 stack是一种先进后出的数据结构,它只有一个出口,允许新增元素.移除元素.取得最顶端元素,但每次只能处理顶端元素,也就是说,stack不允许遍历行为. stack定义 以某种既有容器 ...
- 安装postgreSQL出现configure: error: zlib library not found解决方法
./configure --prefix=/usr/local/pgsql ..... configure: error: zlib library not foundIf you have zlib ...
- Go中iota是什么
Go iota是一个比较奇怪的存在,它只能用在const的申明中,是一个从0开始的行数索引器. 看代码 package main import ( "fmt" ) const ( ...
- 开发-封闭原则(OCP)
1.什么是“开放-封闭” 随着软件系统规模的不断增大,软件系统的维护和修改的复杂性不断提高,这种困境促使法国工程院士Bertrand Meyer在1998年提出了“开放-封闭”(Open-Close ...
- 闪电侠 Netty 小册里的骚操作
前言 即使这是一本小册,但基于"不提笔不读书"的理念,仍然有必要总结一下.此小册对于那些"硬杠 Netty 源码 却不曾在千万级生产环境上使用实操"的用户非常有 ...
- 小型音乐播放器插件APlayer.js的简单使用例子
本篇博客将会给出一个小型音乐播放器插件APlayer.js的使用例子.关于APlayer.js的具体介绍和Github地址,可以参考: https://github.com/MoePlayer/A ...
- Linux学习笔记之Django项目部署(CentOS)
一.引入 用Django写了一个测试的项目,现在要部署在Linux上,一般这种情况下,只要在项目里面敲一行命令:python manage.py runserver 0.0.0.0:8000就行了.但 ...