git post-receive 未执行
我已经设置了以下 post-receive:
$ cat .git/hooks/post-receive
#!/bin/env sh
git checkout -f
,它是可执行的:
$ l .git/hooks/post-receive
-rwx--x--x 1 nils nils 30 11. Jan 13:17 .git/hooks/post-receive
所以当我从本地计算机推送到它时,它应该签出并包含我在本地所做的更改。但事实并非如此:
本地:
$ cat > testfile
hello world
$ git add testfile && git commit -m "added testfile" && git push production master
[master 9f5232d] added testfile
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 testfile
Counting objects: 4, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 290 bytes, done.
Total 3 (delta 1), reused 0 (delta 0)
To ssh://[…]/
88ce501..9f5232d master -> master
随后在远程计算机上:
$ git status --short
D testfile
所以它的工作树中没有测试文件 有
$ git checkout -f
$ git status
# On branch master
nothing to commit (working directory clean)
什么想法可能是错误的吗?
I have setup the following post-receive:
$ cat .git/hooks/post-receive
#!/bin/env sh
git checkout -f
which is executable:
$ l .git/hooks/post-receive
-rwx--x--x 1 nils nils 30 11. Jan 13:17 .git/hooks/post-receive
So when I push into it from my local machine it should checkout and have the changes I made locally. But that is not the case:
Local:
$ cat > testfile
hello world
$ git add testfile && git commit -m "added testfile" && git push production master
[master 9f5232d] added testfile
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 testfile
Counting objects: 4, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 290 bytes, done.
Total 3 (delta 1), reused 0 (delta 0)
To ssh://[…]/
88ce501..9f5232d master -> master
Afterwards on the remote machine:
$ git status --short
D testfile
So it does not have the testfile in its working tree
$ git checkout -f
$ git status
# On branch master
nothing to commit (working directory clean)
Any Ideas what could be possibly wrong?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
更多
发布评论
评论(1)
您应该设置 GIT_WORK_TREE 以确保结帐在正确的位置完成:
不要忘记
chmod +x
该脚本并确保推送的用户有权运行 checkout 命令。You should set the GIT_WORK_TREE to be sure the checkout is done in the right place:
Do not forget to
chmod +x
the script and be sure that the user pushing has the rights to run the checkout command.