>PROBLEM
An attempt to update the local repository using pull and push fails returning the following message:
...
! [remote rejected] master -> master (unpacker error)
remote: error: inflate: data stream error (unknown compression method)
remote: error: unable to unpack a798a0e5cdf6ab498ea641c3d8d7b5763dc901d0 header
remote: fatal: loose object a798a0e5cdf6ab498ea641c3d8d7b5763dc901d0 (stored in //10.0.0.7/j/git/code/objects/a7/98a0e5cdf6ab498ea641c3d8d7b5763dc901d0) is corrupt
error: remote unpack failed: unpack-objects abnormal exit
$git checkout -f HEAD
error: unable to read sha1 file of css_grid.diff (a798a0e5cdf6ab498ea641c3d8d7b5763dc901d0)
error: inflate: data stream error (invalid distance too far back)
error: corrupt loose object '8711ded8021f5a4f59db8899e25c30655e80e803'
fatal: loose object 8711ded8021f5a4f59db8899e25c30655e80e803 (stored in .git/objects/87/11ded8021f5a4f59db8899e25c30655e80e803) is corrupt
Another attempt to clone the repository also fails, returning:
git clone \\10.0.0.7\j\git\code
Cloning into 'code'...
done.
error: unable to read sha1 file of css_grid.diff (a798a0e5cdf6ab498ea641c3d8d7b5763dc901d0)
error: inflate: data stream error (invalid distance too far back)
error: corrupt loose object '8711ded8021f5a4f59db8899e25c30655e80e803'
fatal: loose object 8711ded8021f5a4f59db8899e25c30655e80e803 (stored in L:/transp/1___downloads/code/.git/objects/87/11ded8021f5a4f59db8899e25c30655e80e803) is corrupt
warning: Clone succeeded, but checkout failed.
You can inspect what was checked out with 'git status'
and retry the checkout with 'git checkout -f HEAD'
>SOLUTION
The attempt to clone was used to make sure that the corruption happened on remote repository.
After some research, the best documentation to fix this was "Recovering from repository corruption" but also comments that against corruption the best alternative is a backup.
Although having backups, it didn't help in this case because the backups also had exactly the same issue since a backup is a copy. Because it is not an incremental copy, the backup was useless.
After some research, the best documentation to fix this was "Recovering from repository corruption" but also comments that against corruption the best alternative is a backup.
Although having backups, it didn't help in this case because the backups also had exactly the same issue since a backup is a copy. Because it is not an incremental copy, the backup was useless.
SAVING THE PAST
Faster than trying to fix it for the sake of time saving, the corrupted remote repository was renamed from "code" to "code_corrupted_200220" and saved its copy.
ren code code_corrupted_200220
or
mv code code_corrupted_200220 (linux)
This backup may be used to get some previous commit, or even an attempt to fix it if really necessary just because it is required an old version of a file. Since "clone" command was able to clone to local repository although the warning, this corrupted remote repository is still useful to recover old stuff.
This backup may be used to get some previous commit, or even an attempt to fix it if really necessary just because it is required an old version of a file. Since "clone" command was able to clone to local repository although the warning, this corrupted remote repository is still useful to recover old stuff.
GOING AHEAD WITH THE FUTURE
It was created a new remote repository:
mkdir clone
cd clone
mkdir clone
cd clone
git init --bare
A new remote repository with a new log history.
The old one is preserved in the backup mentioned above, just in case.
The old one is preserved in the backup mentioned above, just in case.
Next step is to push the local repositories.
The procedure was usual except that it is required to set upstream, resembling the procedure when a remote repository is switched (git remote remove origin, git remote add origin new_path).
The procedure was usual except that it is required to set upstream, resembling the procedure when a remote repository is switched (git remote remove origin, git remote add origin new_path).
git add *
git commit -am "MACHINE_NAME: corrupted remote repository switching"
git pull origin master
git push --set-upstream origin master
git commit -am "MACHINE_NAME: corrupted remote repository switching"
git pull origin master
git push --set-upstream origin master
The same procedure was repeated to all local clients.
One day, if fixing the corruption is worthy, we may try the "Recovering from repository corruption" instructions, but till there, maybe Git will bring redundancy option to duplicate the tree.
In such cases it would be useful to have two files in different positions on the disk, in order to recover the information from a particular damaged disk position. This should be really an option because it would double the resources' requirement, but sometimes it is a desirable option if hardware has the power to supply this redundancy without being noticeable and disk space is not a restriction.
The full disk was checked successfully. No errors found, except this occurrence.
In such cases it would be useful to have two files in different positions on the disk, in order to recover the information from a particular damaged disk position. This should be really an option because it would double the resources' requirement, but sometimes it is a desirable option if hardware has the power to supply this redundancy without being noticeable and disk space is not a restriction.
The full disk was checked successfully. No errors found, except this occurrence.
Murphy's day. :-)
>ENV
Windows 10
git v.2.30.1.windows.1
Run git fsck --full to identify corrupted objects, HostingRaja then remove them with rm .git/objects/, and finally run git gc --prune=now to clean up.
ReplyDelete