美文网首页
码云双分支(master/develop)自动部署生产服/测试服

码云双分支(master/develop)自动部署生产服/测试服

作者: 王小滔 | 来源:发表于2019-11-25 10:02 被阅读0次

一般项目的开发测试流程,都会有测试服、生产服的角色,码云代码托管中创建双分支,让其master分支对应生产服,develop分支对应测试服,分别实现自动更新部署,现在分两种情况,分别给出相应的webhooks源代码(PHP),实现本自动更新的基础是在相应的服务器上已经摘取了对应的分支版本并且配置了部署公钥等基础操作,如不了解,请自行搜索,或者参考我的另一篇文章《项目创建部署全流程--码云创建项目、部署webhooks服务器自动更新》

一、测试站点与正式站点都部署在同一服务器上

这种情况比较简单,每次请求根据Push操作的分支来判断相应更新测试站点或者正式站点的项目文件即可,参考源代码如下

<?php
/*
* 码云webhooks自动更新程序
* 根据不同分支来自动更新正式站/测试站
* $logdir 日志存放目录
* $name 站点标识字符,多站点方便区分日志
* $password 码云设置的访问密码
* $wwwroot 正式站点目录
* $testdir 测试站点目录
* author: 王小滔
* date: 2019-11-23
*/

$logdir = "/www/wwwroot/webhook/logs/";
$name = 'project_name';
$password = 'your_password';
$wwwroot = '/www/wwwroot/project_name';
$testdir = '/www/wwwroot/project_name_test';

$json = file_get_contents("php://input");
$data = json_decode($json,true);
if ($data['password'] != $password) {
    die('Password id error!');
}

if (isset($data['ref'])&& $data['total_commits_count'] > 0) {
    if ($data['ref'] == 'refs/heads/master') {
        $dir = $wwwroot;
        $branch = 'master';
        $site = '正式';
    } else {
        $dir = $testdir;
        $branch = 'develop';
        $site = '测试';
    }
    $res = PHP_EOL . "pull start ---------------------------------------------" . PHP_EOL;
    $res .= shell_exec("cd {$dir} && git pull origin {$branch} 2<&1 ");
    $res_log = '------------------------------------------------------------' . PHP_EOL;
    $res_log .= $site . '站点更新,目录:' . $dir . PHP_EOL;
    $res_log .= $data['user_name'] . ' 在 ' . date('Y-m-d H:i:s'). ' 向 ' . $data['repository']['name'] . ' 项目的 ' .                    $data['ref'] . ' 分支push了 ' . $data['total_commits_count'] . ' 个commit:' . $data['commits']['message'];
    $res_log .= $res . PHP_EOL;
    $res_log .= "pull end -----------------------------------------------------" . PHP_EOL;
    file_put_contents($logdir . $name . "_" . date('Ymd'). ".txt",$res_log,FILE_APPEND);
}

二、测试站点与正式站点分别部署在测试服与生产服

这种情况,其实也不复杂,只不过需要事先分别创建两个服务器的部署公钥添加到码云,然后在webhooks添加两个钩子文件网址即可,以下是测试服与生产服分别的对应源代码

1、测试服webhook源代码(对应develop分支)

<?php
/*
* 码云webhooks自动更新程序
* 根据不同分支来自动更新正式站/测试站
* $logdir 日志存放目录
* $name 站点标识字符,多站点方便区分日志
* $password 码云设置的访问密码
* $testdir 测试站点目录
* author: 王小滔
* date: 2019-11-25
*/

$logdir = "/www/wwwroot/webhook/logs/";
$name = 'project_name';
$password = 'your_password';
$testdir = '/www/wwwroot/project_name_test';

$json = file_get_contents("php://input");
$data = json_decode($json,true);
if ($data['password'] != $password) {
    die('Password id error!');
}

