关于git webhook的使用(超级完整,超级详细)

  • Post author:
  • Post category:其他


首先创建仓库,git的基本使用我就略过了。我的博客里面有对应的文章。

一:服务器弄个网站

参考:

,网站下新建一个文件,名字随意,我的是 hook.php;

hook.php的代码如下

<?php
##要打开shell_exec函数,默认为禁用
$json = file_get_contents("php://input");
$data = json_decode($json,true);
##加一些验证,不要裸奔
##我这里就是弄了密码,webhook弄了个密码
if($data['password']==mypassword){
if (isset($data['ref']) && $data['total_commits_count']>0) {
    $res = PHP_EOL."pull start ---------------------------------------------".PHP_EOL;
    $res .= shell_exec("cd 项目所在目录 && git pull 2<&1");
    
##注释的地方我做的一些分支判断更新,根据自己的需求来,基本第一个就可以满足了。
    // if(strpos($data['ref'],'dev1')>0){
    //      $res .= shell_exec("cd 项目所在目录 &&  git stash && git pull origin dev1 && cd .git && chown -R www:www objects 2<&1");

    // }
    // elseif (strpos($data['ref'],'master')>0) {
    //      $res .= shell_exec("cd 项目所在目录 &&  git pull origin master && cd .git && chown -R www:www objects 2<&1 ");
    // }else{
        
    // }
    
    $res_log = '------------------------------------------------------------'.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("/www/wwwroot/hook.weilinit.com/".date('Y-m-d',time()).".txt", $res_log, FILE_APPEND);//写入日志到log文件中
}
}

 
 
 
//git webhook 自动部署脚本
//项目存放物理路径,第一次clone时,必须保证该目录为空
// $savePath = "/www/wwwroot/testweb/";
// $gitPath  = "https://gitee.com/channel_haixia/testhooks.git";//代码仓库
// $email = "294932451@qq.com";//用户仓库邮箱
// $name  = "channel_haixia";//仓库用户名,一般和邮箱一致即可
 
// $isClone = false;//设置是否已经Clone到本地,true:已经clone,直接pull,false:先clone.
 
// //如果已经clone过,则直接拉去代码
// if ($isClone) {
//     $requestBody = file_get_contents("php://input");
//     if (empty($requestBody)) {
//         die('send fail');
//     }
 
//     //解析Git服务器通知过来的JSON信息
//     $content = json_decode($requestBody, true);
//     //若是主分支且提交数大于0
//     if ($content['ref']=='refs/heads/master' && $content['total_commits_count']>0) {
 
//         $res = PHP_EOL."pull start --------".PHP_EOL;
//         $res .= shell_exec("cd {$savePath} && git pull {$gitPath}");//拉去代码
//         $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:';
//         $res_log .= $res.PHP_EOL;
//         $res_log .= "pull end --------".PHP_EOL;
//         file_put_contents("/www/wwwroot/hook.weilinit.com/git-webhook_log.txt", $res_log, FILE_APPEND);//写入日志到log文件中
//     }
// }else {
//     $res = "clone start --------".PHP_EOL;
//     //注:在这里需要设置用户邮箱和用户名,不然后面无法拉去代码
//     $res .= shell_exec("git config --global user.email {$email}}").PHP_EOL;
//     $res .= shell_exec("git config --global user.name {$name}}").PHP_EOL;
//     $res .= shell_exec("git clone {$gitPath} {$savePath}").PHP_EOL;
//     $res .= "clone end --------".PHP_EOL;
//     file_put_contents("/www/wwwroot/hook.weilinit.com/git-webhook_log1.txt", $res, FILE_APPEND);//写入日志到log文件中
// }

二:码云wehbook添加钩子

三:点击一下测试,看会不会生成日志文件。有则证明钩子没问题了,没有就要自己找下问题了。

四: 设置免密

git config --global credential.helper store

然后再次在项目下git pull一下,输入一次账号密码,就可以了。

五:git pull文件权限变更问题

#!/bin/sh
pwd
echo "This is post-checkout hook"
chmod -R 755 ./* && chown -R www:www ./*

#然后给文件可执行权限
chmod +x post-checkout

#git 忽略文件检查权限
git config core.filemode false执行该命令后即可

这样就能解决每次权限都变为root的问题,如果此方法解决不了这个问题,可以用下面方法

还有一种,在钩子命令里面,后面追加  chown www:www  网站目录/或者文件

六:尝试提交一次代码,触发钩子。出现问题(fatal: could not read Username for ‘https://gitee.com’: No such device or address),是因为没设置密码

进入自己的项目

cd .git && vi config


[core]
        repositoryformatversion = 0
        filemode = false
        bare = false
        logallrefupdates = true
[remote "origin"]
        url = https://username:passwd@gitee.com/channel_haixia/channel_dist.git
        fetch = +refs/heads/*:refs/remotes/origin/*
[branch "dev1"]
        remote = origin
        merge = refs/heads/dev1

将url设置一下自己的账号密码

七:可能出现问题(.git/info/refs not valid: is this a git repository?)

因为你的账号密码中有特殊字符,Linux特殊字符需要用urlencode转义。比如的就是邮箱 294932451@qq.com   这里的@要进行转义

所以我的账号要改成  294932451%40qq.com  这样就可以了。



版权声明:本文为qq_31164125原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。