一些常用的 Git 进阶知识与技巧

1. 同一电脑存在多个 Git 账号

假设我们在同一电脑上拥有多个 Git 账号,例如公司内部使用的是 Gitlab,个人使用的是 Github 或者 Gitee。那就会遇到一种情况,上班时想给个人开源项目提交代码,但是 Git 绑定的是公司的账号。

在这种情况下,我们可以让 Git 绑定多个不同的 ssh key,每个 ssh key 对应一个不同的 Git 服务器。

生成第一个 ssh key:

生成第二个 ssh key:

参数 -f 表示指定生成的文件名, path/to/file 是文件名路径,例如 ~/.ssh/id_rsa_github

执行上面两条命令后会得到两对 ssh key。

一些常用的 Git 进阶知识与技巧

这时还需要在该目录下创建一个 config 文件。写上以下内容:

这个配置文件的作用是指定私钥文件位置。

然后我们可以把第一个密钥配置到公司的 Gitlab 服务器,并把相应的 Git 账号和邮箱设成全局。

然后把另一对 ssh key 配置到 Github 上,并在电脑上的 Github 项目里单独配置 Git 用户姓名和邮箱。

至此,我们就大功告成了。可以同时在不同的 Gitlab 和 Github 项目上提交代码了。

2. 修改 git commit 记录的用户姓名和邮箱

假设电脑上同时存在 Gitlab 和 Github 项目,其中 Gitlab 用户信息已经全局配置过了。现在新拉了一个 Github 项目,提交了一个 commit 并且已经推送到了远程仓库。这时发现该项目未配置 Github 的用户信息,默认使用的是全局账号 Gitlab 的用户信息。

我们可以通过以下命令来修改最近一次提交的用户信息:

username 是用户名,用户邮箱旁边的 <> 符号不能去掉。修改后再执行 git push -f 推送到远程仓库。

如果要修改多个 commit 的用户信息怎么办? 可以通过以下的代码来修改:

将上述代码中的用户名和邮箱修改后,保存为 .sh 格式的文件,例如 edit.sh。然后在项目根目录下执行 sh edit.sh(windows 下可右击-> Git Bash Here -> sh edit.sh),再执行 git push -f 强推即可。

3. 修改某个历史记录的消息

假设当前分支有 a b c d 四个 commit 记录:

如果你想对 c 记录的消息进行修改。可以使用 git rebase 将 c 记录换到最前面,然后使用 git commit --amend 对其消息进行修改。

具体操作步骤

执行以下命令对记录 d 前面的三个 commit 进行编辑:

进行 vim 编辑界面后,移动光标到 c 记录上,按下 dd 剪切该记录,然后移动光标到第一行,按下 p 粘贴,再输入 :wq 保存。

执行 git commit --amend 对切换顺序后的 c 记录进行修改。进入 vim 编辑界面后,按 i 进行修改,然后按 ESC,再输入 :wq 保存。

最后用前面讲过的 git rebase 操作将 c 记录恢复到原来的位置。

一些常用的 Git 进阶知识与技巧

这个过程的执行结果就和上图一样,这是当前分支修改后和远程分支上的对比,箭头指向的记录消息就是修改后的消息。

如果想把修改后的记录同步到远程仓库,这时只要执行 git push -f 就可以了。

第二种方式

  1. 使用 git checkout -b <branchName> c 从指定记录切出一个分支
  2. 在新分支使用 git commit --amend 修改提交消息
  3. 使用 git cherry-pick 将 b a 记录,追加到新分支(注意,这里的 b a 提交记录是指原分支上的 commit,也就是选取原分支上的 b a 记录添加到新分支上,这样新分支上的记录就变成了 a b c,并且 c 记录的提交消息在第二步已经修改过)
  4. 使用 git checout 原分支名 切换回原来的分支,再执行 git rebase <branchName> 合并新分支,最后强推到远程分支

4. 挑选指定的 commit 进行合并

假设你切了一个 bugFix 分支来修复线上 bug,经过一段时间的努力后终于将 bug 修复了。但是为了调试(加了很多 debug 代码)或其他原因,bugFix 上多了很多无用的记录消息。

