github webhook git pull Permission denied

使用php-fpm 去拉去git 代码 git pull,

$cmd = "cd $target && git pull ";
$res = shell_exec($cmd);

提示 error: cannot open .git/FETCH_HEAD: Permission denied

直接 在linux 命令行 去执行git pull 成功.

原因在于没有文件权限. 

直接用who 去查看当前用户, 看上去是root. 

所以采取了在webhook文件里执行

$cmd = "echo yes | ssh-keygen -t rsa 2>&1" ;

得以查看到当前是apache用户 而非root用户, 再查看apache 所在的组为apache

所以去linux命令行执行

chown apache:apache /usr/local/nginx/html/da/.git

给该目录增加apache用户权限

最终可成功拉去代码 

Already up-to-date.

 

私有仓需要为apache用户添加ssh public key

用以下命令生成并在github setting 中添加

sudo -u apache ssh-keygen -t rsa

1. 先手动clone 下来 仓库

2. cd 进入项目目录并git pull , 以便生成.git/FETCH_HEAD

3. 

chown apache:apache /usr/local/nginx/html/dat/.git

 

 

 ---------------------------------------------------------------------------------------------------------

php hook 文件存放目录与仓库代码仓库目录都要开启

chown apache:apache /usr/local/nginx/html
chmod 775 /usr/local/nginx/html

否则会报无写入权限

 

 

 

posted @ 2019-06-21 14:41  龙鸿轩  阅读(1027)  评论(0编辑  收藏  举报