设为首页 收藏本站
查看: 886|回复: 0

[经验分享] 分享几个 git 的使用场景

[复制链接]

尚未签到

发表于 2018-1-13 11:06:14 | 显示全部楼层 |阅读模式
  你真的会使用 git 吗?你能回答下面几个问题吗?
  
有三个commit(顺序:CommitA、CommitB、CommitC),它们相互独立,没有依赖。


  • 在不修改B、C的前提下,修改A,怎么操作?
  • 合并A、B、C为一个commit,怎么操作?
  • 调整A、B、C的顺序编程 C、B、A,怎么操作?
  作为一个开发,日常工作中不可避免的要使用 git。
  
当然了,如果你技术无敌、独立承担一个项目、没人干预或者影响你的工作,那么你可能不需要下面这些总结。哈哈哈...
  由于 xxx 原因,我认为应该给项目组的其他人讲讲 git。
  
因为语言障碍和技术熟练度的障碍,为了让同事们更好地理解并且愿意使用 git 。我不得不一个场景一个方法地讲解,所以有了下面总结。

  这难道不是一种成长吗?


场景1
  J 写了一个功能,分成3次commit(顺序:CommitA、CommitB、CommitC)。完成功能之后,他找了B先生进行Code Review,B先生觉得 CommitB 和 CommitC 没有问题,CommitA需要进行简单修改。
  
那么如何在不改变CommitB和CommitC的前提下,修改CommitA呢?

方法:
  使用 git rebase -i,操作如下


  •   rebase CommitA、CommitB、CommitC 三个commit
      

    $ git rebase -i <parent commit of A>
  •   修改 CommitA
      
    (1)Commit A前面pick修改为edit,然后:wq保存退出。
      
    DSC0000.png

  (2)这是HEAD停留在CommitA,可以对CommitA进行修改,然后使用下面命令覆盖CommitA
  

$ git add <修改文件>  
$ git commit -amend
  


  •   让git完成后续rebase操作
      

    $ git rebase -continue
场景2
  J修改了CommitA后,项目leader希望一个功能尽可能使用一个commit提交。
  
那么如何合并CommitA、CommitB、CommitC为一个commit呢?

方法:
  同样使用 git rebase -i,操作如下


  •   rebase CommitA、CommitB、CommitC 三个commit
      

    $ git rebase -i <parent commit of A>
  •   合并 Commits
      
    (1)CommitB和CommitC前面pick修改为squash,然后:wq保存退出。
      
    DSC0001.png

  (2)这时,我们会需要重新编辑 commit message,统合3条commit的信息。然后:wq保存退出。


  •   让git完成后续rebase操作
      

    $ git rebase -continue
场景3
  J 合并CommitA、CommitB、CommitC后,新产生的CommitA+需要将代码更新到master上。但是,同一项目组的T已经提交了CommitD。
  
本来 J 只需要merge自己的CommitA+到master就可以了,但是 J 下一个任务依赖于 T 提交的CommitD。
  
J 希望一次性更新master和自己的branch(branch_J_dev),一石二鸟。
  
那么如何在merge自己的CommitA+到master的同时将CommitD也merge到自己的branch(branch_J_dev)中呢?

方法:
  又是使用 git rebase,操作如下


  •   rebase 自己的branch_J_dev 到 master
      

    $ git checkout branch_J_dev  
    $ git rebase --onto master <CommitA+>

  •   master 合并 branch_J_dev 的提交
      

    $ git checkout master  
    $ git merge branch_J_dev
      

      git checkout master和git merge branch_J_dev 非常重要,网络上大部分教程都没有最后一步。
      
    而且好多人都把命令写成了git rebase --ontomaster <commit>全是抄袭同一个人的,也是醉了。哈哈哈哈...
      
    我也是因为被坑了,所以才查了一下一下资料,发现竟然还需要一步。


场景4(需求基本和场景3一致)
  如何 J 本次希望提交的代码有CommitA+、CommitB+、CommitC+三次commit(顺序:CommitA+、CommitB+、CommitC+)。
  
那么如何在merge自己的CommitA+、CommitB+、CommitC+到master的同时将CommitD也merge到自己的branch(branch_J_dev)中呢?

方法:
  基本和场景3一致,操作如下


  •   rebase 自己的branch_J_dev 到 master
      

    $ git checkout branch_J_dev  
    $ git rebase --onto master <CommitA+>^

  •   CommitA 合并进master
      

    $ git checkout master  
    $ git merge branch_J_dev
      

      ^代表,起点。<CommitA+>^表示CommitA为起点后面所有的Commit。


场景5
  如何修改 commit 记录(调整顺序+修改message)?
  
其实这种操作没什么意义,但是对于对 commit log 有强迫症的人,或许有想修改 commit 记录的冲动。
  
哈哈哈哈...

方法:
  还是使用 git rebase。惊喜不惊喜?意外不意外?操作如下


  •   rebase CommitD和CommitA+
      

    $ git rebase -i <parent commit of D>
  • 调整 commit 顺序,就是将 CommitD 和 CommitA+ 顺序进行调整。
  • 修改 message ,将 pick 修改为reword。
  •   让git完成后续rebase操作
      

    $ git rebase --continue  

    (最后)小提示
  •   如果想中途取消rebase操作,后悔药

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-434603-1-1.html 上篇帖子: git添加比较和合并工具(meld) 下篇帖子: 解决因为本地代码和远程代码冲突,导致git pull无法拉取远程代码的问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表