Java应用构建并部署ECS

本文涉及的产品
云效 DevOps 流水线,基础版人数 不受限
云效 DevOps 代码管理,基础版人数 不受限
云效 DevOps 项目协作,基础版人数 不受限
简介: 如果你使用Java进行开发使用Jar/War的制品形式进行交付制品最终会运行在ECS或者自有主机上那么本文档可以帮助您实现研发流程的协同自动化。用户诉求一般来说,用户使用主机部署场景如下:对源代码进行一定的质量检测,比如单元测试,代码扫描将源代码构建成为可交付的制品,比如Jar/War对制品进行测试环境验证使用完成验证的制品进行线上部署上述活动需要有不同角色的参与:开发、测试、运维。如何保证不同参与者可以使用统一的交付流程来进行协作,是云效Flow交付流水线要解决的主要问题

简介

如果你

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

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

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

云效解决方案

结合云效持续交付流水线和主机部署的能力,为应用持续交付提供了很好的基础保障,如图:

O1CN01POFs7Q1fa7dOl1JV1_!!6000000004022-2-tps-1077-500.png
开发者提交代码变更到代码库,云效在监听着代码库的变动,一旦代码发生变化,将自动触发云效持续部署流水线一次构建任务的运行,包括代码检查、构建、测试部署、测试验证和生产部署等过程。其中,在构建完之后,生成制品包并自动上传至OSS仓库,在部署阶段(测试环境的部署和生产环境的部署)时,再从制品仓库中取得最新的版本,根据不同的部署策略通过主机部署到不同环境,这里资源可以是阿里云或者自建主机资源。

创建流水线

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

