文档

PHP构建并部署到ECS

更新时间:

一、背景

如果你

1.使用PHP进行开发

2.需要将源码部署到ECS

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

二、用户诉求

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

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

2.将源代码构建成为可交付的制品,比如Jar/War,如果是PHP语言则不需要这一步

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

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

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

三、云效解决方案

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

31

开发者提交代码变更到代码库,云效在监听着代码库的变动,一旦代码发生变化,将自动触发云效持续部署流水线一次构建任务的运行,包括代码检查、构建、测试部署、测试验证和生产部署等过程。以PHP语言为例,在单元测试等检查通过后,在部署阶段(测试环境的部署和生产环境的部署)可以获取当前的代码库信息和commit id,将代码同步到不同环境的主机资源中,完成发布。这里资源可以是阿里云或者自建主机资源。

四、云效操作实践

1、创建流水线

  • 进入云效,点击页面左上角的dock,选择流水线进入Flow:

说明

立即体验:云效流水线Flow

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

412
  • 选择相应模板,并点击创建

413

2、配置代码库

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

421

3、配置部署任务

  • 接下来配置主机部署任务。先选择制品,选择获取git版本阶段输出的制品。为了配置主机组,需要先创建一个,点击”新建主机组”。

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

432433434435436

选择好服务以后,需要对服务器进行php运行环境的配置,登录服务器以后,需要执行以下命令:

yum install git;
yum install php php-mysql php-fpm php-mbstring php-gd php-pear php-mhash php-eaccelerator  php-cli php-imap php-ldap php-odbc php-pear php-xml php-xmlrpc php-mssql php-snmp php-soap php-tidy php-common php-devel php-pecl-xdebug phpmyadmin php-mcrypt -y;
yum install httpd;
systemctl restart httpd;
  • 接下来进行部署脚本的配置:

a.下载路径:由于PHP语言可以直接通过git clone或者git checkout的方式来直接更新源码,所以下载路径可以为空

b.执行用户:希望以是哪个用户的身份进行脚本执行,本例的值为:root

c.部署脚本:在机器上执行脚本的具体内容,本例的值为:

if [ ! -d "/var/www/html/php-demo" ]; then
  git clone https://atomgit.com/flow-example/php-laravel-blog.git /var/www/html/php-demo;
fi  

cd /var/www/html/php-demo;
git checkout ${COMMIT_ID};  
438
  • 部署策略配置

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

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

4、添加人工卡点

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

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

441442443

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

444445

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

5、运行流水线

配置完毕,点击”保存并运行”触发流水线:

451452

扫描、单测及构建上传的任务自动完成,并停在了卡点上:

453

普通人员无权限通过,切换到延枚的账号之后,可以通过或者拒绝:

454

点击”验证通过“,流水线会进入主机部署的任务,点击”部署详情”可以看到更多部署信息:

455

点击查看日志,可以看到执行的日志详情:

456

日志显示部署成功,此时访问该主机的公网接口可以看到服务已经可以正常访问了:

$ curl http://39.97.XXX.XX/php-demo/public/index.php

6、回滚

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

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

461

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

462463

7、通知

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

471

再次运行之后,就会收到相应的通知:

472

五、结语

通过 Flow 流水线可以轻松实现PHP语言从代码到上线的整个流程。如果你对其他语言感兴趣,可以查看其他文档。