成为Git专家

“time-lapse photography of man standing beside road and bridge during daytime” by Ahsan Avi on Unsplash

我在提交中犯了一个错误,我该如何解决?

我的提交历史很糟糕,我该如何让它更整洁?

如果你有过上述问题,那么这篇文章适合你。这篇文章涵盖了一系列主题,这些主题将使您成为Git专家。

如果您不了解Git基础知识,请单击此处查看我的Git基础知识博客。您必须了解Git的基础知识才能充分利用本文。

我的提交中犯了一个错误。我该怎么办?


“broken ceramic plate on floor” by chuttersnap on Unsplash

场景1

假设您已经提交了一堆文件并意识到您输入的提交说明跟实际上并不清楚。现在您要更改提交说明。为此,您可以使用git commit --amend

git commit --amend -m “New commit message”

情景2

假设您想提交六个文件,但是,错误地,您最终只提交了五个文件。您可能认为可以创建新提交并将第6个文件添加到该提交。

这种方法没有错。但是,为了保持一个整洁的提交历史,如果你真的能以某种方式将这个文件添加到你之前的提交本身,那不是更好吗?这也可以通过以下方式完成git commit --amend

git add file6
git commit --amend --no-edit

--no-edit 表示提交说明不会更改。

场景3

无论何时在Git中进行提交,提交都会附上作者姓名和作者电子邮件。通常,当您第一次设置Git时,您需要设置作者姓名和电子邮件。您无需担心每次提交的作者详细信息。

也就是说,对于特定项目,您可能希望使用不同的电子邮件ID。您需要使用以下命令为该项目配置电子邮件ID:

git config user.email “your email id”

假设您忘记配置电子邮件,并且已经完成了第一次提交。Amend也可用于更改先前提交的作者。可以使用以下命令更改提交的作者:

git commit --amend --author "Author Name <Author Email>"

要点注意

只在本地存储库中使用modify命令。对远程存储库使用modify可能会造成很多混淆。

我的提交历史是一团糟。我该如何处理?

假设您正在处理一段代码。您知道代码大约需要十天才能完成。在这十天内,其他开发人员也将提交代码到远程存储库。

将本地存储库代码与远程存储库中的代码保持同步是一种很好的做法。这会在您提出拉取请求时避免很多合并冲突。因此,您决定每两天从远程存储库中提取一次更改。

每次将代码从远程存储库提取到本地存储库时,都会在本地存储库中创建新的合并提交。这意味着您的本地提交历史将有大量的合并提交,这可能会使审阅者感到困惑。

以下是提交历史记录在本地存储库中的显示方式。

如何使提交历史更整洁?

这就需要rebase来处理。

什么是rebase?

让我通过一个例子解释一下。


此图显示了发布分支和功能分支中的提交

  1. Release分支有三个提交:Rcommit1,Rcommit2和Rcommit3。
  2. 您只在一次提交时从Release分支创建了Feature分支,即Rcommit1。
  3. 您已向Feature分支添加了两个提交。它们是Fcommit1和Fcommit2。
  4. 您的目标是从Release分支到您的Feature分支的提交。
  5. 你将使用rebase来做到这一点。
  6. 让Release分支的名称release ,Feature分支的名称是feature
  7. 可以使用以下命令重新进行重新定位:
git checkout feature
git rebase release

Rebasing

在重新定位时,您的目标是确保功能分支从Release分支获取最新代码。

重新尝试尝试逐个添加每个提交,并检查冲突。这听起来有点令人困惑吗?

让我在图表的帮助下解释。

这显示了内部实际的变革:

步骤1

  1. 运行该命令的那一刻,Feature分支指向Release分支的头部。
  2. 现在,Feature分支有三个提交:Rcommit1,Rcommit2和Rcommit3。
  3. 您可能想知道Fcommit1和Fcommit2发生了什么。
  4. 提交仍然存在,将在下面的步骤中使用。

第2步

  1. 现在Git尝试将Fcommit1添加到Feature分支。
  2. 如果没有冲突,则在Rcommit3之后添加Fcommit1
  3. 如果存在冲突,Git会通知您,您必须手动解决冲突。解决冲突后,使用以下命令继续重新绑定
git add fixedfile
git rebase --continue

第3步

  1. 一旦添加了Fcommit1,Git将尝试添加Fcommit2。
  2. 同样,如果没有冲突,则在Fcommit1之后添加Fcommit2并且rebase成功。
  3. 如果存在冲突,Git会通知您,您必须手动解决。解决冲突后,请使用步骤2中提到的相同命令
  4. 整个rebase完成后,您会注意到Feature分支有Rcommit1,Rcommit2,Rcommit3,Fcommit1和Fcommit2。

注意事项

  1. Rebase和Merge在Git中都很有用。Rebase并不比Merge好。
  2. 在合并的情况下,您将进行合并提交。在rebase的情况下,没有像合并提交那样的额外提交。
  3. 一种最佳实践是在不同点使用命令。使用远程存储库中的最新代码更新本地代码存储库时,请使用rebase。在处理pull请求以将Feature分支与Release或Master分支合并时,请使用merge。
  4. 使用Rebase会改变提交历史记录(使其更整洁)。但话虽如此,改变提交历史存在风险。因此,请确保永远不要对远程存储库中的代码使用rebase。始终只使用rebase来更改本地仓库代码的提交历史记录。
  5. 如果对远程存储库进行了rebase,则会产生很多混淆,因为其他开发人员无法识别新的历史记录。
  6. 此外,如果在远程存储库上完成rebase,则当其他开发人员尝试从远程存储库中提取最新代码时,它可能会产生问题。所以我再说一遍,总是只为本地存储库使用rebase😃

恭喜

你现在是Git专家😃

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容