从 git hook 调用脚本

amd*_*mdc 2 git bash githooks

假设我在 server /hooks 文件夹中有两个脚本:

第一个启动日志记录并写入有关推送的基本信息:(接收后)

#!/bin/sh
read oldrev newrev refname
LOGFILE=post-receive.log
echo " push - Old SHA: $oldrev -> $newrev >> $LOGFILE
sh ./post-receive-logic >> $LOGFILE
Run Code Online (Sandbox Code Playgroud)

第二个进行实际部署:(接收后逻辑)

#!/bin/sh
cd ~/proj
pm2 stop ~/proj/main.js
git --git-dir ~/proj/.git --work-tree ~/proj pull
npm install
pm2 restart ~/proj/main.js
echo "finished"
Run Code Online (Sandbox Code Playgroud)

当我推送提交时,第二个脚本永远不会被调用:工作树没有更改,没有服务器被终止并重新启动,没有特定于第二个脚本的输出。

如果我./post-receive-logic手动调用,一切都会正常,服务器停止,文件被拉取,服务器再次启动。

我尝试不使用 来调用它sh,如下所示:

./post-receive-logic >> $LOGFILE
Run Code Online (Sandbox Code Playgroud)

但没有运气。

我究竟做错了什么?

tor*_*rek 5

练习:在 post-receive 挂钩操作期间,.(或)在哪里?$PWD

运行它时,它就是你的 $PWD任何东西。自动运行时怎么样?(查看接收系统的裸 git 存储库:您的$LOGFILE输出将位于该目录中。)

(您的帖子中的挂钩文本中缺少闭合引号,因此大概您手动复制了脚本的某些部分,也许还缺少其他内容。另外,请确保挂钩具有执行权限。但我的猜测是你被 git 运行钩子并$PWD设置为.git目录而不是钩子目录这一事实所困扰。)

(旁注:你的钩子可能不完整,因为它只读取一个oldrev newrev refname,但 agit push可以推送许多引用。通常你应该循环:while read oldrev newrev refname; do ...; done。如果你有一个预接收钩子拒绝推送多个引用,那么,这特定的接收后挂钩可能是正确的。)