半自動化部署webHook鉤子配置

半自動化部署(鉤子)

碼云-logo.png

這里沒有用github宋欺,因為github私有庫是收費的蛤织,并且github上的爬蟲太多。有一些私有的東西不方便不翩,所以選擇碼云兵扬,它的私有庫不收錢不限制,還是中文的口蝠,所以選擇用碼云來操作器钟。(項目成熟之后再開源)

  • 先設(shè)置 WebHook


    WebHooks設(shè)置.png

這里記得設(shè)置一下,二級域名妙蔗,用來鉤子的調(diào)用傲霸。

  • 服務(wù)器配置域名指向鉤子的【測試】文件
<?php
        // echo shell_exec('whoami');die;  # 測試web訪問用戶組 (隱藏的坑)
        $result = shell_exec("cd /home/wwwroot/blog && git pull origin master && echo 'shell_success'");
        file_put_contents('test.txt', 'success', FILE_APPEND);
        file_put_contents('test.txt', '================', FILE_APPEND);
        var_dump($result);
        echo 'success';
  • 正式鉤子,寫入提交記錄log日志代碼:
<?php
    // 項目存放物理路徑
    $savePath = "/home/wwwroot/blog";
    // 代碼倉庫
    $gitPath  = "git@gitee.com:xxxxxxxx/blog.git";

    // 獲取鉤子post參數(shù)
    $requestBody = file_get_contents("php://input");
    if (empty($requestBody)) {
        die('send fail');
    }

    // 解析Git服務(wù)器通知過來的JSON信息
    $content = json_decode($requestBody, true);

    // 若是主分支且i && 提交數(shù)大于0
    if ($content['ref'] == 'refs/heads/master' && $content['total_commits_count'] > 0) {
        $res = PHP_EOL . "pull start ------------------"; // PHP_EOL 代表 \r\n 換行
        $res .= ' <' . implode('', array_column($content['commits'], 'message')) . '>' . PHP_EOL; // commit 版本名稱

        // 拉取代碼
        $res .= shell_exec("cd {$savePath} && git pull {$gitPath}");

        // 日志編寫
        $res_log = PHP_EOL . '>>>>>>>>>>>>========================================<<<<<<<<<<<<' . PHP_EOL . PHP_EOL;
        $res_log .= '【' . $content['user_name'] . '】在【' . date('Y-m-d H:i:s');            // 誰在什么時間
        $res_log .= '】向【' . $content['repository']['name'] . '】項目的【' . $content['ref'] . '】'; // 向誰的什么
        $res_log .= '分支push了' . $content['total_commits_count'] . '個commit:' . PHP_EOL;  // 怎么做了什么事情
        $res_log .= $res; // 放入git記錄代碼
        $res_log .= "pull end --------------------" . PHP_EOL;

        // 寫入日志到log文件中
        file_put_contents("git-webhook_log.txt", $res_log, FILE_APPEND);

        echo 'Success';die;
    }

    echo 'Error';die;
  • 正式鉤子后的日志樣式
>>>>>>>>>>>>========================================<<<<<<<<<<<<

【SuperHaoHao】在【2018-12-26 16:02:22】向【Laravel55-LTS】項目的【refs/heads/master】分支push了1個commit:

pull start ------------------ <- test: 測試正式版Hook腳本-完成樣式OK的v3>
Updating 203c107..c292f87
Fast-forward
 app/Http/Controllers/Applets/v1/User/LoginController.php | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
