在远程服务器中,我设置了一个接收后的钩子,以便对我的存储库进行git检出:

#!/bin/sh
GIT_WORK_TREE=/var/www/<website> git checkout -f

但是当我从本地机器推送到服务器中的git存储库时,我得到了以下错误消息:

remote: error: unable to unlink old '<file>' (Permission denied)

这将出现多次,几乎每个文件都有一个错误消息。

但是我有一个README.txt文件,我可以使用git更改,以下是它的权限:

-rw-r--r--  1 <serverusername>  <serverusername>  2939 Aug  2 10:58 README.txt

但是其他具有完全相同所有者和相同权限的文件,会给我这个错误。

在另一个网站的另一个本地存储库中,我有我的本地机器用户名作为所有者的文件,当我推送到远程服务器时,它尊重文件的远程服务器所有者,就像一个魅力。

显然这似乎是一个权限相关的错误,但我找不到一种方法来修复它,有什么建议吗?


当前回答

拉扯可能会造成局部变化。

添加您的未跟踪文件:

转到添加 。

储备的变化。

git 存储

删除本地更改。

Git藏匿点

在sudo的允许下拉

须藤git拉远程分支

其他回答

如果您正在使用任何IDE,最有可能的问题是该文件已被某些进程使用。比如你的tomcat可能正在使用这个文件。尝试识别特定的进程并关闭它。这应该能解决你的问题。

git reset --hard

为我工作

在windows上最简单的方法:

1)进入任务管理器

2)结束文件资源管理器任务

3)在任务管理器中,进入“文件”页签,然后点击“运行新任务”

4)在弹出窗口中写入explorer.exe

问题解决。

我得到这个错误,和其他奇怪的git错误,当我有一个服务器运行(在Intellij)。停止服务器并重新尝试git命令经常为我修复它。

在我的例子中,我必须为文件夹上的所有组成员授予读、写和执行权限。这是因为Git用户是组成员,而不是所有者。

sudo chmod -R g=rwx <folder>