Gerrit上分支操做记录(建立分支、删除分支)

 

Git分支对于一个项目的代码管理而言,是十分重要的!许多久用git的朋友可能已经掌握的很牢固了,但对于一些初涉git的童鞋来讲,可能还不是很熟悉。
在此,我将本身的一些操做经历作一梳理,但愿能帮助到有用到的朋友们。html

gerrit分支操做经常使用的命令能够参考:http://www.cnblogs.com/kevingrace/p/5690820.htmllinux

1)首先,利用gitlab进行建立分支
登录gitlab,建立组test,在这个组上建立工程apptest,而后让这个工程里添加内容
注意:在添加内容的使用,咱们能够自定义分支名,这个分支就是咱们想要建立的分支
以下截图:ios

 

这样,就建立了三个分支:master(默认),test,devgit

特别注意:web

后面建立的分支都是之前面当前分支为源建立的vim

因此新建立分支的文件都会包括前面的分支的文件,应该将和前面分支重复的文件删除!bash

如:服务器

master分支下是testfile文件app

test分支下是testfile文件、123文件,应该将testfile文件删除ssh

dev分支下是testfile文件、123文件、zhonghon文件,应该将testfile文件和zhonghon文件删除

 

以下:

 

在linux客户机上操做分支,修改分支下的代码并上传到远程的git分支上

[gerrit@115~]$  git clone git@103.10.86.30:test/apptest.git

[gerrit@115~]$ git branch -av         #查看当前分支状况,发现了上面在gitlab里面建立的三个分组master,dev,test

* master 1c2ecde 12                       #发现当前在master分支下(*指向master)
remotes/origin/HEAD -> origin/master
remotes/origin/dev 6eae416 234
remotes/origin/master 1c2ecde 12
remotes/origin/test d5b51b9 Delete zhonghogn

[gerrit@115~]$ vim .gitrevirw

[gerrit@115~]$ vim .testr.conf

[gerrit@115~]$ git add .

[gerrit@115~]$ git commit -m “add on master"

[gerrit@115~]$ git push -u origin master          #提交到master分支下,查看gitlab上apptest工程下的master分支,已经有这两个文件

 

接着选择一个非master的分支,如dev分支,修改里面的代码

[gerrit@115~]$ git branch dev remotes/origin/dev      #先将远程gitlab上建立的分支在本地别名化

[gerrit@115~]$ git checkout dev         #使用git checkout命令切换到dev分支下
Switched to branch 'dev'
[gerrit@115~]$ git branch -av        #查看当前分支,发现本地有了dev分支了(上面设置过的分支别名)
* dev 6eae416 234
master 1c2ecde 12
remotes/origin/HEAD -> origin/master
remotes/origin/dev 6eae416 234
remotes/origin/master 1c2ecde 12
remotes/origin/test d5b51b9 Delete zhonghogn

[gerrit@115~]$ vim .gitrevirw            #修改dev分支下的代码  

[gerrit@115~]$ vim .testr.conf

[gerrit@115~]$ git add .

[gerrit@115~]$ git commit -m “add on dev"

[gerrit@115~]$ git push -u origin dev             #注意,这里提交到dev分支下
Counting objects: 5, done.
Delta compression using up to 32 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 535 bytes, done.
Total 4 (delta 0), reused 0 (delta 0)
To git@103.10.86.30:test/apptest.git
7a4b6e6..6eae416 dev -> dev
Branch dev set up to track remote branch dev from origin.

git push -u origin dev
Counting objects: 5, done.
Delta compression using up to 32 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 535 bytes, done.
Total 4 (delta 0), reused 0 (delta 0)
To git@103.10.86.30:test/apptest.git
7a4b6e6..6eae416 dev -> dev
Branch dev set up to track remote branch dev from origin.

这样就能push到远程的remotes/origin/dev 上了,去gitlab上看看dev分支下已经有了这两个文件.gitreview和.testr.conf

以下:

 

其余的分支如上面gitlab里的test分支,要想弄到本地,操做和上面的dev分支操做同样

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

 

线上部署了gerrit+gitlab环境(代码同步),将git代码放到上面进行维护管理了!

应开发同事要求,要在他们的项目下建立除master默认分支以外的其余分支

在gerrit上建立分支,这里我总结了下面两种状况的操做,在此作一详细记录:

 (1)

第一种状况:gerrit上尚未建立项目

《gerrit上的项目最好是从gitlab上git clone --bare过来,而且项目不要为空》

思路:

先在gitlab上建立分支(上面截图),而后在linux服务器(这里选择gerrit本机)git clone下载gitlab里的项目(如上面的apptest)