pull end --------------------
{"ref":"refs/heads/master","before":"729aa4bbffadd38c10049e1bac4b21d06e32db48","after":"fbd3204cd86b774711c08501141775f06b0690f3","total_commits_count":1,"commits_more_than_ten":false,"created":false,"deleted":false,"compare":"https://gitee.com/XuChen****/blog/compare/729aa4bbffadd38c10049e1bac4b21d06e32db48...fbd3204cd86b774711c08501141775f06b0690f3","commits":[{"id":"fbd3204cd86b774711c08501141775f06b0690f3","tree_id":"386c9c4a600ec6955ad4b624ddb7f55741f31a96","message":"- test: 測試正式版Hook腳本v4","timestamp":"2018-12-26T15:13:47+08:00","url":"https://gitee.com/XuChen****/blog/commit/fbd3204cd86b774711c08501141775f06b0690f3","author":{"time":"2018-12-26T15:13:47+08:00","id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"committer":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"distinct":true,"added":[],"removed":[],"modified":["app/Http/Controllers/Applets/v1/User/LoginController.php"]}],"head_commit":{"id":"fbd3204cd86b774711c08501141775f06b0690f3","tree_id":"386c9c4a600ec6955ad4b624ddb7f55741f31a96","message":"- test: 測試正式版Hook腳本v4","timestamp":"2018-12-26T15:13:47+08:00","url":"https://gitee.com/XuChen****/blog/commit/fbd3204cd86b774711c08501141775f06b0690f3","author":{"time":"2018-12-26T15:13:47+08:00","id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"committer":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"distinct":true,"added":[],"removed":[],"modified":["app/Http/Controllers/Applets/v1/User/LoginController.php"]},"repository":{"id":4613621,"name":"Laravel55-LTS","path":"blog","full_name":"SuperHaoHao/Laravel55-LTS","owner":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****","login":"XuChen****","avatar_url":"https://gitee.com/uploads/51/1178551_XuChen****.png?1509607253","html_url":"https://gitee.com/XuChen****","type":"User","site_admin":false},"private":true,"html_url":"https://gitee.com/XuChen****/blog","url":"https://gitee.com/XuChen****/blog","description":"","fork":false,"created_at":"2018-10-29T15:28:53+08:00","updated_at":"2018-12-26T14:50:07+08:00","pushed_at":"2018-12-26T14:50:07+08:00","git_url":"git://gitee.com/XuChen****/blog.git","ssh_url":"git@gitee.com:XuChen****/blog.git","clone_url":"https://gitee.com/XuChen****/blog.git","svn_url":"svn://gitee.com/XuChen****/blog","git_http_url":"https://gitee.com/XuChen****/blog.git","git_ssh_url":"git@gitee.com:XuChen****/blog.git","git_svn_url":"svn://gitee.com/XuChen****/blog","homepage":null,"stargazers_count":0,"watchers_count":1,"forks_count":0,"language":"PHP","has_issues":true,"has_wiki":true,"has_pages":false,"license":null,"open_issues_count":0,"default_branch":"master","namespace":"XuChen****","name_with_namespace":"SuperHaoHao/Laravel55-LTS","path_with_namespace":"XuChen****/blog"},"project":{"id":4613621,"name":"Laravel55-LTS","path":"blog","full_name":"SuperHaoHao/Laravel55-LTS","owner":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****","login":"XuChen****","avatar_url":"https://gitee.com/uploads/51/1178551_XuChen****.png?1509607253","html_url":"https://gitee.com/XuChen****","type":"User","site_admin":false},"private":true,"html_url":"https://gitee.com/XuChen****/blog","url":"https://gitee.com/XuChen****/blog","description":"","fork":false,"created_at":"2018-10-29T15:28:53+08:00","updated_at":"2018-12-26T14:50:07+08:00","pushed_at":"2018-12-26T14:50:07+08:00","git_url":"git://gitee.com/XuChen****/blog.git","ssh_url":"git@gitee.com:XuChen****/blog.git","clone_url":"https://gitee.com/XuChen****/blog.git","svn_url":"svn://gitee.com/XuChen****/blog","git_http_url":"https://gitee.com/XuChen****/blog.git","git_ssh_url":"git@gitee.com:XuChen****/blog.git","git_svn_url":"svn://gitee.com/XuChen****/blog","homepage":null,"stargazers_count":0,"watchers_count":1,"forks_count":0,"language":"PHP","has_issues":true,"has_wiki":true,"has_pages":false,"license":null,"open_issues_count":0,"default_branch":"master","namespace":"XuChen****","name_with_namespace":"SuperHaoHao/Laravel55-LTS","path_with_namespace":"XuChen****/blog"},"user_id":1178551,"user_name":"SuperHaoHao","user":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"pusher":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****"},"sender":{"id":1178551,"name":"SuperHaoHao","email":"61****123@qq.com","username":"XuChen****","user_name":"XuChen****","url":"https://gitee.com/XuChen****","login":"XuChen****","avatar_url":"https://gitee.com/uploads/51/1178551_XuChen****.png?1509607253","html_url":"https://gitee.com/XuChen****","type":"User","site_admin":false},"enterprise":null,"hook_name":"push_hooks","password":""}

Hook - 坑

正常來說上面的流程已經(jīng)結(jié)束了眉反,但是... 其實肯定能中獎下面的這些問題

  • 解除 php.ini 禁用的 shell_exec() 函數(shù)

【Lnmp的php.ini路徑】# vim /usr/local/php/etc/php.ini

php.ini.png

  • 無法執(zhí)行 git 的所有命令昙啄,比如說 git pull origin master (但是可以執(zhí)行cd /home/wwwroot/blog),并且無法切換 su www 用戶
切換www用戶.png

Error-www操作git.png

解決 www 權(quán)限的各種問題

【查看用戶組】  cat /etc/passwd
【修改nologin】 vim /etc/passwd   把 /sbin/nologin 改為 /bin/bash
【使用www登陸】 su www
【修改文件屬組】 chown -R www:www blog/
  • 上面正式版代碼寸五,有寫入文件梳凛,記得給文件寫入權(quán)限
【修改文件權(quán)限】chmod -R 755 git-webhook_log.txt
  • 需要先手動拉取一遍代碼(因為必須是.ssh)
www用戶操作git.png
  • 附上我16遍鉤子的 git commit 圖 # emmmmmmm
commitList.png

emmmmm。梳杏。韧拒。。秘狞。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末叭莫,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子烁试,更是在濱河造成了極大的恐慌雇初,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件减响,死亡現(xiàn)場離奇詭異靖诗,居然都是意外死亡,警方通過查閱死者的電腦和手機支示,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進店門刊橘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人颂鸿,你說我怎么就攤上這事促绵。” “怎么了?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵败晴,是天一觀的道長浓冒。 經(jīng)常有香客問我,道長尖坤,這世上最難降的妖魔是什么稳懒? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮慢味,結(jié)果婚禮上场梆,老公的妹妹穿的比我還像新娘。我一直安慰自己纯路,他們只是感情好或油,可當我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著驰唬,像睡著了一般装哆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上定嗓,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天蜕琴,我揣著相機與錄音,去河邊找鬼宵溅。 笑死凌简,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的恃逻。 我是一名探鬼主播雏搂,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼寇损!你這毒婦竟也來了凸郑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤矛市,失蹤者是張志新(化名)和其女友劉穎芙沥,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浊吏,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡而昨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了找田。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片歌憨。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖墩衙,靈堂內(nèi)的尸體忽然破棺而出务嫡,到底是詐尸還是另有隱情甲抖,我是刑警寧澤,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布心铃,位于F島的核電站惧眠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏于个。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一暮顺、第九天 我趴在偏房一處隱蔽的房頂上張望厅篓。 院中可真熱鬧,春花似錦捶码、人聲如沸羽氮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽档押。三九已至,卻和暖如春祈纯,著一層夾襖步出監(jiān)牢的瞬間令宿,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工腕窥, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留粒没,地道東北人。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓簇爆,卻偏偏與公主長得像癞松,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子入蛆,可洞房花燭夜當晚...
    茶點故事閱讀 44,864評論 2 354