收好这份 Git 命令应急手册,关键时刻可保你一命

2023-12-24 15:58

本文主要是介绍收好这份 Git 命令应急手册,关键时刻可保你一命,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天跟大家分享一个比较有意思的网站 - Oh shit, git!。

http://ohshitgit.com/

这个网站整理了一些 Git 新手在使用 Git 时常会遇到的各种突发状况,并贴心的给出了应对方案。

我大致瞄了一眼,文章里面提到的一些问题,大部分新手确实会经常遇到,所以我在这里简单的整理一下,把这些应对方案分享给大家。

你们可以把这篇文章马住或分享给同事,以备不时之需,毕竟不怕神对手,就怕猪队友~

下面切入正题,跟大家聊下在 Git 的使用过程中,经常会出现哪些问题,以及应该对应使用哪种解决方案。

注:为了使场景描述更加生动,因此加入了新手女神与高级舔狗两个角色来配合讲解 ????

女神:哎呀,刚刚有个地方搞错了,怎么重新来过呢?

女神莫慌,Git 的牛逼之处,在于它自带时光机效果,能让你在项目的历史代码中任意穿梭。

如果项目的某一处地方它自己不小心坏掉了,不妨试下下面的这行命令:

$ git reflog

这条命令能列出你在 Git 上的所有操作记录,你只要找到 HEAD@{index} 前面所对应的操作索引,并使用下面命令即可:

$ git reset HEAD@{index}

注:使用时需将HEAD@{index}替换为对应索引。

女神:想改个小东西,但代码不小心提交(commit)了,这可咋整?

这个简单,首先,添加下当前已改动的代码:

$ git add .

然后,运行下面这条命令,它就会把你刚刚添加的代码合并到最后一次提交上了:

$ git commit --amend

女神:哼!刚刚写的提交历史写得不够好,我想重写一下!

好的,还是上面提到过的那条代码,运行一下,就可以重写提交历史啦:

$ git commit --amend

女神:这下惨了,我刚刚不小心把新分支的代码提交到主分支上了!

女神别着急,我们一步步来,你先创建个新分支(some-new-branch-name):

$ git branch some-new-branch-name

然后把刚才的提交从主分支中移除:

$ git reset HEAD~ --hard

需要注意的是,上面的代码只会切换到最后一条提交记录上,如果你已跑到其它提交记录上怎么办?没关系,你可以用 git reset HEAD@{number} 再跑回来。

等你跑回来之后,我们再切换到新分支上:

$ git checkout some-new-branch-name

好了,完成啦,现在主分支干干净净,刚刚不小心提交的代码也被移到新分支上了。

需要注意的是,上面的代码只对本地仓库有效,如果你已经把代码提交到远程仓库上,那就得跟队友商量下解决方案了。

啥?我就是你队友?这可真让我受宠若惊☺️ 不过没事,等下我帮你在线上主分支上 reset 然后 push -f 一下就好啦~

女神:完蛋了,我把代码提交到错误的分支上了!

别怕别怕,有我在呢。

我们先撤销最后一次提交,但保留变更代码:

$ git reset HEAD~ --soft
$ git stash

再切到你想要提交的正确分支(name-of-the-correct-branch)上,并把变更代码提交上去:

$ git checkout name-of-the-correct-branch
$ git stash pop
$ git add .
$ git commit -m "your message here"

OK,到这里就搞定了。

如果想要逼格高点,也可以用 cherry-pick 这个命令来完成上面那些操作。具体的操作步骤如下。

首先,切换到正确的分支上:

$ git checkout name-of-the-correct-branch

然后使用 cherry-pick 来获取最新一条提交记录:

$ git cherry-pick master

最后再把主分支上那条提交错误的记录删除:

$ git checkout master
$ git reset HEAD~ —-hard

女神:咦?为啥我运行 diff 后啥都没有?

遇到这种情况,应该是文件没有加入到暂存区的缘故。解决方案很简单,咱们要么把文件加入到暂存区,要么就直接使用下面这条命令:

$ git diff --staged

这样,就可以看到未存入暂存区文件的 diff 效果啦。

女神:这项目怎么这么乱!好烦呐!我不玩了!

别气别气,别气坏了身子就不好了,么么哒 ????

如果本地代码仓库把自己折腾得乱七八糟,不用怕,用下面这招,一击必杀:

$ cd ..
$ sudo rm -r fucking-git-repo-dir
$ git clone https://some.github.url/fucking-git-repo-dir.git
$ cd fucking-git-repo-dir

是的,这就是备胎(线上仓库)的强大之处,只要你备胎尚在,你就可以大大方方的把本地仓库删了,clone 备胎,从头再来。

女神:好啦,我没什么问题了,谢谢你哦~

不不不,这块问题还多着呢?你打开下面这个网站,听我跟你细细道来…

https://stackoverflow.com/questions/tagged/git


点击「阅读原文」可查看文章原内容。

GitHubDaily - 挖掘开源的价值。

  • 微博: @GitHubDaily

  • 知乎:GitHubDaily

这篇关于收好这份 Git 命令应急手册,关键时刻可保你一命的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/532326

相关文章

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

java中ssh2执行多条命令的四种方法

《java中ssh2执行多条命令的四种方法》本文主要介绍了java中ssh2执行多条命令的四种方法,包括分号分隔、管道分隔、EOF块、脚本调用,可确保环境配置生效,提升操作效率,具有一定的参考价值,感... 目录1 使用分号隔开2 使用管道符号隔开3 使用写EOF的方式4 使用脚本的方式大家平时有没有遇到自

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

Git进行版本控制的实战指南

《Git进行版本控制的实战指南》Git是一种分布式版本控制系统,广泛应用于软件开发中,它可以记录和管理项目的历史修改,并支持多人协作开发,通过Git,开发者可以轻松地跟踪代码变更、合并分支、回退版本等... 目录一、Git核心概念解析二、环境搭建与配置1. 安装Git(Windows示例)2. 基础配置(必

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java