欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

gitlab-php-webhook - gitlab webhook php exec 调用 shell 脚本。shell 脚本中调用 git pull 命令无法执行。

程序员文章站 2022-06-09 11:30:10
...
情况如下:
我在ubuntu server 14.04 上面安装了gitlab,来托管项目代码。然后想通过gitlab的web hook 功能来做测试服务器代码自动化更新代码功能。现在遇到一个问题:就是我客户端在master分支上面push代码的时候,我测试服务器的代码目录并没有自动更新。我的shell脚本如下:

!/bin/bash
echo 'haha:::==' >> /tmp/wtz.log

cd /srv/www/bfar-ng

echo 'my name is gitlab'>> /tmp/wtz.log

git checkout master

git pull origin master >> /srv/www/deploy/info.log
git pull origin master

echo 'you are so cute!!!::'>> /tmp/wtz.log

查看wtz.log 后发现echo 'my name is gitlab'>> /tmp/wtz.log 和echo 'you are so cute!!!::'>> /tmp/wtz.log 都成功写入到日志文件中。但测试服务器项目原代码就是没有自动更新。除非手动git pull origin master 或者 在终端里面直接执行 上面的shll。它才会更新。
ps:项目目录我都设置777权限了。

求教为啥无法执行git命令。

回复内容:

情况如下:
我在ubuntu server 14.04 上面安装了gitlab,来托管项目代码。然后想通过gitlab的web hook 功能来做测试服务器代码自动化更新代码功能。现在遇到一个问题:就是我客户端在master分支上面push代码的时候,我测试服务器的代码目录并没有自动更新。我的shell脚本如下:

!/bin/bash
echo 'haha:::==' >> /tmp/wtz.log

cd /srv/www/bfar-ng

echo 'my name is gitlab'>> /tmp/wtz.log

git checkout master

git pull origin master >> /srv/www/deploy/info.log
git pull origin master

echo 'you are so cute!!!::'>> /tmp/wtz.log

查看wtz.log 后发现echo 'my name is gitlab'>> /tmp/wtz.log 和echo 'you are so cute!!!::'>> /tmp/wtz.log 都成功写入到日志文件中。但测试服务器项目原代码就是没有自动更新。除非手动git pull origin master 或者 在终端里面直接执行 上面的shll。它才会更新。
ps:项目目录我都设置777权限了。

求教为啥无法执行git命令。

之前正好搞过这个,主要还是权限的问题,最好用 sudo git pull origin master, 然后参照这个 http://*.com/questions/3173201/sudo-in-php-exec 将 PHP 的执行用户加到 sudo 免密输入的列表中...

git pull origin master试试

已搞定了,www-data 的权限问题。

正好也碰到这个问题 。
现在是centos服务器,用国内的coding.net作托管的私有项目。和你情况一样
现是是webhook提交到一个php,然后通过这个php执一个shell。
php里代理是这样的:echo shell_exec('sh ./webhook.sh');
shell是这样的 `#!/bin/sh
echo >> ./_n.log
git pull`

只能去linux里手动git pull,日志也能输出成功
为什么这个不能执行