之前用git init初始化服务端的git仓库,在本地推送更新后发现一个问题,当我在本地推送更新到远程仓库后,我在远程仓库也就是服务端查看文件,发现文件并没有更改,然后我git status了一下,发现推送的更新在暂存区,需要我检出更新git checkout -f 或着释放暂存区的更新git stash一下,这样每次更新我都要在服务器端进行检出更新的操作,其实更新已经推送到服务端远程仓库了,如果我将更新推送到另一个分支,然后再服务器端切换到对应的分支,也是可以看到更新的。那么怎么将推送到当前分支的更新马上检出而不用自己在服务器端进行检出操作呢。这里可以使用hooks钩子来设置。
先进入到仓库的.git/hooks/文件目录下,然后新建一个post-receive文件,并写入配置信息
cd .git/hooks
cat > post-receive
#!/bin/sh
unset GIT_DIR
cd ..
git checkout -f
按ctrl+D保存。
或者将hooks文件目录下的post-update.sample文件更名为post-update,然后打开文件,
在exec git update-server-info这一行代码前面加上一个# 号,即改成
#exec git update-server-info
然后再在下面加上
unset GIT_DIR
cd ..
git checkout -f
保存一下
这样我们在本地再推送一次更新,可以在服务端查看,发现文件已经更新了,不用再手动检出更新了。