我把我的repo克隆到了我的ubuntu一个文件夹到新机器上,我得到了这个:
christopher@christopher-laptop:~/source/personal$ git clone ~/Ubuntu\ One\ Side\ Work/projects.git/
Cloning into 'projects'...
done.
fatal: unable to read tree 29a422c19251aeaeb907175e9b3219a9bed6c616
christopher@christopher-laptop:~/source/personal$
Run Code Online (Sandbox Code Playgroud)
所以我试着看看这里提出的许多其他问题,大多数人说要跑git fsck --full,然后当我尝试时我得到这个.
christopher@christopher-laptop:~/Ubuntu One Side Work/projects.git$ git fsck --full
Checking object directories: 100% (256/256), done.
Checking objects: 100% (447/447), done.
broken link from commit 235ae1f48701d577d71ebd430344a159e5ba4881
to commit 984c11abfc9c2839b386f29c574d9e03383fa589
broken link from tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
to blob 25a742dff0a403b2b3884f2ffddf63eb45721fac
broken link from tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
to blob dd4e97e22e159a585b20e21028f964827d5afa4e
broken link from tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
to tree 29a422c19251aeaeb907175e9b3219a9bed6c616
broken link from tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
to tree 8084e8e04d510cc28321f30a9646477cc50c235c
broken link from tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
to blob a0daa0c1567b55d8de2b4d7a3bc010f58c047eab
broken link from tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
to blob e9052d35bfb6d30065b206fc43f4200a04d5281b
broken link from tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
to blob 1a3a5e4dd2502ac121c22f743c4250e254a94eeb
broken link from tree 4aa336dc1a5838e8918e03b85580069d83f4ad09
to tree 8cc55ec952dc192a233e062201d1e7e873ac3db0
broken link from tree e5674a91a53e15575a1f3bf5786bc5cc719fb483
to blob 4a994e1e7bb7ce28dcec98bad48b9a891d7dec51
broken link from tree e5674a91a53e15575a1f3bf5786bc5cc719fb483
to blob ac033bf9dc846101320c96a5ce8aceb8c96ec098
broken link from tree 252ab84542264e1589576b6ee51e7a31e580a0e2
to tree 2069041cd5950e529e2991d37b7290ec021d90d4
broken link from tree 2d4964aa4d4f5d8c7228518ce72ef6a63f820c6d
to blob d83690e1b9a6bdd8a08754b38231799acefcb2ab
broken link from tree c7192e82fc581bd6448bda1a25e8729bdac5f4ff
to blob 30d54d47ae82add1917ca173d42e58b396df580b
broken link from tree 7c66306901fc71389623286936cef172d4ffe408
to blob bc7e05d705401273b1df4e939de0f540597c0931
broken link from tree 0940f5fd227d4c84d6e6749d872db50a4522ae3a
to tree 923767594ac22023e824948d65622fe5b407d1a1
broken link from tree 8eadcd2a971e8357d24f0d80f993d2963452209f
to blob 2598bde3dc8cb80ee49510b8159344004b88645f
broken link from tree ffa302dd0d969172ef23caeefe856ab2f57a4e4d
to blob d6925fa431be1ac585bf9a481e98f75107a6e6fb
broken link from tree 7045b8870a49ce30a2027537a96d73d162bda773
to blob 25688652dea26f61f576ca1b52b9d1a18fbfd01d
broken link from tree 37e4705d34bd440ce681ae32ae9a180a13256d72
to tree 246f564d4cee53339b8a4244f3173b61caa518eb
missing blob d6925fa431be1ac585bf9a481e98f75107a6e6fb
missing blob ac033bf9dc846101320c96a5ce8aceb8c96ec098
missing tree 29a422c19251aeaeb907175e9b3219a9bed6c616
missing tree 8084e8e04d510cc28321f30a9646477cc50c235c
missing blob 30d54d47ae82add1917ca173d42e58b396df580b
missing tree 8cc55ec952dc192a233e062201d1e7e873ac3db0
missing blob e9052d35bfb6d30065b206fc43f4200a04d5281b
dangling tree 4b26e95db542c72ac4a22ec25abe38fb2de79752
missing blob d83690e1b9a6bdd8a08754b38231799acefcb2ab
missing blob 25a742dff0a403b2b3884f2ffddf63eb45721fac
missing tree 923767594ac22023e824948d65622fe5b407d1a1
missing blob 25688652dea26f61f576ca1b52b9d1a18fbfd01d
missing blob 2598bde3dc8cb80ee49510b8159344004b88645f
dangling tree 3a683869f1bb0c1634de75700c316b3b36570dbd
dangling blob 4098d30843380d798a811f1aa9a02994f0dbbb27
missing tree 2069041cd5950e529e2991d37b7290ec021d90d4
missing blob 4a994e1e7bb7ce28dcec98bad48b9a891d7dec51
missing blob 1a3a5e4dd2502ac121c22f743c4250e254a94eeb
missing blob a0daa0c1567b55d8de2b4d7a3bc010f58c047eab
dangling tree 6c7b5162aa7a303fa3fe8dc393c5da564e309521
missing commit 984c11abfc9c2839b386f29c574d9e03383fa589
missing blob bc7e05d705401273b1df4e939de0f540597c0931
missing blob dd4e97e22e159a585b20e21028f964827d5afa4e
missing tree 246f564d4cee53339b8a4244f3173b61caa518eb
dangling commit a01f5c1e5315dc837203d6dee00d3493be9c5db9
Run Code Online (Sandbox Code Playgroud)
这看起来很糟糕.当我这样做时,git log | head我得到了这个
christopher@christopher-laptop:~/Ubuntu One Side Work/projects.git$ git log | head
error: Could not read 984c11abfc9c2839b386f29c574d9e03383fa589
fatal: Failed to traverse parents of commit 235ae1f48701d577d71ebd430344a159e5ba4881
commit 2fb0d2d0643b445440f01b164f11ee9ee71fca48
Author: christopher <christopher@christopher.christopher>
Date: Wed Aug 7 15:51:42 2013 -0400
finishing chapter 7
Run Code Online (Sandbox Code Playgroud)
这里的其他问题已经说过了./git/refs/heads/master.这是一个简单的回购并refs/heads/存在,但refs/heads/master没有.ref: refs/heads/master然而,在裸仓中的HEAD说
packed-refs 虽然这样说
# pack-refs with: peeled
2fb0d2d0643b445440f01b164f11ee9ee71fca48 refs/heads/master
Run Code Online (Sandbox Code Playgroud)
还有其他问题建议运行git reflog,当我运行时没有输出显示.
所以我真的不知道该怎么做.应该采取什么策略?是否有可能在8月7日将头重置为最后一次提交
编辑:
执行git日志并转到屏幕输出的底部显示:
commit 996e03b949aea176238e3c7a8452700bbb987ac9
Author: christopher <christopher@christopher>
Date: Wed Jul 3 23:00:44 2013 -0400
many many changes
error: Could not read 984c11abfc9c2839b386f29c574d9e03383fa589
fatal: Failed to traverse parents of commit 235ae1f48701d577d71ebd430344a159e5ba4881
Run Code Online (Sandbox Code Playgroud)
这似乎阻止了git prune的工作
Zoe*_*wll 81
作为CodeGnome的最后一个选项的替代方案,如果只有本地存储库被破坏,并且您知道远程控制器的URL,则可以使用它来重新设置.git以匹配远程控制器(替换${url}为远程URL):
mv -v .git .git_old && # remove old git
git init && # initialise new repo
git remote add origin "${url}" && # link to old repo
git fetch && # get old history
git reset origin/master --mixed # force update to old history
Run Code Online (Sandbox Code Playgroud)
这会使您的工作树完好无损,并且只影响git的簿记.
我最近也为此目的制作了一个bash脚本
(附录A),它围绕此操作包含了一些安全性.
如果你的repo有子模块,这个过程会以某种方式弄乱它们,我到目前为止找到的唯一解决方案是删除它们然后使用git submodule update --init(或重新克隆repo,但这看起来太激烈了).
#!/bin/bash
# Author: Zoey Llewellyn "Zobean" Hewll
#
# Usage: fix-git [REMOTE-URL]
# Must be run from the root directory of the repository.
# If a remote is not supplied, it will be read from .git/config
#
# For when you have a corrupted local repo, but a trusted remote.
# This script replaces all your history with that of the remote.
# If there is a .git, it is backed up as .git_old, removing the last backup.
# This does not affect your working tree.
#
# This does not currently work with submodules!
# This will abort if a suspected submodule is found.
# You will have to delete them first
# and re-clone them after (with `git submodule update --init`)
#
# Error codes:
# 1: If a url is not supplied, and one cannot be read from .git/config
# 4: If the url cannot be reached
# 5: If a git submodule is detected
if [[ "$(find -name .git -not -path ./.git | wc -l)" -gt 0 ]] ;
then
echo "It looks like this repo uses submodules" >&2
echo "You will need to remove them before this script can safely execute" >&2
echo "Then use \`git submodule update --init\` to re-clone them" >&2
exit 5
fi
if [[ $# -ge 1 ]] ;
then
url="$1"
else
if ! url="$(git config --local --get remote.origin.url)" ;
then
echo "Unable to find remote 'origin': missing in '.git/config'" >&2
exit 1
fi
fi
url_base="$(echo "${url}" | sed -E 's;^([^/]*://)?([^/]*)(/.*)?$;\2;')"
echo "Attempting to access ${url_base} before continuing"
if ! wget -p "${url_base}" -O /dev/null -q --dns-timeout=5 --connect-timeout=5 ;
then
echo "Unable to reach ${url_base}: Aborting before any damage is done" >&2
exit 4
fi
echo
echo "This operation will replace the local repo with the remote at:"
echo "${url}"
echo
echo "This will completely rewrite history,"
echo "but will leave your working tree intact"
echo -n "Are you sure? (y/N): "
read confirm
if ! [ -t 0 ] ; # i'm open in a pipe
then
# print the piped input
echo "${confirm}"
fi
if echo "${confirm}"|grep -Eq "[Yy]+[EeSs]*" ; # it looks like a yes
then
if [[ -e .git ]] ;
then
# remove old backup
rm -vrf .git_old | tail -n 1 &&
# backup .git iff it exists
mv -v .git .git_old
fi &&
git init &&
git remote add origin "${url}" &&
git config --local --get remote.origin.url | sed 's/^/Added remote origin at /' &&
git fetch &&
git reset origin/master --mixed
else
echo "Aborting without doing anything"
fi
Run Code Online (Sandbox Code Playgroud)
Tod*_*obs 52
Git并不像你想象的那样存储历史.它基于祖先链在运行时计算历史记录.如果您的祖先缺少blob,树或提交,那么您可能无法完全恢复您的历史记录.
您可以尝试的第一件事是从备份中恢复丢失的项目.例如,查看是否有存储的提交备份.git/objects/98/4c11abfc9c2839b386f29c574d9e03383fa589.如果是这样,你可以恢复它.
如果提交已经打包并且您希望将其返回到松散的对象以进行存储库操作,您可能还需要查看git-verify-pack和git-unpack-objects.
如果您无法从备份中替换丢失的项目,则可以删除丢失的历史记录.例如,您可以检查您的历史记录或reflog以查找提交的祖先984c11abfc9c2839b386f29c574d9e03383fa589.如果你发现一个完整,那么:
如果它有效,你当然会失去介入的历史.此时,如果您有一个工作历史记录日志,那么修剪所有无法访问的提交和对象的历史记录和reflog是一个好主意.
如果您的存储库仍然存在损坏,那么希望您拥有可以从中恢复的未损坏的备份或克隆.如果没有,但您当前的工作目录包含有效文件,那么您可以随时重新初始化Git.例如:
rm -rf .git
git init
git add .
git commit -m 'Re-initialize repository without old history.'
Run Code Online (Sandbox Code Playgroud)
它非常激烈,但如果您的存储库历史真的无法恢复,它可能是您唯一的选择.因人而异.
Jon*_*n L 19
我最近在Ubuntu\xc2\xa018.04.3 (Bionic Beaver)下使用 Git 版本 2.7.1 时遇到了类似的问题。这是我的做法:
\nsudo apt install git-repair\ngit-repair # Fix a broken Git repository\nor\ngit-repair --force # Force repair, even if data is lost\ngit fsck # To verify it was fixed\nRun Code Online (Sandbox Code Playgroud)\n大多数情况下,恢复过程都是成功的。
\n在尝试此页面上描述的任何修复之前,我建议您制作存储库的副本并仅处理此副本。然后最后如果可以修复,请与原始文件进行比较,以确保在修复过程中没有丢失任何文件。
另一种对我有用的替代方法是使用以下方法将 Git 头和索引重置为以前的状态:
git reset --keep
您也可以通过打开 Git GUI 并选择每个“暂存更改”并单击“取消暂存更改”来手动执行相同操作。当一切都未暂存时,您现在应该能够压缩您的数据库,检查您的数据库并提交。
我也尝试了以下命令,但它们对我不起作用。但它们可能适合您,具体取决于您遇到的确切问题:
git reset --mixed
git fsck --full
git gc --auto
git prune --expire now
git reflog --all
Run Code Online (Sandbox Code Playgroud)
最后,为了避免同步损坏您的 Git 索引的问题(可能发生在Dropbox、SpiderOak或任何其他云磁盘上),您可以执行以下操作:
.git使用:将您的文件夹转换为单个“捆绑”Git 文件git bundle create my_repo.git --all,然后它应该像以前一样工作,但是由于所有内容都在一个文件中,因此您不会再冒同步损坏您的 git 存储库的风险。我尝试移走 0 字节的目标文件并再次从远程获取它们,它起作用了:
find . -type f -size 0 -exec mv {} /tmp \;
git fetch
Run Code Online (Sandbox Code Playgroud)
它从远程获取丢失的对象,并允许我继续工作而无需重新初始化整个存储库。
小智 5
这是一个脚本(bash),用于通过@CodeGnome自动执行第一个解决方案,以从备份中还原(从损坏的存储库的顶层运行)。备份不需要完成,只需要缺少对象即可。
git fsck 2>&1 | grep -e missing -e invalid | awk '{print $NF}' | sort -u |
while read entry; do
mkdir -p .git/objects/${entry:0:2}
cp ${BACKUP}/objects/${entry:0:2}/${entry:2} .git/objects/${entry:0:2}/${entry:2}
done
Run Code Online (Sandbox Code Playgroud)
小智 5
如果您配置了远程服务器,并且/不关心丢失一些未推送的代码,则可以执行以下操作:
git fetch && git reset --hard
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
127274 次 |
| 最近记录: |