最后将整个项目发布到gerrit上

关于怎么在gerrit上设置项目,你们可参考个人另外一片博客,里面有详细介绍(http://www.cnblogs.com/kevingrace/p/5651447.html

《注意,上面在新分支下添加的.gitreview文件必定要有,否则就不能使用git review命令提交代码审核了,具体上面参考的另外一篇博客中有说明》

在gerrit的一个普通用户如wangshibo下操做:

若是修改apptest项目的非master分支下的代码,如上面的dev分支

用 gerrit用户在 Gerrit 上建立 test-project1 项目
要知道 review 是在 gerrit 上,而 gerrit 上如今是没有项目的,想让 gitlab 上的项目能在 gerrit 上 review 的话,必须在 gerrit 上建立相同的项目,并有相同的仓库文件.

用 gerrit用户在 Gerrit 上建立 apptest 项目
[gerrit@115]$ ssh-gerrit gerrit create-project apptest      #这时候gerrit上其实已经有apptest项目了
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
ssh-gerrit是别名
[gerrit@115r ~]$ cat ~/.bashrc
# .bashrc

 

# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
alias ssh-gerrit='ssh -p 29418 -i ~/.ssh/id_rsa 103.10.86.30 -l gerrit'
# User specific aliases and functions
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

虽然上面建立了apptest项目,而且gerrit界面里已经有这个项目,可是个空目录
咱们须要将Gitlab上的apptest项目发布到gerrit上
在此须要用到git clone –bare 命令
[gerrit@115]$ cd /home/gerrit/gerrit_site/git/        #即登录到gerrit安装目录的git下
[gerrit@115 git]$ rm -fr apptest.git
[gerrit@115 git]$ git clone --bare git@103.10.86.30:test/apptest.git
[gerrit@115 git]$ ls
All-Projects.git All-Users.git apptest.git
[gerrit@115 git]$ cd apptest.git/
[gerrit@115 git]$ ls              #即test-project1工程和gerrit里默认的All-Projects.git工程结构是同样的了
branches config description HEAD hooks info objects packed-refs refs


登录gerrit界面,发现apptest工程已经建立了。

 

 

接着修改非master分支,好比dev分支的代码并提交到gerrit里审核

[root@115~]# su - wangshibo    #切换到gerrit的用户用户wangshibo下

[wangshibo@115~]$ git branch -av            #查看本地的分支结构

* master 1c2ecde 12
remotes/origin/HEAD -> origin/master
remotes/origin/dev 6eae416 234
remotes/origin/master 1c2ecde 12
remotes/origin/test d0ef218 444

[wangshibo@115~]$ git branch dev remotes/origin/dev    将远程分支本地别名化

[wangshibo@115~]$ git checkout dev           # 切换到dev分支下

[wangshibo@115~]$ vim haha

[wangshibo@115~]$git add haha

[wangshibo@115~]$git commit -m "23232323"

[wangshibo@115~]$git review dev             #提交代码审核的时候,注意要指定提交到分支dev上审核

而后用wangshibo用户登陆gerrit,进行审核

审核经过后,经过apptest的dev分支的gitweb就能查看到提交的代码,以下:

 

 

 

 

Gerrit里面分支代码审核经过后,会自动同步到Gitlab上相应工程的分支下的

也就是说:Gerrit到Gitlab的同步策略包含全部的分支!

 

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

第二种状况:gerrit上已经建立好了项目,后续建立分支并插入到gerrit的项目里:

【gerrit上对应项目的access的refs/heads/*的“push”权限能够运行推送代码和分支到gerrit上;“Create Reference”权限运行建立分支;】

首先在gerrit界面建立分支(这里新建立分支ops),以下:

管理员账号登录gerrit,点击apptest项目的Branches->Create Branch  (默认的initial Revision是HEAD)

刚建立后,会发现新分支和mater分支的Revision一致,HEAD指针是一致的

 

接着在本地git clone把代码从新克隆下来,

好比上面在gerrit里已经建立好了apptest项目,将这个项目clone到本地

 

 

[gerrit@115~ ]$ git clone ssh://gerrit@103.10.86.30:29418/apptest && scp -p -P 29418 gerrit@103.10.86.30:hooks/commit-msg apptest/.git/hooks/

[gerrit@115~ ]$ cd apptest

[gerrit@115~ apptest]$ git branch -av         #查看分支状况,已经能够发现gerrit界面里建立的新分支ops
* master 486e140 Merge "123"         #当前在master分支下
remotes/origin/HEAD -> origin/master
remotes/origin/dev 27a1d5c 343434
remotes/origin/master 486e140 Merge "123"     #新分支刚建立时,跟当前所在分支的ID是一致的
remotes/origin/ops 486e140 Merge "123"
remotes/origin/test d0ef218 444

[gerrit@115~ apptest]$ git checkout -b ops remotes/origin/ops     #将新建分支在本地别名化,并切换进去
Branch ops set up to track remote branch ops from origin.
Switched to a new branch 'ops'
[gerrit@115~ apptest]$ git branch -av      再查看,发现当前分支就是ops了
master 486e140 Merge "123"
* ops 486e140 Merge "123"
remotes/origin/HEAD -> origin/master
remotes/origin/dev 27a1d5c 343434
remotes/origin/master 486e140 Merge "123"
remotes/origin/ops 486e140 Merge "123"
remotes/origin/test d0ef218 444

千万记住一点::

新分支建立后,是和建立时的当前所在分支下的内容是一致的。

切换到新建分之之后,若是不清空当前内容,直接push上去,那该分支代码和你切换以前的分支是同样的。

因此要删除新分支里的内容,而后再push提交,提交后查看分支状况,就会发现新建分支和以前的分支的 Revision指向就不同了,以下:

[gerrit@115~apptest]$ rm -rf ./*
[gerrit@115~ apptest]$ git add .
[gerrit@115~ apptest]$ git commit -am "222"    #由于前面是直接rm删除的,因此这里commit要多加一个-a,若是是git rm删除就不用加-a
[ops 3a26276] 222
2 files changed, 0 insertions(+), 2 deletions(-)
delete mode 100644 haha
delete mode 100644 zhonghogn
[gerrit@Zabbix-server apptest]$ git push -u origin ops       #这里是gerrit管理员下,因此能够直接push,普通用户就git review ops了
Counting objects: 3, done.
Delta compression using up to 32 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (2/2), 246 bytes, done.
Total 2 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1)
remote: Processing changes: refs: 1, done
To ssh://gerrit@103.10.86.30:29418/apptest
486e140..3a26276 ops -> ops
Branch ops set up to track remote branch ops from origin.

 

这时候再查看分支状况,就会发现ops分支和master分支的ID不同了

[gerrit@Zabbix-server apptest]$ git branch -av
master 486e140 Merge "123"
* ops 3a26276 222
remotes/origin/HEAD -> origin/master
remotes/origin/dev 27a1d5c 343434
remotes/origin/master 486e140 Merge "123"
remotes/origin/ops 3a26276 222
remotes/origin/test d0ef218 444

再次登陆gerrit界面,就会发现Revision天然也就不一致了,ops分支下的内容和master分支下的内容也不同了

 ops分支下这个时候仍是空的(上面已经清空了)

 

接着就能够往ops分支里建立或修改代码了,以下:

[root@115~ ]# su - wangshibo                 #切换到gerrit普通用户wangshibo帐号下操做
[wangshibo@115~ ]$ git clone ssh://gerrit@103.10.86.30:29418/apptest && scp -p -P 29418 gerrit@103.10.86.30:hooks/commit-msg apptest/.git/hooks/
[wangshibo@115~ ]$ cd apptest/
[wangshibo@115~ ]$ git branch -av              #查看分支,当前分支是master
* master 486e140 Merge "123"
remotes/origin/HEAD -> origin/master
remotes/origin/dev 27a1d5c 343434
remotes/origin/master 486e140 Merge "123"
remotes/origin/ops 3a26276 222
remotes/origin/test d0ef218 444
[wangshibo@115~ ]$ git checkout -b ops remotes/origin/ops          #将远程分支本地别名化
Branch ops set up to track remote branch ops from origin.
Switched to a new branch 'ops'
[wangshibo@115~ ]$ git branch -av              #发现当前分支已是ops了
master 486e140 Merge "123"
* ops 3a26276 222
remotes/origin/HEAD -> origin/master
remotes/origin/dev 27a1d5c 343434
remotes/origin/master 486e140 Merge "123"
remotes/origin/ops 3a26276 222
remotes/origin/test d0ef218 444
[wangshibo@115~ ]$ ls                                 #没有内容,上面已经提到,切换后就讲内容清空了
[wangshibo@115~ ]$ vim testfile                   #新增内容
[wangshibo@115~ ]$ git add testfile
[wangshibo@115~ ]$ git commit -m "branch test"
[ops ba9572e] branch test
1 files changed, 2 insertions(+), 0 deletions(-)
create mode 100644 testfile
[wangshibo@115~ ]$ git review ops                #提交代码审核,提交是指定到分支ops里
Creating a git remote called "gerrit" that maps to:
ssh://wangshibo@103.10.86.30:29418/apptest.git
remote: Processing changes: new: 1, refs: 1, done
remote:
remote: New Changes:
remote: http://103.10.86.30:80/64 branch test
remote:
To ssh://wangshibo@103.10.86.30:29418/apptest.git
* [new branch] HEAD -> refs/publish/ops

 

登录gerrit,就会发现有个review的审核请求了

 

经过审核

 

 

 

这个时候,review审核已经经过了

经过apptest项目的ops分支的gitweb就能看到新增的代码了

 

 

 

最后,登录Gitlab,就能发现相应项目的分支代码也都同步过来了(前提是gerrit里面作了相应的replication同步配置)!很神奇的~~~~~

 

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

如何删除gerrit界面上建立的分支?也能够理解在本地如何删除远程分支:

 

git 删除远程分支
一不当心把本地的临时分支push误提交到server上去了,想要删除。
[wangshibo@115 ~]$ git branch -av
master
remote/origin/master
remote/origin/origin/master     #这个就是误提交的分支

 

这个时候,执行下面命令便可删除远程分支
[wangshibo@115 ~]$git push origin :origin/master

 

冒号前面的空格不能少,原理是把一个空分支push到server上,至关于删除该分支。其实也是一个push推送过程,只不过是推送的空的而已!

 

好比下面一例,在本地误提交了一个分支到远程的gerrit上了!如今须要删除。

[wangshibo@115 GItLearn]$ 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
remotes/origin/remotes/origin/devlop dc21d7f 123          #删除这个多余的分支

 

[wangshibo@115 GItLearn]$ git push origin :remotes/origin/devlop
remote: Processing changes: refs: 1, done
To ssh://wangshibo@103.11.186.130:29418/GItLearn
- [deleted] remotes/origin/devlop
[wangshibo@115 GItLearn]$ git branch -av #再次查看,上面多余的分支已经删除了!
devlop dc21d7f 123
* master 44f4b3a Add new file
remotes/origin/HEAD -> origin/master
remotes/origin/dev 44f4b3a Add new file
remotes/origin/master 44f4b3a Add new file

 

再次登录gerrit查看,上面多余的分支就没有了!

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

如何在本地建立分支,而后上传到gerrit上?也能够理解为在本地建立分支,而后推送到远程新分支上:

命令格式以下:
#git push origin local_branch:remote_branch

注意:
这个操做,local_branch必须为你本地存在的分支,remote_branch为远程分支,若是remote_branch不存在则会自动建立分支。

只不过这个上传到远程后,分支内容是和master分支内容是同样的!

另外:
#git push origin :remote_branch
上面的local_branch留空(即冒号前面留有空格),则是删除远程remote_branch分支。(上面已经提到了!)

 

以下面的例子:
[wangshibo@115 GItLearn]$ 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


本地建立分支devlop,而后上传到gerrit上:
[wangshibo@115 GItLearn]$ git branch devlop                #新建devlop分支
[wangshibo@115 GItLearn]$ git branch -av
devlop 44f4b3a Add new file
* 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 GItLearn]$ git push origin devlop:devlop       #上传到远程gerrit上,gerrit上若没有devlop,则会自动建立
Total 0 (delta 0), reused 0 (delta 0)
remote: Processing changes: refs: 1, done
To ssh://wangshibo@103.10.86.30:29418/GItLearn
* [new branch] devlop -> devlop
[wangshibo@115 GItLearn]$ git branch -av         #再次查看,发现已经上传到远程gerrit上了
devlop 44f4b3a Add new file
* master 44f4b3a Add new file
remotes/origin/HEAD -> origin/master
remotes/origin/dev 44f4b3a Add new file
remotes/origin/devlop 44f4b3a Add new file
remotes/origin/master 44f4b3a Add new file

 

登录gerrit查看,发现已经有了这个分支了!【这样上传后,分支内容和master分支内容是同样的,由于在本地建立devlop分支的时候,当前分支是master】

 

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

将远程gerrit上的代码分支迁移到本地新的gerrit分支上
迁移流程:
1.先将远程gerrit整个代码clone到本地(默认迁移过来后的当前分支是master)
2.clone到本地后,查看分支列表
3.在本地gerrit上建立同名分支
4.切换到clone下来的代码的各个分支,而后将分支内容push到本地新gerrit上的同名分支上

*******把本地仓库提交到远程仓库的master分支中(其余分支操做同样)git push ssh://gerrit@103.10.86.30:29418/apptest_ios.git master #或者像上面同样,将远程分支本地化,而后一步步提交

相关文章
相关标签/搜索