例如上面的三个记录,前面的两个记录添加了很多调试代码,在最后一个记录终于修复了 bug,并且删除了调试代码。这时如果直接将 bugFix 分支合到 master 分支,就会把调试的记录也合并进来。

这时可以使用 git cherry-pick 只将最后一个记录合并到 master 分支。或者使用 git rebase 将 bugFix 分支另外两个记录抛弃,然后再合并。

5. ^ 和 ~ 的区别

操作符 ^ 与 ~ 符一样,后面也可以跟一个数字。 ~ 表示向上返回几代记录。

但是该操作符后面的数字与 ~ 后面的不同,并不是用来指定向上返回几代,而是指定合并提交记录的第几个父记录。

Git 默认选择合并提交的“第一个”父记录,在操作符 ^ 后跟一个数字可以改变这一默认行为。

单看文字可能不太好理解,下面看几个示例。

执行命令 git checkout main^ 回到第一个父记录(原来 HEAD 指向 c3,现在指向 c1)。

执行命令 git checkout main^2 回到第二个父记录(原来 HEAD 指向 c3,现在指向 c2)。

最后再来一个更复杂的示例:

通过这些示例我们还能发现 ~n 等于连续的 n 个 ^

6. git revert 与 git reset 的区别

git reset 可以回退 Git 的历史记录。例如当前分支有三个记录,并且 HEAD 指向 c 记录:

如果我们想回退到 b 记录,只要执行 git reset b 就可以了:

接着使用 git push -f 将回退版本后的分支强制推送到远程仓库,这样本地分支和远程分支就同步了。

git revert 也可以撤销记录,只不过它撤销的记录不会消失,这一点和 git reset 不一样。git reset 撤销的记录就跟消失了一样。

现在我们用 git revert 来重新演示下刚才的操作:

如果我们执行 git revert b,则会在当前分支上再生成一个新的 commit 记录,变成 a b c b',这个 b' 的状态和记录 b 是一样的。

也就是说,执行 git reset b 后,当前的分支记录会变成 a b。执行 git revert b 后,当前的分支记录会变成 a b c b'

如果你想让别人知道你撤销过记录,就使用 git revert,因为它会留下撤销的记录,否则用 git reset

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。商机网仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 tenspace2022@163.com 举报,一经查实,本站将立刻删除。 本文链接:https://www.315965.com/n/53106.html 聚才发 母婴好物

(0)
上一篇 2023年12月15日 上午7:04
下一篇 2023年12月15日 上午7:14

