当前位置:Gxlcms > PHP教程 > gitlab-php-webhook-gitlabwebhookphpexec调用shell脚本。shell脚本中调用gitpull命令无法执行。

gitlab-php-webhook-gitlabwebhookphpexec调用shell脚本。shell脚本中调用gitpull命令无法执行。

时间:2021-07-01 10:21:17 帮助过:41人阅读

情况如下:
我在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://stackoverflow.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,日志也能输出成功
为什么这个不能执行

人气教程排行