关于ecs:Java应用构建并部署ECS

3次阅读

共计 2161 个字符,预计需要花费 6 分钟才能阅读完成。

简介

如果你

应用 Java 进行开发
应用 Jar/War 的制品模式进行交付
制品最终会运行在 ECS 或者自有主机上
那么本文档能够帮忙您实现研发流程的协同自动化。

用户诉求
一般来说,用户应用主机部署场景如下:

对源代码进行肯定的品质检测,比方单元测试,代码扫描
将源代码构建成为可交付的制品,比方 Jar/War
对制品进行测试环境验证
应用实现验证的制品进行线上部署
上述流动须要有不同角色的参加:开发、测试、运维。如何保障不同参与者能够应用对立的交付流程来进行合作,是云效 Flow 交付流水线要解决的次要问题。
本场景云起实验室提供相应资源,此处获取

云效解决方案

联合云效继续交付流水线和主机部署的能力,为利用继续交付提供了很好的根底保障,如图:


开发者提交代码变更到代码库,云效在监听着代码库的变动,一旦代码发生变化,将主动触发云效继续部署流水线一次构建工作的运行,包含代码查看、构建、测试部署、测试验证和生产部署等过程。其中,在构建完之后,生成制品包并主动上传至 OSS 仓库,在部署阶段(测试环境的部署和生产环境的部署)时,再从制品仓库中获得最新的版本,依据不同的部署策略通过主机部署到不同环境,这里资源能够是阿里云或者自建主机资源。

创立流水线

接下来以一个 Java Spring Boot 的代码库为例,解说如何进行构建并部署到阿里云 ECS 服务器。

1. 应用您本人的账号进入云效(https://devops.aliyun.com)点击页面左上角的 dock,抉择流水线进入 Flow。

2. 点击右上角【新建流水线】,进入流水线创立向导页面。


3. 抉择相应模板,并点击创立。

配置代码库

1. 创立流水线之后会自动弹出增加代码源的窗口,这里抉择 Flow 提供的示例代码源,并进行增加

配置构建上传工作

1. 批改一下”Java 构建上传“的工作,减少一个打包门路,填入 deploy.sh。这个文件存在于代码库中,其中蕴含了在 ECS 上进行利用启动的脚本,为了进行后续的主机部署,须要将这个文件也打入到压缩包中,在后续的主机部署工作中能够看到如何应用该 deploy.sh。在该配置中指定了 target/ 和 deploy.sh 两个门路,所以 Flow 会将这两个文件(夹)打包成为一个压缩包,并进行归档,在 Flow 中咱们称之为制品,该制品也会在后续的主机部署工作中用到。

连贯 ECS 服务器

点击页面右侧 切换至 Web Terminal 即可连贯到 ECS 服务器。

配置部署工作

1. 接下来配置主机部署工作,在制品下拉框中抉择”制品名称.default”,也就是后面的”Java 构建上传“步骤归档的那个制品。为了配置主机组,须要先创立一个,点击”新建主机组”。

2. 参考如下步骤增加 ECS 主机。

a. 抉择“自有主机”;

b. 复制自有主机界面命令;


c. 在 ECS 服务器中粘贴复制过去的命令并进行装置;

d.  agent 插件装置胜利后自有主机界面会主动获取到主机信息;


e. 进一步填写自有主机信息,可参考下图所示;点击保留后自有主机增加实现。

  1. 接下来进行部署脚本的配置:

下载门路:示意心愿把”构建上传”工作中的压缩包下载到机器上的什么地位,在本例的值为:/home/admin/app/package.tgz
执行用户:心愿以是哪个用户的身份进行脚本执行,本例的值为:root
部署脚本:在机器上执行脚本的具体内容,本例的值为:

mkdir -p /home/admin/application/
tar zxvf /home/admin/app/package.tgz -C /home/admin/application/
sh /home/admin/application/deploy.sh restart

4. 部署策略配置

a. 暂停形式:心愿一个主机组中的机器以什么样的暂停形式进行,比方第一批暂停,每批暂停,或者不暂停。举荐应用第一批暂停,在公布完第一批之后,对线上服务进行察看,如果没有异样,则能够持续其余批的公布

b. 分批数量:心愿主机组中的机器分为几批进行公布。比方一共 4 台机器,分两批,则每批同时公布 2 台机器。

增加人工卡点

为了保障通过审批的制品能力进入部署环境,须要增加一个人工卡点,这里假如这个环境是测试环境,须要有测试管理员来审批能力进入。

首选须要在企业中创立一个角色”测试管理员“,并将企业用户”张三”的角色设置为该角色。






以上演示了如何增加一个进入测试环境的卡点,增加生产环境的卡点也是相似的,这里不再赘述,能够相似的进行配置。

运行流水线

配置结束,点击”保留并运行”触发流水线:


扫描、单测及构建上传的工作主动实现,并停在了卡点上:


一般人员无权限通过,切换到张三的账号之后,能够通过或者回绝:


点击”验证通过“,流水线会进入主机部署的工作,点击”部署详情”能够看到更多部署信息:


点击查看日志,能够看到执行的日志详情:


日志显示部署胜利,此时拜访该主机的公网接口能够看到服务曾经能够失常拜访了:

$ curl http://47.244.109.14:8080/
Greetings from Spring Boot!

回滚

如果公布实现之后发现线上服务有问题,则须要疾速回滚。云效 Flow 提供了通过历史版本间接进行回滚的能力。

在流水线运行页面点击”部署历史“,而后抉择相应的部署工作,便能够看到该部署工作所有的胜利部署记录

点击版本 4 的”回滚“,即可回滚到该版本。


正文完
 0