Git: 掉坑记 -- git reset 杀手

git reset --hard 了怎么办?

掉坑起因

项目修改完成之后,会依赖一个比较大的文件,所以这个大文件就在项目根目录中,使用 git 的时候,直接 git add、git commit、git push 一键三连,等到 git push 后就会提示文件过大,超过100M。
由于技术太菜,经过谷哥和度娘的帮助下,我成功通过以下命令回撤了版本:

# 1、查看提交日志
git log

# 2、选择提交id后
git reset --hard id

然后,一看本地项目,卧*,被删的一干二净,然后在仔细看到别的博客中说到,这个命令之后,本地文件会被删除,需要谨慎使用。再次使用 git log 查看的时候,撤回到指定id版本,在其后提交的内容已经不存在了。这里就不能再使用 git reset --hard 这个命令再跳回到最后提交版本中。

解决方法

但是,别慌,方法总比问题多。解决这个问题其实也很简单:

# 1、使用reflog查看记录
git reflog

# 2、使用 reset 跳回最后版本,id 就是显示在最前面的那个你提交的版本号,根据实际情况恢复你自己的内容
git reset --hard id
# 注: 一般这里,就可以把之前删的文件恢复了,如果没有,执行下面命令

# 3、checkout, file 就是你项目名称
git checkout file/

但是,上面这些内容只是解决了如何恢复已经commit后删除的内容,但是没有解决之前大文件的问题,这里进行 push 的话还是会不行,所以我们需要进行下面操作:

# 1、找到你的大文件, 显示10个最大的文件id列表
git verify-pack -v .git/objects/pack/pack-*.idx | sort -k 3 -g | tail -10

# 2、根据文件id查询文件路径,如果你已经知道路径,则可以直接进入第3步
git rev-list --objects --all | grep 3b08a747589895bdc995cd18ae1fe9e70abcd417

# 3、移除文件 your_file就是你的大文件
git log --pretty=oneline --branches -- your_file

# 4、删除文件历史记录
git filter-branch -f --prune-empty --index-filter 'git rm -rf --cached --ignore-unmatch your_file' --tag-name-filter cat -- --all

# 5、提交
git push --force --all

ok,到这里就把遇到的问题解决了。

参考链接:
百度经验 - git reset -hard 的误操作的解决办法
百度经验 - git如何恢复本地删除的文件夹
大芒果 - git 仓库中删除历史大文件

我的博客即将同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=wlg3bm8mo4o5

### 回答1: git:husky>pre-commit是一个Git钩子,它在提交代码前执行一些操作。通常用于代码风格检查、单元测试等操作,以确保代码质量和稳定性。Husky是一个Git钩子管理工具,可以方便地配置和管理Git钩子。 ### 回答2: Git是目前最流行的版本控制系统。在大多数项目中,代码的质量和一致性非常重要。在Git中,可以使用钩子(Hooks)来确保代码的质量和一致性。其中,pre-commit是常用的钩子之一。而Git: Husky则是Git中常用的钩子管理工具。 Git: Husky是一个钩子管理工具,它允许开发者进行钩子配置,包括在提交代码之前运行何种指令。 具体地说,Git: Husky支持pre-commit钩子,使开发者可以在代码提交之前运行一些脚本,以确保提交的代码的质量和一致性。 pre-commit钩子可以被用于在代码提交之前运行某些指令。例如:静态代码分析工具,或者在代码提交之前运行的测试。因此,pre-commit钩子可以帮助开发者检查代码错误、格式、风格等。其过程是:在代码提交之前,pre-commit钩子运行拖的脚本,检查指定的问题并生成反馈,然后提交成功或失败。 总之,Git: Husky中的pre-commit钩子是非常实用的工具。它可以让开发者在代码提交之前运行各种指令,以检查代码错误、格式、风格等。这有助于确保代码的质量和一致性,提高软件开发的效率和质量。所以,建议开发者在Git中应用Git: Husky这一钩子管理工具,并使用pre-commit钩子确保代码的质量。 ### 回答3: Git是一款非常流行的版本控制工具,而husky>pre-commit是Git中的一个功能。Husky是一款JavaScript库,可以通过它来为Git的hooks添加JavaScript脚本,而pre-commit是Git hook的一种类型,可以在commit前触发,并且可以运行一些脚本来帮助我们检查代码或其它工作。 在Git中,pre-commit可以帮助我们做很多事情。例如,在代码提交之前,我们可以用pre-commit来对代码进行语法检查、格式化、代码审查、代码测试等。如果代码不符合某些规范,pre-commit还可以阻止代码提交,从而让我们更加规范地管理代码。 使用husky>pre-commit也非常简单。首先,我们需要在项目中安装husky,然后在package.json文件中设置pre-commit属性来配置pre-commit hook。在pre-commit属性中,我们可以定义一个或多个需要执行的脚本,这些脚本会在commit之前执行。例如,我们可以在pre-commit中加入代码格式化、代码审查和代码测试三个脚本,来确保我们提交的代码符合团队的代码规范和质量要求。 总之,使用husky>pre-commit可以很好地帮助我们管理代码,确保代码的质量和一致性。这对于团队协作和代码维护都非常重要。同时,husky>pre-commit也可以提高我们的编码效率,让我们集中精力在代码逻辑的编写上,而不是在代码格式、代码规范等上浪费时间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值