1. 程式人生 > 實用技巧 >php專案使用git的webhooks實現自動部署

php專案使用git的webhooks實現自動部署

前言

在專案開發中使用git進行程式碼的管理,每次完成更改上傳程式碼後,還需要登入伺服器將程式碼拉取下來.現在git伺服器(gitee/gitlab/github)都會有Webhooks功能,以實現在向git倉庫推送/合併等時機讓伺服器自動拉取新程式碼.

流程說明

使用Webhooks後,整個上傳部署流程如下:

伺服器端操作

webhook指令碼建立

關於推送的post資料格式,參考碼雲的《WebHook 推送資料格式說明》.根據這個引數格式編寫php的指令碼檔案如下:

    <?php
    /**
      *git webhook 自動部署指令碼
      */
    //接收post引數
    $requestBody = file_get_contents("php://input");
    if (empty($requestBody)) {
        exit('data null');
    }
    $content = json_decode($requestBody, true);
    
    //驗證密碼,驗證碼雲上配置的webhook密碼
    //if (empty($content['password']) || $content['password'] != 'password') //{
    //	exit('password error');
    //}
    
    $path = "/var/www/test/"; //專案存放物理路徑
    //判斷master分支上是否有提交
    if ($content['ref']=='refs/heads/master' && $content['total_commits_count']>0) {
        $res = shell_exec("cd {$path} && git pull origin master 2>&1");//當前為www使用者
        $res_log = '------------------------->'.PHP_EOL;
        $res_log .= '使用者'. $content['user_name'] . ' 於' . date('Y-m-d H:i:s') . '向' . $content['repository']['name'] . '專案的' . $content['ref'] . '分支push了' . $content['total_commits_count'] . '個commit:' . PHP_EOL;
        $res_log .= $res.PHP_EOL;
        $x = file_put_contents("git_webhook_log.txt", $res_log, FILE_APPEND);//追加寫入日誌檔案
        if ($x) {
        	echo 'true-';
        } else {
        	echo 'false-';
        }
    }
    echo 'done';

伺服器使用者設定

由於是通過url請求php編寫的指令碼執行操作,所以開啟nginx.conf檔案檢視執行使用者,預設為www,也可在任意php檔案中新增程式碼: echo system("whoami");,然後訪問檔案檢視php執行使用者.
確定使用者後,開啟/etc/passwd檔案檢視該使用者的資訊,如下:

    www:x:1000:1000::/var/www:/bin/bash

其格式和具體含義如下:

使用者名稱:口令:使用者標識號:組標識號:註釋性描述:主目錄:登入Shell

其中要注意"主目錄"這一項,若後續操作提示該目錄不存在或錯誤,開啟此檔案修改.
接著依次執行下面三條命令:

    su - www //切換到www使用者
    ssh-keygen -t rsa -C "[email protected]" //以郵箱為名建立rsa金鑰
    cat /var/www/.ssh/id_rsa.pub //檢視rsa公鑰並複製,.ssh所在目錄即上面所提"主目錄"

git倉庫操作

配置部署公鑰

在碼雲上開啟專案倉庫,依次點選[管理]=>[部署公鑰管理]=>[新增公鑰].將上面複製的id_rsa.pub公鑰新增進來.完成後在伺服器上執行命令:

    ssh -T [email protected]

首次使用會提示the authenticity of host 'gitee.com...需要輸入yes確認並新增主機到本機SSH可信列表.若返回 Hi XXX! You've successfully authenticated, but Gitee.com does not provide shell access. 內容,則證明新增成功.新增成功後,當前賬戶www就可以使用SSH協議對倉庫進行克隆/拉取等操作了.

新增webhook

在碼雲上開啟專案倉庫,依次點選[管理]=>[WebHooks]=>[新增],填寫webhook的php指令碼地址,如有需要填寫webhook密碼/金鑰(金鑰需要再新增驗籤),如下圖

到此,完成配置,之後的push操作可在碼雲[WebHooks 管理]中檢視自動部署請求記錄資訊.也可檢視伺服器中的git_webhook_log.txt部署日誌(php指令碼中寫入,不需要可註釋掉).


個人網站地址: https://www.zhuyilong.我愛你/tech/php_git_webhook.html