全部产品

NodeJS应用构建并部署ECS

作者:

一、背景

如果你

1.使用NodeJS进行开发

2.使用二进制的制品形式进行交付

3.制品最终会运行到ECS或者自有主机上

那么本文档可以帮你宁实现研发流程的协同自动化。

二、用户诉求

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

1.对源代码进行一定的质量检测,比如单元测试,代码扫描

2.将源代码构建成为可交付的制品,比如二进制文件

3.对制品进行测试环境验证

4.使用完成验证的制品进行线上部署

上述活动需要有不同角色的参与:开发、测试、运维。如何保证不同参与者可以使用统一的交付流程来进行协作,是云效Flow交付流水线要解决的主要问题。

三、云效解决方案

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

31

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

四、云效操作实践

1、创建流水线

  • 进入云效(https://devops.aliyun.com)点击页面左上角的dock,选择流水线进入Flow

411
  • 点击右上角【新建流水线】,进入流水线创建向导页面。选择相应模板,并点击创建

412

2、配置代码库

创建流水线之后会自动弹出添加代码源的窗口,这里选择Flow提供的示例代码源,并进行添加

411

3、配置构建任务

在Nodejs构建任务中我们需要完成Nodejs的应用依赖包下载,并将构建后的应用包作为构建产物上传以在后续的部署任务中使用:

在Nodejs构建步骤中使用cnpm install安装Nodejs应用依赖

431

在构建产物上传中,上传构建产物以及应用的部署脚本appctl.sh

432

4、配置部署任务

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

451
  • 选择”阿里云ECS“,点击”新建服务授权”,跳转到阿里云,完成RAM授权,然后会自动跳回到Flow。此时再选择相应的地区,并选择需要部署的ECS,点击下一步,填写主机组名称,然后点击保存,完成主机组创建。新建的主机组会自动填入到流水线配置中。

452453

454458

459
  • 配置部署命令,如下所示,部署过程会先讲制品下载到主机的/home/admin/app/package.tgz,后以root用户的身份执行部署脚本:

4510

部署脚本如下所示:

mkdir -p/home/admin/application/tar zxvf /home/admin/app/package.tgz -C/home/admin/application/cd /home/admin/application/./app-configs/bin/appctl.shrestart

5、运行流水线

配置部署命令后,点击”保存并运行”触发流水线:

453

代码编译上传后,自动触发发布任务:

452

点击卡片上的日志按钮可以查看发布详情:

451

6、添加人工卡点

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

首选需要在企业中创建一个角色”测试管理员“,并将企业用户”砧木”的角色设置为该角色。

469999946888846666

然后回到流水线继续进行配置,在发布前面添加一个任务,搜索”人工卡点“,并按照角色进行配置:

463462462

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

重新保存并运行流水线,当镜像构建完成后,可以看到流程会自动暂停,并等待当前企业中角色测试管理员的人员进行审批,只有当审批通过后,才会继续触发后续的发布流程

461

7、回滚

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

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

471472

8、通知

为了更好的进行协作,Flow提供了通知能力在流水线不同的生命周期节点上进行通知。一般来讲开发团队会关心部署的成功和失败,那么可以将该事件推送到团队的钉钉群中,配置方式如下,点击”添加插件”,选择钉钉机器人通知,填入webhook地址,运行时机选择”失败“,”成功”

481482

五、结语

通过以上的操作流程,就可以建立起来一个协同多角色的流水线。接下来你可能想再了解其中的一些细节:

1.定制化代码扫描规则定制化扫描及单元测试通过规则

2.如何添加非ECS主机