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?
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.
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:
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.
Just close the Visual Studio (or Unity) and try to add those files again.
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:
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:
To test that everything is fixed, execute the following:
Quickly followed by executing:
You will see that everything has been added to the git repository without any need to test / fiddle around with anything any further.
Looking at the Git source code (
sha1_file.c
, functionmove_temp_to_file()
) it looks like Git is failing to rename a temporary file named/opt/www/.git/objects/3f/tmp_obj_XXXXXX
(whereXXXXXX
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:
git config core.sharedRepository 0664
(seegit help config
for details) to ensure that newly created directories and files have proper permissions for all users of the repository.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:
Be sure to run the above commands the same user that experienced the error.
chown
ing andchmod
ing the objects directory.