git: Unable to index file - permission denied

2019-01-24 00:20发布

问题:

Only for one file, I am getting the following error:

error: unable to write sha1 filename /opt/www/.git/objects/3f/ce3587c54a8be14c69b08c6b01f94949b11b47: Permission denied

error: wp/wp-admin/css/theme-install.dev.css: failed to insert into database
fatal: unable to index file wp/wp-admin/css/theme-install.dev.css

I checked my permissions on the file in question, the .git objects directory in question, and .git itself. I can add any other files except for this one. I could stat/r/w/touch the file, and touching did not help. The permissions are all correct.

Is this some crazy bug?

回答1:

Looking at the Git source code (sha1_file.c, function move_temp_to_file()) it looks like Git is failing to rename a temporary file named /opt/www/.git/objects/3f/tmp_obj_XXXXXX (where XXXXXX is six random characters) to /opt/www/.git/objects/3f/ce3587c54a8be14c69b08c6b01f94949b11b47. This can happen if you don't have permission to delete files in /opt/www/.git/objects/3f.

Some things to try:

  • If multiple users accessing the Git repository, you may need to run something like git config core.sharedRepository 0664 (see git help config for details) to ensure that newly created directories and files have proper permissions for all users of the repository.
  • Try running rm -f /opt/www/.git/objects/3f/tmp_obj_* and see if that makes the problem go away.
  • See if you can reproduce the problem outside of Git by doing the following:

    mkdir -p /opt/www/.git/objects/3f
    cd /opt/www/.git/objects/3f
    rm -f tmp_obj_* ce3587c54a8be14c69b08c6b01f94949b11b47
    echo "testing" >tmp_obj_abcdefg
    mv tmp_obj_abcdef ce3587c54a8be14c69b08c6b01f94949b11b47
    rm -f tmp_obj_abcdefg
    

    Be sure to run the above commands the same user that experienced the error.

  • Try recursively chowning and chmoding the objects directory.


回答2:

If you are using visual studio or something similar that is generating the mdf file, simply close VS & retry your git command again. This time it should work.

To save constantly closing & reopening, you should add references into .gitignore file in the project root. For example, if it is a database causing the issue, add the following:

# SQL Server files
*.mdf
*.ldf


回答3:

You don't have permission to write in /opt/www/.git/objects/3f.

The quickest solution is to use the sudo command to execute your command with root privileges.

sudo <Your git command>

Solved it for me.



回答4:

Something has gone awry in your git repository likely caused by an external process creating a file or directory which is owned by a user other than the current user.

This error is common when using Docker, and a service in your docker-compose.yml file has a locally mounted volume which was created using a different user to that of the local machine user.

If this is the first time that this error has occurred, execute the below on your working directory to change the ownership of files and folders back to the logged in user:

sudo chown -R ${USER}:${USER} .

If this is not the first time you have encountered this issue, i.e. you have already committed and pushed files and folders that are owned by another user, then the above alone will not rectify the situation, as well as executing the above command - you will need to carry out the following instructions.

By far, the quickest fix is to execute the following from your root project directory which holds your git repository:

sudo chown -R ${USER}:${USER} .git/objects

To test that everything is fixed, execute the following:

git add .

Quickly followed by executing:

git status

You will see that everything has been added to the git repository without any need to test / fiddle around with anything any further.



回答5:

Just close the Visual Studio (or Unity) and try to add those files again.



回答6:

I was having this problem on my bare origin repository when the permissions were root:git 770, apparently I had to change it to 771, even though my user is in the git group. I suspect perhaps git is perhaps either not acl-aware, or not so compatible with secondary groups, as the git group was one of my secondary groups in this case.



标签: git indexing add