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

[经验分享] Git日常操作命令梳理

[复制链接]

尚未签到

发表于 2018-1-16 06:54:43 | 显示全部楼层 |阅读模式
[iyunv@115~~]#git push origin master  
除了master之外,我们还可以随便创建分支,然后push到服务器上去。
  

  
[iyunv@115~~]#git push -u origin prepub
  
Counting objects: 27, done.
  
Delta compression using up to 2 threads.
  
Compressing objects: 100% (15/15), done.
  
Writing objects: 100% (15/15), 7.30 KiB, done.
  
Total 15 (delta 10), reused 0 (delta 0)
  
To git@search.ued.taobao.net:projects/search.git
  
1b95a57..779dbe1 prepub -> prepub
  

  
远程分支的标识形式为{remote/branch},比如origin/product。
  
[iyunv@115~~]#git branch -a
  
master
  
p4popt
  
* prepub
  
product
  
remotes/origin/HEAD -> origin/master
  
remotes/origin/master
  
remotes/origin/p4popt
  
remotes/origin/prepub
  
remotes/origin/product
  

  
远程分支和本地分支需要区分,所以,在从服务器上拉取特定分支的时候,需要指定本地分支名字。
  
[iyunv@115~~]#git branch product origin/product
  
Branch product set up to track remote branch product from origin.
  
而1.6.2以上版本的git,可以通过--track选项,简化这一过程。这也是为什么直接执行git clone的时候,会自动创建本地master分支的原因。(实际上,pull操作相当于fetch+merge。)
  

  
[iyunv@115~~]#git checkout --track origin/product
  
Branch product set up to track remote branch refs/remotes/origin/product.
  
Switched to a new branch "product"
  
远程分支和本地分支是松散的结构,可以把任意远程分支合并到任意本地分支里;同样,也可以把任意本地分支push到任意远程分支上。
  
# THIS WILL MESS UP YOUR REPO!!
  
[iyunv@115~~]#git branch
  
master
  
* prepub
  
p4popt
  
product
  
[iyunv@115~~]#git pull origin product
  
[iyunv@115~~]#git push origin master
  
同步本地远程分支。
  
[iyunv@115~~]#git fetch origin
  
删除远程分支。
  
[iyunv@115~~]#git push origin :p4popt
  
To git@search.ued.taobao.net:projects/search.git
  
- [deleted] p4popt
  
补充:git cherry-pick和git rebase
  
git cherry-pick可以选择某一个分支中的一个或几个commit(s)来进行操作。例如,假设我 们有个稳定版本的分支,叫v2.0,另外还有个开发版本的分支v3.0,我们不能直接把两个分支合并,这样会导致稳定版本混乱,但是又想增加一个v3.0 中的功能到v2.0中,这里就可以使用cherry-pick了。
  


  
先在v3.0中查看要合并的commit的commit>  
[iyunv@115~~]#git log
  
假设是 commit f79b0b1ffe445cab6e531260743fa4e08fb4048b
  

  
切到v2.0中
  
[iyunv@115~~]#git check v2.0
  

  
合并commit
  
[iyunv@115~~]#git cherry-pick f79b0b1ffe445cab6e531260743fa4e08fb4048b
  
git rebase有点类似git merge,但是两者又有不同,打个比方,你有两个抽屉A和B,里面都装了衣服,现在想把B中的衣服放到A中,git merge是那种横冲直撞型的,拿起B就倒入A里面,如果满了(冲突)再一并整理;而git rebase就很持家了,它会一件一件的从B往A中加,会根据一开始放入的时间顺序的来加,如果满了你可以处理这一件,你可以继续加,或者跳过这一件,又 或者不加了,把A还原。所以merge适合那种比较琐碎的,简单的合并,系统级的合并还是用rebase吧。
  

  
合并b
  
[iyunv@115~~]#git rebase b
  

  
处理完冲突继续合并
  
[iyunv@115~~]#git rebase --continue
  

  
跳过
  
[iyunv@115~~]#git rebase --skip
  

  
取消合并
  
[iyunv@115~~]#git rebase --abort

运维网声明 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-435551-1-1.html 上篇帖子: git 创建新项目,下载工程,合并和更新工程简单应用记录 下篇帖子: 技术生活杂烩-迟到的博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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