git rm --cached 命令如何解决疑难杂症

"

经历不是一句鸡汤。说教不过两片嘴唇的触碰,经历确是风雨里的打磨。不经我苦难,莫劝我向善。


—— 小闫同学

"

诡异之事年年有,只是今年有点多,在仓库上传到 GitHub 后,偶然在 GitHub 中瞄了一眼,我的天?这个图标不像文件夹啊?这个怎么点不开?git 上传正常啊?本地工作区和暂存区都是干净的了啊?更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

一、问题描述

本地仓库提交后,GitHub 中某文件夹无法正常点击,内容无法显示。

二、原因分析

经排查,定位到原因:之前仓库中包含了一个特殊的文件夹(此文件夹是另外一个 git 仓库),在执行下面语句时:

git add .

提示仓库中包含其他仓库,需要解决此问题。本人操作是删除掉此文件夹中的 .git 配置目录,然后依次执行以下命令:

git add .
git commit -m 'add the new file'
git push

顺利推送仓库到远程,过程中并无报错。这个过程或许是导致问题的原因。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

三、解决办法

现在问题是本地工作区与暂存区干净如新,远程仓库有问题。该如何解决?这时用到了一个命令:

git rm --cached <dir_name>

我们先来看一下手册:

usage: git rm [<options>] [--] <file>...


    -n, --dry-run         dry run
    -q, --quiet           do not list removed files
    --cached              only remove from the index
    -f, --force           override the up-to-date check
    -r                    allow recursive removal
    --ignore-unmatch      exit with a zero status even if nothing matched

可以看到 --cached 的作用:将文件仅仅从索引中移除,翻译成人能看懂的话便是 「之前已经提交,现在将此目录释放掉,恢复到工作区,未被追踪的状态,即 git add . 命令之前的状态」

我们执行完此命令之后使用如下命令查看所有改变后的文件状态:

git status

发现出问题的目录已经变成了红色未被追踪的状态,此时将出问题的目录中所有包含 git 信息的文件和目录都删除,然后再依次执行命令:

git add .
git commit -m 'add the new file'
git push

去远程仓库中查看后发现问题解决。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

四、总结

当出现未知问题致使远程仓库同预期结果不一致时,本地可以将问题目录恢复到未被追踪状态,核查完问题之后再次提交最新结果,操作步骤如下:

1.删除缓存,释放目录,恢复到未被追踪状态:

git rm --cached <dir_name>

2.依次执行如下操作再次提交:

git add .
git commit -m 'Information you need to submit'
git push

3.完美解决问题。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值