if (isset($data['ref'])&& $data['total_commits_count'] > 0) {
    if ($data['ref'] == 'refs/heads/develop') {
      $res = PHP_EOL . "pull start ---------------------------------------------" . PHP_EOL;
      $res .= shell_exec("cd {$testdir} && git pull origin develop 2<&1 ");
      $res_log = '------------------------------------------------------------' . PHP_EOL;
      $res_log .= '测试站点更新,目录:' . $testdir . PHP_EOL;
      $res_log .= $data['user_name'] . ' 在 ' . date('Y-m-d H:i:s'). ' 向 ' . $data['repository']['name'] . ' 项目的 ' .                      $data['ref'] . ' 分支push了 ' . $data['total_commits_count'] . ' 个commit:' . $data['commits']['message'];
      $res_log .= $res . PHP_EOL;
      $res_log .= "pull end -----------------------------------------------------" . PHP_EOL;
      file_put_contents($logdir . $name . "_" . date('Ymd'). ".txt",$res_log,FILE_APPEND);
    }
}

2、生产服webhook源代码(对应master分支)

<?php
/*
* 码云webhooks自动更新程序
* 根据不同分支来自动更新正式站/测试站
* $logdir 日志存放目录
* $name 站点标识字符,多站点方便区分日志
* $password 码云设置的访问密码
* $testdir 测试站点目录
* author: 王小滔
* date: 2019-11-25
*/

$logdir = "/www/wwwroot/webhook/logs/";
$name = 'project_name';
$password = 'your_password';
$wwwroot = '/www/wwwroot/project_name';

$json = file_get_contents("php://input");
$data = json_decode($json,true);
if ($data['password'] != $password) {
    die('Password id error!');
}

if (isset($data['ref'])&& $data['total_commits_count'] > 0) {
    if ($data['ref'] == 'refs/heads/master') {
      $res = PHP_EOL . "pull start ---------------------------------------------" . PHP_EOL;
      $res .= shell_exec("cd {$wwwroot} && git pull origin master 2<&1 ");
      $res_log = '------------------------------------------------------------' . PHP_EOL;
      $res_log .= '正式站点更新,目录:' . $wwwroot . PHP_EOL;
      $res_log .= $data['user_name'] . ' 在 ' . date('Y-m-d H:i:s'). ' 向 ' . $data['repository']['name'] . ' 项目的 ' .                      $data['ref'] . ' 分支push了 ' . $data['total_commits_count'] . ' 个commit:' . $data['commits']['message'];
      $res_log .= $res . PHP_EOL;
      $res_log .= "pull end -----------------------------------------------------" . PHP_EOL;
      file_put_contents($logdir . $name . "_" . date('Ymd'). ".txt",$res_log,FILE_APPEND);
    }
}

OK,就是这么简单,希望对大家有帮助,如果还有什么问题,欢迎随时与我交流!

相关文章

  • 码云双分支(master/develop)自动部署生产服/测试服

    一般项目的开发测试流程,都会有测试服、生产服的角色,码云代码托管中创建双分支,让其master分支对应生产服,de...

  • Git-开发流程

    我们的项目中,master、develop 为受保护分支,master 对应生产环境,develop 对应测试环境...

  • Git 常用命令

    1. Git 分支 主分支master 分支:存放随时可供生产环境中的部署的代码develop 分支:存放当前最新...

  • git branch最佳实践

    一. 主分支 master分支生产环境下的正式版本 develop分支nightly build 自动化任务的来源...

  • 代码提交、合并和部署服务流程文档

    代码提交、合并和部署服务流程 代码至少两个分支,主分支master、开发分支develop。 主分支master ...

  • git 分支开发规范

    [TOC] 分支命名 master 分支 master 为主分支,也是用于部署生产环境的分支,确保master分支...

  • Git分支命名规范

    master 分支 master 为主分支,也是用于部署生产环境的分支,确保master分支稳定性 master ...

  • Git规范

    分支管理 分支命名 master 分支 master 为主分支,也是用于部署生产环境的分支,确保master分支稳...

  • Git 分支开发规范

    分支管理 分支命名 master 分支 master 为主分支,也是用于部署生产环境的分支,确保master分支稳...

  • gitsouce 使用笔记 合并分支

    本地分支 develop_lw develop master 远程分支develop master 在develo...

网友评论

      本文标题:码云双分支(master/develop)自动部署生产服/测试服

      本文链接:https://www.haomeiwen.com/subject/kmkdwctx.html