记录一次Git操作不当造成的事故

本人Git学艺不精,平时仅限基本使用,今天出了事故,一头冷汗,特此记录前因后果,提醒大家。

一句话总结关键 就是:千万不要随便 git reset --hard !!!


今天正准备提交代码时,突然发现不太对劲,IDEA左侧Git记录变动的部分多了一个蓝色的文件,点开看发布没有变动,完全一样。这是小问题。

我漫不经心,尝试打开IDEA再重新打开后,突然发现Git记录变动里把全部文件都变蓝色了!一个个点开看,发现对比都是完全一样(除了我真正有变动的),我没见过这场面,这要我怎么提交?

于是我就去问AI,DeepSeek太卡了,就通义千问了。

我发现它知道在 IntelliJ IDEA 中,文件或文件夹显示为蓝色通常表示这些文件在 Git 仓库中处于 "已修改"(Modified) 状态。然而,我发现文件内容实际上并没有任何更改,但仍然显示为蓝色。

既然正确理解了我的意思,很开心,准备采纳它的建议,我先后试了以下建议

  • 配置 Git 的换行符处理行为:在终端中运行以下命令,确保 Git 不会自动转换换行符:

    git config --global core.autocrlf false

  • 忽略文件权限更改: 在终端中运行以下命令,让 Git 忽略文件权限的变化:

    git config --global core.fileMode false

都没有任何变化。

然后发现建议一里面部分和建议四的解决方案相同,如下:

重新检出文件: 执行以下命令重新检出文件,清除可能的换行符问题:

css 复制代码
git rm --cached -r .
git reset --hard

清理 Git 缓存: 在终端中运行以下命令,强制刷新 Git 的索引缓存:

css 复制代码
git rm --cached -r .
git reset --hard

我出于对AI的信任,直接采用了,第一条命令有变化,具体变化忘了,第二条命令直接回退到了上次提交!天塌了,也就是说这几天新写的代码全没了 !!!(不过也确实成功消除了异常的蓝色文件) 你就说解决没解决问题吧?

愤怒质问AI,渴望恢复。

git rm --cached -r .:这个命令会从 Git 的索引(即暂存区)中移除所有文件,但不会删除工作目录中的实际文件。

git reset --hard:这个命令会将工作目录和暂存区重置为最近一次提交的状态,丢弃任何未提交的更改(包括新添加的文件、修改的内容等)。

如果你在运行这些命令之前有未提交 的更改,这些更改会被永久丢失

我上网搜索解决方案,和AI说的一样,是用Git 的 reflog,但是没用

看到 使用 IntelliJ IDEA 的本地历史功能 ,尝试后发现可以,欣喜若狂,然后靠这个一个一个文件找回了。

感恩IDEA,赞美IDEA。这么多天,每一次细小的修改都帮我记录下来了。

不禁感叹,"无知时诋毁IDEA,懂事时理解IDEA,成熟时追随IDEA。"


另外,问问有没有大佬遇到过我一开始这种全部变蓝的情况,还是很好奇到底怎么回事。

相关推荐
中科三方9 小时前
新注册的域名无法访问,是怎么回事?
git·github
potender18 小时前
git提交到GitHub问题汇总
git·github
昊虹AI笔记2 天前
Git(分布式版本控制系统)系统学习笔记【并利用腾讯云的CODING和Windows上的Git工具来实操】
git
一线大码2 天前
IntelliJ IDEA 新版本开箱使用指南(2023.3.4)
java·后端·intellij idea
曲江涛2 天前
Git 忽略文件.gitignore
git
测试界清流2 天前
自动化测试、压力测试、持续集成
数据库·git
kld2303 天前
Jenkins 使用教程:从入门到精通
git·go·jenkins
明月心9523 天前
采用gitlab的package registry 方式 通过api 上传发布包,解决git命令拉取大文件异常退出问题
git·gitlab
一天八小时3 天前
Shell操作学习
linux·git·学习