相关推荐

  • 绘画教程二次元(绘画教程二次元简单)

    怎样画好二次元人物?画二次元动漫人物步骤!二次元里除了让人羡慕的各种超现实能力外,还有一点发酸的是,二次元里不管男的、女的,皮肤都是完美无瑕的,毛孔都没有!真实世界,达不到二次元里的完美,也只能通过画画寄托一下情感~那么二次元动漫人物皮肤怎么画?今天要教大家的就是二次元动漫人物皮肤皮肤的画法教程,一起来看看吧! 《海贼王·路飞》 1、先在线稿铺上底色,这里的…

    2023年7月30日
    235
  • cdr教程入门基础知识(cdr入门图文自学教程)

    对于很多跨入设计行业的新手来说,CorelDRAW也是必备技能之一,它是一款专门用于矢量绘图软件,很多设计师们应该都有耳闻或者正在使用。今天小编使用CorelDRAW 2019 for Win 版本来讲解基础内容,认真学习你也能成为一名不错的设计师。 一、CorelDRAW 2019软件介绍 图1:CorelDRAW 2019初始页面 打开CDR软件,首先出…

    2023年7月30日
    328
  • 抖音权重下降了怎样快速恢复(三个降权的补救提升方法)

    大家好,我是二小姐,今天是2024年的10月18号那么这里讲一下关于抖音账号的几种不同的权种第一种情况。   很多同学问的最多的一个问题就是说,二小姐你看我这个账号,我这个播放量只有100个,现在还能不能够用,这个账号能不能够用?如果你发了一两百个作品出去,播放量都还是只有几十个,100个,连200个都没有超过,那你最好就换一个账号,因为这个怎么说呢,有些手…

    2023年8月13日
    894
  • 强烈推荐的微信小程序开发总结

    遇到过的坑 小程序页面栈最多十层 问题:假设小程序内有12个问题页面,答完上一个问题后wx.navigateTo到下一个问题页面,那么到第十题时,你会发现wx.navigateTo跳转不到下一个页面。这是因为使用wx.navigateTo跳转会把当前页面保存到页面栈中,而小程序页面栈最多十层。 require的路径不支持绝对路径 问题:在嵌套比较深的目录层级…

    2023年12月17日
    174
  • 折纸教程大全简单易学(折纸教程大全简单易学动物)

    一张简单的纸却能变出许多可爱的小动物,折纸的乐趣就在动手,今天给大家分享那些只有孩子才喜欢去折的小动物。 相信每次看到有折纸大全的教程,妈妈们都会忍不住为孩子们收藏,哪天有空了,就教孩子一起折。里面的小动物小花,因为造型不复杂而且比较简单,步骤不多,耐心一点看图解,然后教一教孩子,基本就能折出来。 但是这样的小小折纸,折出来之后,最多就是孩子能高兴一会,平面…

    2023年7月30日
    224
  • .Net 7 轻松上手Dapr之服务调用

    对于Dapr ,在项目中也有用过一段时间,优缺点并存,但是瑕不掩瑜,目前随着版本的迭代和第三方团队对它的支持也使得我们用得更加得心应手,所以借此也回顾一下Dapr的相关知识以及分享一下项目中用到的第三方库MASA.Framework 对Dapr的完美支持。然后本文只是个人学习与分享,不喜勿喷,谢谢! 什么是Dapr? Dapr 是 Distributed A…

    2023年12月16日
    202
  • 凉拌黄瓜的做法简单又好吃(凉拌黄瓜的简单做法)

    夏季胃口不好,如果能做一道爽口的凉拌菜,无论是吃米饭、喝粥、吃面条,都是妥妥的开胃下饭菜~ By *长腿_河马太太* 用料 黄瓜 2根 盐 1勺 醋 1勺 生抽 2勺 白糖 2勺 蒜 5瓣 姜 少许 红剁椒 1勺 干辣椒 3个 花椒 1克 做法步骤 1、1⃣️、黄瓜切成段,放白糖1勺、盐1勺腌制1小时,等黄瓜出水以后倒掉水,再用清水冲洗干净 2、2⃣️、冲洗…

    2023年8月2日
    531
  • 幻灯片制作流程(幻灯片制作教程视频小白系列课程)

    正如工厂流水线生产汽车一样,PPT 制作同样存在流程,遵循合适的方法,不仅能够提高幻灯片的制作效率,更能够让你更加合理的分配 PPT 制作时间。 那么,从0到1.一套幻灯片是怎么被制作出来的呢?我在这里给大家分享一下我的个人经验。 假如说咱们现在就要做一套 关于 「PPT 制作流程」的幻灯片 。启动时都要做点啥呢? 1/ 首先,在我们开始动笔写文字稿之前,我…

    2023年8月1日
    236
  • 宫保鸡丁的做法 正宗 步骤(宫保鸡丁的做法及配料)

    By 安逸Juliana 用料 鸡胸肉 1块 黄瓜 1/2根 胡萝卜 1/3根 葱 适量 蒜 适量 【腌料】 : 料酒 2勺 盐 2匙 玉米淀粉 1勺 【调料汁用料】 : 生抽 2勺 醋 2勺 糖 1勺

    2023年8月2日
    256
  • 象棋教程初学者(中国象棋教程入门篇)

    上篇文章已经介绍了象棋入门棋子该如何走法,今天分享一下入门初学者该如何下象棋。 象棋布局非常多,先手有中炮、先马局、飞相局、士角炮、过宫炮等,那么作为新手应该先学哪个呢?该如何走呢? 新手必先学的为中炮局,中炮攻势猛,思路清晰,是新手玩家用的最多的布局走法。若精通后,三天即可让人刮目相看了。 中炮开局 中炮走法口诀: 起炮在中宫,观棋气象雄。 马常守中卒,士…

    2023年7月31日
    218