查看分支列表,带有*的分支表示是当前所在分支
[root@115~~]#git branch

查看分支详细情况 (推荐这种方式)
[root@115~~]#git branch -av

创建分支(比如devlop):
[root@115~~]#git branch devlop

切换已有分支
[root@115~~]#git checkout devlop

创建并切换分支(比如opstest):
[root@115~~]#git checkout -b opstest

将远程分支remotes/origin/testapp(比如通过git branch -av发现的)拉到本地,创建别名testapp并切换进去
[root@115~~]#git checkout -b testapp remotes/origin/testapp (当前已经切换到testapp)

删除分支(比如opstest)

[root@115~~]#git branch -d opstest

如果opstest分支有新内容没有提交的话,这样删除会有提示:

git branch -D opstest进行强制删除

**********************************************

如果opstest是当前所在分支,则删除不了!必须将其切换出去后才能删除
在gerrit界面上创建的分支,如下,直接删除是不行的!

[wangshibo@115~]$ git branch
* master
[wangshibo@115~]$ git branch -av
* master 44f4b3a Add new file
remotes/origin/HEAD -> origin/master
remotes/origin/dev 44f4b3a Add new file
remotes/origin/master 44f4b3a Add new file

[wangshibo@115 ]$ git branch -d remotes/origin/dev
error: branch 'remotes/origin/dev' not found.

正确删除方式是:

登陆gerrit服务器,找到gerrit安装目录的git/项目名称/refs/heads下删除dev

[gerrit@115]$ pwd
/home/gerrit/gerrit_site/git/GItLearn.git/refs/heads
[gerrit@115]$ ls
dev
[gerrit@115]$ ls
dev
[gerrit@115]$ rm -f dev
[gerrit@115]$ ls
[gerrit@115]$

这样,就成功删除了gerrit界面里创建的分支了!!

**************************************************

合并分支
比如将分支devlop合并到master分支下
注意:合并前要先切回到要并入的分支
[root@115~~]#git checkout master
[root@115~~]#git marge devlop

----------------------------------------------------------------
合并的时候,有时候会出现冲突
冲突的时候,git会报出哪些文件冲突,这时候需要手动解决完冲突方可提交。
[root@115~~]# git devlop master
Auto-merging index.html
CONFLICT (content): Merge conflict in index.html
Automatic merge failed; fix conflicts and then commit the result.

通过git status查看冲突文件。
[root@115~~]#git status
index.html: needs merge
# On branch master
# Changed but not updated:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# unmerged: index.html
#

打开index.html,git会在冲突位置做上标示。
<<<<<<< HEAD:index.html
<div id="footer">contact : email.support@github.com</div>
=======
<div id="footer">
please contact us at support@github.com
</div>
>>>>>>> iss53:index.html

解决完冲突,这时候需要手动标识该冲突已经解决,类似svn的resolved。
[root@115~~]#git add index.html
[root@115~~]#git status
# On branch master
# Changed but not updated:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: index.html
#

这时候就可以提交了。
[root@115~~]#git commit -m "合并分支devlop"
[master e3ece67] 合并分支devlop
1 files changed, 1 insertions(+), 0 deletions(-)
----------------------------------------------------------------

管理多个分支
前面提到,git非常推荐频繁使用分支,在大量分支的情况下,我们需要对分支做好管理(曾经一次上线,开了13个分支 = =)
通过-av可以看到最后一次提交日志。
[root@115~~]#git branch -av
* master b904c07 把丘迟的产品搜改动合并一下
p4popt 8b93380 p4p加上refpid,开发给出来的配置是 P4P_refpid
prepub a6cc66b P4P解析参数少一次替换,顺便解决\!失效的问题
product 301ae4e rankbar图片换成data uri

通过--merged和--no-merged来查看分支是否已经合并完成。
[root@115~~]#git branch --merged
* master
p4popt

[root@115~~]#git branch --no-merged
prepub
product

未合并的分支,在删除时会提示分支未合并。
[root@115~~]#git branch -d product
warning: deleting branch 'product' that has been merged to
'refs/remotes/s/product', but it is not yet merged to HEAD.
Deleted branch product (was 301ae4e).

分支管理流程
一般情况下,分支可以划分为长分支和短分支两种。
长分支

长期任务
prepub:上线前合并,根据上线列表,从各个分支中集中到该分支,统一部署提测
master:上线后合并,长期保留一个稳定可用的分支应付紧急任务
项目
较难解决的bug
新特性试验田
重构
长分支,经常会落后其他分支一大截,需要养成习惯,适时从其他重要分支进行合并, 尤其是项目分支 。
短分支

临时需求
小bug
分支可视化
git本身的log提供--gragh选项,可以提供字符界面的分支可视化视图。
[root@115~~]#git log --graph --pretty=oneline
| * 50cc7a78b7f2704a2014afa3667f6ac5b5b47374 merging refs/remotes/origin/prepub into HEAD
| |\
| | * 8f685bd1be3757effe32d6ff37f86bd07dd2b549 又被无情地冲掉了代码
| * | 75a17b4ad610327a9b0e1eecfc6c4bf9cade7359 修改icon
| |/
| * 146a0990de450c854b1a7d9995e12979fff2d537 merging refs/remotes/origin/prepub into HEAD
| |\
| | * 93b379680796eb443961bb8c59008f8ae5678be4 Merge branch 'prepub' of search.ued.taobao.net:projects/search into prepub
| | |\
| | * | 8b93380ccfb9020bf8f8e1e8a4a553601de3c788 p4p加上refpid,开发给出来的配置是 P4P_refpid
| * | | 08201de89834f6fecb195c2b7c3546b5cafccc85 秒杀折扣浮动层样式
| | |/
| |/|
| * | 0f4d1df17f79c7aa3ca3d36ab848c10b78029010 修改icon
| * | ae719fc29cc550321f284323db06a294b97c1398 p4p创意优化
| |/
| * a6d4501e1456589d30ab1a5800b651876629c8ca 修改icon

