github hooks钩子的搭建(代码同步功能,webhooks)

钩子是什么,就是将本地代码推送至github后自动将代码同步至服务器。

搭建步骤

  • 在服务器查找运行php的用户,为他生成deploy-key,保存在github上
  • 在服务器拉取项目仓库
  • 在服务器项目根目录下建立代码同步的deploy.php
  • github上设置仓库的webhooks
  • 本地拉取仓库提交代码测试

1.设置deploy-key

查找php是什么用户运行的

ps aux | grep php

我的显示是www用户 但是查看所有用户

cat  /etc/passwd | grep www

查找出来是www-data
查找用户组

cat /etc/group | grep www

查找出来也是www-data
所以我判定我的php执行用户是www-data 属于www-data用户组

配置服务器git:

git config --global user.name "name"
git config --global user.email "email" 

执行命令

sudo -Hu www-data ssh-keygen -t rsa

生成www-data用户的deploy-key(为什么要给www-data用户生成key,因为在本地提交代码时,github会请求服务器的php文件从而同步服务器代码)

这时候报错

github hooks钩子的搭建(代码同步功能,webhooks)_第1张图片
报错.png

报错原因是无法在目录下创建目录以及找不到目录
原来www目录属于root用户组 权限是rwxr-xr-x


github hooks钩子的搭建(代码同步功能,webhooks)_第2张图片
image.png

我们需要进入www目录创建.ssh目录后更改目录用户权限

chown -R  www-data:www-data ./.ssh/

这时候再次执行命令 sudo -Hu www-data ssh-keygen -t rsa ,生成deploy-key。将生成的id_rsa.pub文件内容,添加到项目中的 deploy keys中。

打开github上的项目仓库,给项目添加deploy-key

github hooks钩子的搭建(代码同步功能,webhooks)_第3张图片
image.png

2. 在服务器上拉取自己的仓库(使用ssh方式)

3.建立代码同步的deploy.php

在仓库根目录下建立deploy.php文件

write_log('send fail from github is empty');exit;
        }else{
            //获取github推送代码时经过哈希加密密钥的值
            $signature = $_SERVER['HTTP_X_HUB_SIGNATURE'];
        }
        
        if (strlen($signature) > 8 && $this->isFromGithub($requestBody,$signature)) {
            //验证密钥是否正确,如果正确执行命令。
            $res = shell_exec("cd /var/www/html/ball_mation/ball_mation/ &&                         
git pull 2>&1"); // 项目目录
            $res_log = "\n -------------------------".PHP_EOL;
            $res_log .= '['.$payload['commits'][0]['author']['name'] . ']' . '向[' . $payload['repository']['name'] . ']项目的' . $payload['ref'] . '分支'.$_SERVER['X-GitHub-Event'].'了代码。commit信息是:'.$payload['commits']['message'].'。详细信息如下:' . PHP_EOL;
            $res_log .= $res.PHP_EOL;
            http_response_code(200);
            $this->write_log($res_log);
        }else{
            $this->write_log('git 提交失败!');
            abort(403);
        }
    }
    
    public function isFromGithub($payload,$signature)
    {
        //$hash是github的密钥。然后与本地的密钥做对比。
        list($algo, $hash) = explode("=", $signature, 2); 
        return $hash === hash_hmac($algo, $payload, $this->serect);
    }
 
    public function write_log($data)
    {
        // 此处加载日志类,用来记录git push信息,可以自行写。    
        file_put_contents('./push_push.log', $data.PHP_EOL, FILE_APPEND|LOCK_EX);
    }
}
 
$deploy = new Deployment();
 
if($_SERVER['REQUEST_METHOD'] == 'POST'){
    //触发此代码的时候,git是以post方式触发
    $signature = $deploy->deploy();
}

代码中的$serectshell_exec()函数中的项目路径需要更改为自己的

4.设置仓库的webhooks

github hooks钩子的搭建(代码同步功能,webhooks)_第4张图片
image.png

填写自己的serect跟deploy.php访问url即可,传输方式选择json
github hooks钩子的搭建(代码同步功能,webhooks)_第5张图片
image.png

5.本地测试
拉取仓库代码在本地修改提交后,检查服务器代码是否同步,若同步即为成功

你可能感兴趣的:(github hooks钩子的搭建(代码同步功能,webhooks))