1.使用您自己的账号进入云效(https://devops.aliyun.com)点击页面左上角的dock,选择流水线进入Flow。O1CN01TgfEoM1ubEprM0dn9_!!6000000006055-2-tps-1920-1080.png

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

O1CN011Sx9bc1DwHYY94pbG_!!6000000000280-2-tps-1920-1080.png
3.选择相应模板,并点击创建。
O1CN0191ddoW1MJeh6uUjnk_!!6000000001414-2-tps-1920-1080.png

配置代码库

1.创建流水线之后会自动弹出添加代码源的窗口,这里选择Flow提供的示例代码源,并进行添加
O1CN01aupxDo1LriXG7f5LD_!!6000000001353-2-tps-1920-1080.png

配置构建上传任务

1.修改一下”Java构建上传“的任务,增加一个打包路径,填入deploy.sh。这个文件存在于代码库中,其中包含了在ECS上进行应用启动的脚本,为了进行后续的主机部署,需要将这个文件也打入到压缩包中,在后续的主机部署任务中可以看到如何使用该deploy.sh。在该配置中指定了target/和deploy.sh两个路径,所以Flow会将这两个文件(夹)打包成为一个压缩包,并进行归档,在Flow中我们称之为制品,该制品也会在后续的主机部署任务中用到。
O1CN01Hed71P2A2ScD1LKcP_!!6000000008145-2-tps-1920-1080.png
O1CN01T8zsi61gFnfw3QAp4_!!6000000004113-2-tps-1920-1080.png

连接ECS服务器

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

O1CN01JfAMoX1xiyPCBH5Dy_!!6000000006478-2-tps-1404-830.png

配置部署任务

1.接下来配置主机部署任务,在制品下拉框中选择”制品名称.default”,也就是前面的”Java构建上传“步骤归档的那个制品。为了配置主机组,需要先创建一个,点击”新建主机组”。
O1CN01Ud1fEe1gWHw47ZAMh_!!6000000004149-2-tps-1920-1080.png

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

a. 选择 “自有主机”;
O1CN01icc8pe1v4YBZNQl0A_!!6000000006119-2-tps-1920-915.png

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

O1CN01uvm7Qp26Pa92Qq4nj_!!6000000007654-2-tps-1920-915.png
c. 在ECS服务器中粘贴复制过来的命令并进行安装;

O1CN01UYl2DV1q1jfidAcOw_!!6000000005436-2-tps-1893-862.png

d.  agent插件安装成功后自有主机界面会自动获取到主机信息;

O1CN01JbgWNr1rPNjk8n3z6_!!6000000005623-2-tps-1920-915.png
e. 进一步填写自有主机信息,可参考下图所示;点击保存后自有主机添加完成。

O1CN01bdZcbR1u4iiUHaqMe_!!6000000005984-2-tps-1920-915.png

  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

O1CN01AeaX2b1vTjy97gytD_!!6000000006174-2-tps-1920-1080.png

4.部署策略配置

a. 暂停方式:希望一个主机组中的机器以什么样的暂停方式进行,比如第一批暂停,每批暂停,或者不暂停。推荐使用第一批暂停,在发布完第一批之后,对线上服务进行观察,如果没有异常,则可以继续其余批的发布

b. 分批数量:希望主机组中的机器分为几批进行发布。比如一共4台机器,分两批,则每批同时发布2台机器。

添加人工卡点

为了保证经过审批的制品才能进入部署环境,需要添加一个人工卡点,这里假设这个环境是测试环境,需要有测试管理员来审批才能进入。

首选需要在企业中创建一个角色”测试管理员“,并将企业用户”张三”的角色设置为该角色。
O1CN01OKbw7I2478y9Klnqc_!!6000000007343-2-tps-1920-1080.png
O1CN017gUm8A1sW595iswlc_!!6000000005773-2-tps-1920-1080.png
O1CN01gQg9ke1q6JdM0mftR_!!6000000005446-2-tps-1920-1080.png
O1CN01nZL0fC1lAN3kQGOBD_!!6000000004778-2-tps-1920-1080.png
O1CN01hjo7Xn1VRkEVKQkcY_!!6000000002650-2-tps-1920-1080.png
O1CN01vz5dSr1caApUM2Ndv_!!6000000003616-2-tps-1920-1080.png
以上演示了如何添加一个进入测试环境的卡点,添加生产环境的卡点也是类似的,这里不再赘述,可以类似的进行配置。

运行流水线

配置完毕,点击”保存并运行”触发流水线:
O1CN01He2gGO1XnqZvSBk5Y_!!6000000002969-2-tps-1920-1080.png
O1CN010uywsD1kYoaExd1n1_!!6000000004696-2-tps-1920-1080.png
扫描、单测及构建上传的任务自动完成,并停在了卡点上:

O1CN01qBp7cz1bOtSerwhxh_!!6000000003456-2-tps-1920-1080.png
普通人员无权限通过,切换到张三的账号之后,可以通过或者拒绝:

O1CN01tKDwTI1uxDqd9fcM5_!!6000000006103-2-tps-1920-1080.png
点击”验证通过“,流水线会进入主机部署的任务,点击”部署详情”可以看到更多部署信息:

O1CN01wezVTV1dBGufMEb4K_!!6000000003697-2-tps-1920-1080.png
点击查看日志,可以看到执行的日志详情:

O1CN01sfQclw1ZYORjsI2Ls_!!6000000003206-2-tps-1920-1080.png
日志显示部署成功,此时访问该主机的公网接口可以看到服务已经可以正常访问了:

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

回滚

如果发布完成之后发现线上服务有问题,则需要快速回滚。云效Flow提供了通过历史版本直接进行回滚的能力。

在流水线运行页面点击”部署历史“,然后选择相应的部署任务,便可以看到该部署任务所有的成功部署记录
O1CN01Rx6IKD1hH0KfrdcE0_!!6000000004251-2-tps-1920-1080.png
点击版本4的”回滚“,即可回滚到该版本。

O1CN013jEztR1vzLIW1rWst_!!6000000006243-2-tps-1920-1080.png
O1CN01wE8rnf1rO0Y0lcJNh_!!6000000005620-2-tps-1920-1080.png

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
人工智能 安全 Java
Java和Python在企业中的应用情况
Java和Python在企业中的应用情况
81 7
|
23天前
|
安全 算法 Java
Java CAS原理和应用场景大揭秘:你掌握了吗?
CAS(Compare and Swap)是一种乐观锁机制,通过硬件指令实现原子操作,确保多线程环境下对共享变量的安全访问。它避免了传统互斥锁的性能开销和线程阻塞问题。CAS操作包含三个步骤:获取期望值、比较当前值与期望值是否相等、若相等则更新为新值。CAS广泛应用于高并发场景,如数据库事务、分布式锁、无锁数据结构等,但需注意ABA问题。Java中常用`java.util.concurrent.atomic`包下的类支持CAS操作。
58 2
|
1月前
|
开发框架 .NET PHP
网站应用项目如何选择阿里云服务器实例规格+内存+CPU+带宽+操作系统等配置
对于使用阿里云服务器的搭建网站的用户来说,面对众多可选的实例规格和配置选项,我们应该如何做出最佳选择,以最大化业务效益并控制成本,成为大家比较关注的问题,如果实例、内存、CPU、带宽等配置选择不合适,可能会影响到自己业务在云服务器上的计算性能及后期运营状况,本文将详细解析企业在搭建网站应用项目时选购阿里云服务器应考虑的一些因素,以供参考。
|
2月前
|
缓存 Java 开发者
Java多线程并发编程:同步机制与实践应用
本文深入探讨Java多线程中的同步机制,分析了多线程并发带来的数据不一致等问题,详细介绍了`synchronized`关键字、`ReentrantLock`显式锁及`ReentrantReadWriteLock`读写锁的应用,结合代码示例展示了如何有效解决竞态条件,提升程序性能与稳定性。
217 6
|
1月前
|
监控 Java 数据库连接
Java线程管理:守护线程与用户线程的区分与应用
在Java多线程编程中,线程可以分为守护线程(Daemon Thread)和用户线程(User Thread)。这两种线程在行为和用途上有着明显的区别,了解它们的差异对于编写高效、稳定的并发程序至关重要。
44 2
|
2月前
|
关系型数据库 MySQL Java
MySQL索引优化与Java应用实践
【11月更文挑战第25天】在大数据量和高并发的业务场景下,MySQL数据库的索引优化是提升查询性能的关键。本文将深入探讨MySQL索引的多种类型、优化策略及其在Java应用中的实践,通过历史背景、业务场景、底层原理的介绍,并结合Java示例代码,帮助Java架构师更好地理解并应用这些技术。
68 2
|
2月前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
数据采集 SQL 弹性计算
使用云服务器ECS部署了自己的第一个爬虫
云服务器部署爬虫爬取网站最新通告并推送
使用云服务器ECS部署了自己的第一个爬虫
|
5天前
|
弹性计算 数据挖掘 应用服务中间件
阿里云轻量应用服务器68元与云服务器99元和199元区别及选择参考
目前阿里云有三款特惠云服务器,第一款轻量云服务器2核2G68元一年,第二款经济型云服务器2核2G3M带宽99元1年,第三款通用算力型2核4G5M带宽199元一年。有的新手用户并不是很清楚他们之间的区别,因此不知道如何选择。本文来介绍一下它们之间的区别以及选择参考。
173 84
|
15天前
|
机器学习/深度学习 人工智能 PyTorch
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
阿里云GPU云服务器怎么样?阿里云GPU结合了GPU计算力与CPU计算力,主要应用于于深度学习、科学计算、图形可视化、视频处理多种应用场景,本文为您详细介绍阿里云GPU云服务器产品优势、应用场景以及最新活动价格。
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考