git还有很多GUI工具,可以提供可视化地分支走势图,比如gitk,qgit,GitX等等。
远程分支

至今为止,前面所有提到的概念都是直接本地操作的,并不需要任何网络连接。
而git本身是一个分布式代码管理工具(DVCS),所以分支管理上,存在本地分支和远程分支两种概念。
可以简单的理解,远程分支就是别人的本地分支push到服务器上的时候产生的。比如master就是一个最典型的远程分支(默认)。
[root@115~~]#git push origin master
除了master之外,我们还可以随便创建分支,然后push到服务器上去。

[root@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。
[root@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

远程分支和本地分支需要区分,所以,在从服务器上拉取特定分支的时候,需要指定本地分支名字。
[root@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。)

[root@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!!
[root@115~~]#git branch
master
* prepub
p4popt
product
[root@115~~]#git pull origin product
[root@115~~]#git push origin master
同步本地远程分支。
[root@115~~]#git fetch origin
删除远程分支。
[root@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 id
[root@115~~]#git log
# 假设是 commit f79b0b1ffe445cab6e531260743fa4e08fb4048b

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

# 合并commit
[root@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
[root@115~~]#git rebase b

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

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

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

总结Gerrit常用命令的更多相关文章

  1. ###Git 基础图解、分支图解、全面教程、常用命令###

    一.Git 基础图解 转自:http://www.cnblogs.com/yaozhongxiao/p/3811130.html Git 图解剖析 git中文件内容并没有真正存储在索引(.git/in ...

  2. Git配置和常用命令

    Git配置 git config --global user.name "hunng" git config --global user.email "huangthin ...

  3. git/repo常用命令

    Git作为广受欢迎的一款版本控制工具,它该如何通过命令行使用呢?本文为你揭晓浓缩精华精华版:git常用命令一览,含部分repo操作. 代码下载 repo init -- -->初始化需要下载的分 ...

  4. Linux 常用命令(持续补充)

    常用命令: command &:将进程放在后台执行 ctrl + z:暂停当前进程 并放入后台 jobs:查看当前后台任务 bg( %id):将任务转为后台执行 fg( %id):将任务调回前 ...

  5. LVM基本介绍与常用命令

    一.LVM介绍LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制LVM - 优点:LVM通常用于装备大量磁盘的系统,但它同样适 ...

  6. Linux学习笔记(一):常用命令

    经过统计Linux中能够识别的命令超过3000种,当然常用的命令就远远没有这么多了,按照我的习惯,我把已经学过的Linux常用命令做了以下几个方面的分割: 1.文件处理命令 2.文件搜索命令 3.帮助 ...

  7. git常用命令(持续更新中)

    git常用命令(持续更新中) 本地仓库操作git int                                 初始化本地仓库git add .                       ...

  8. 【原】npm 常用命令详解

    今年上半年在学习gulp的使用,对npm的掌握是必不可少的,经常到npm官网查询文档让我感到不爽,还不如整理了一些常用的命令到自己博客上,于是根据自己的理解简单翻译过来,终于有点输出,想学习npm这块 ...

  9. npm常用命令

    npm常用命令 环境:win7 npm 是什么 NPM(node package manager),通常称为node包管理器.顾名思义,它的主要功能就是管理node包,包括:安装.卸载.更新.查看.搜 ...

随机推荐

  1. C#知识点总结【2】

    此文章只是 记录在C#当中一些我个人认为比较重要的知识点,对于有些基础实现或者用法并未说明: 继承 C#当中可以实现两种继承方式 1.实现继承:一个类派生于一个类,它拥有基类的所有成员字段和函数. 2 ...

  2. android 事件

    package com.example.yanlei.my2; import android.app.Activity; import android.content.Context; import ...

  3. 浅谈Hex编码算法

    一.什么是Hex 将每一个字节表示的十六进制表示的内容,用字符串来显示. 二.作用 将不可见的,复杂的字节数组数据,转换为可显示的字符串数据 类似于Base64编码算法 区别:Base64将三个字节转 ...

  4. 朝花夕拾-android 一个注册新用户时,多步填写用户资料的框架

    源码地址:http://git.oschina.net/zj2012zy/Android-Demo/tree/master/AndroidDemo/setpregister 效果如下: 基本思路: 1 ...

  5. <极客学院>视频教程学习笔记-iOS中CALayer的使用

    <1>CALayer简介 1.CALayer一般作为UIView的容器而使用. 2.CALayer是一个管理者图片载体(image-based content)的层结构 3.直接修改单独创 ...

  6. win7共享文件夹给局域网

    1.设置共享   2.关闭"需要密码访问"          

  7. OOD沉思录 --- 类和对象的关系 --- 包含关系4

    4.9 在实现语义约束时,最好根据类定义来实现.但是这经常会导致泛滥成灾的类,在这种情况下约束应当在类的行为中实现,通常在类的构造函数中实现,但不是必须如此. 还是以汽车为例,我们看汽车的定义,为了集 ...

  8. Nginx为什么比Apache Httpd高效:原理篇

    一.进程.线程? 进程是具有一定独立功能的,在计算机中已经运行的程序的实体.在早期系统中(如linux 2.4以前),进程是基本运作单位,在支持线程的系统中(如windows,linux2.6)中,线 ...

  9. 一个完整的WSDL文档及各标签详解

    <?xml version="1.0" encoding="UTF8" ?> <wsdl:definitions targetNamespac ...

  10. c++基础回顾

    #include <iostream> #include <vector> #include <string> int main(int argc, const c ...