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 ...
随机推荐
- JavaScript高级编程(1)——JavaScript初识
一.javascript的简介 1.1 javascript的历史回顾. Javascript诞生于1995年.当时,它主要的目的是用来处理一些由服务器端处理的输入验证操作.在javascript没有 ...
- Unity教程之-UGUI美术字体的制作与使用
文章转载自:http://www.unity.5helpyou.com/3211.html 游戏制作中,经常需要使用各种花哨的文字或者数字,而字体库往往不能达到我们需要的效果,因此需要一种用图片替代文 ...
- Vc数据库编程基础MySql数据库的表增删改查数据
Vc数据库编程基础MySql数据库的表增删改查数据 一丶表操作命令 1.查看表中所有数据 select * from 表名 2.为表中所有的字段添加数据 insert into 表名( 字段1,字段2 ...
- vux环境配置
第一步 在vue项目中的package.json文件的dependencies中添加下面三行,即安装vux及其相关依赖 "vux":"^2.7.3", &quo ...
- for循环中变量的作用域问题
看下面这一行代码 for (let i = 0; i < 3; i++) { let i = 'abc' console.log(i) } // abc // abc // abc 从上面可以看 ...
- Linux查询端口是否被占用的四种方法
一个面试题,使用三种不同的方法查看8080被哪个进程占用了.通常比较熟悉的方法是netstat和lsof两种,但还有什么方法呢. 1.netstat或ss命令 netstat -anlp | grep ...
- Perl中的自增、自减
自增和自减 perl也支持数值类型的自增和自减操作.不仅如此,还支持字符.字符串的自增.自减. 如果自增(++)和自减(--)符号放在数值的前面,则先增减,再返回: 如果自增(++)和自减(--)符号 ...
- python if条件判断语句
if的基本格式 if语句用来做判断,并选择要执行的语句分支.基本格式如下: if CONDITION1: code_block(1) elif CONDITION2: code_block(2) el ...
- does not support SSL connections
语言:C# 开发工具:Visual Studio 2017 问题场景介绍: nuget引用的MySql.Data版本是6.10.5,MySQL的数据库连接串如下: Server=xxx;Databas ...
- [转]RPA简介
本文转自:https://www.cnblogs.com/wendyzheng/articles/9211530.html 开篇: 公司正在全面推广RPA,正好借此机会学习一下,发现国内对RPA的了解 ...