`
JohnShen0708
  • 浏览: 59435 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Git, Gerrit, Hudson (2) -- 使用GIT

阅读更多

 

1. 拷贝远程库

在 Git bash 中,使用以下命令拷贝远程库:

 

git clone review:<repository_name>

 

<repository_name> 是远程库的名称,例如:远程库叫 "ProjectA",使用以下命令:

 

git clone review:ProjectA

 

但是,如果使用的是 Tortoise 将不能使用这种简写的形式,得使用 URL 链接:

 

ssh://<username>@<Gerrit_host_name>:29418/ProjectA

 

注意:以上步骤并不能把 ProjectA 直接下下来,而是建立了连接,后面还需若干步骤来下载代码。

 

 

2. 建立“钩子”

你需要取得 Gerrit 的 Change-Id 的钩子(hook)。使用 Git bash 输入以下命令:

 

# 进入到刚才拷贝下来的远程库目录
cd ProjectA
# 从 server 上下载 “钩子”
scp -p review:hooks/commit-msg .git/hooks/

 

一个叫 "commit-msg" 的文件会被下载下来。

hooks 实际上是包含一系列命令的脚本,该脚本在 commit 时会被自动调用,你可以在服务器上放置这样的脚本,以统一客户端的提交行为 (或者其它需要统一的事情 )。

 

3. 可视化组件

git 有一个可视化工具:gitk,它可以展示每次的提交,也可以看到哪些被 merge ,以及 branch 上的情况,在命令行下输入以下命令:

 

# 显示当前所在分支( Branch )上的所有提交
gitk
# 显示所有分支的所有提交
gitk --all

 

4. 创建跟踪分支(Tracking Branches)

在第 1 步中的 git clone 命令会自动在本地创建一个叫 'master' 的分支跟踪远端库中的 master (即 'origin/master' )。而后可以使用 git branch 在本地创建分支来跟踪服务器上的远端分支( Remote Branches )。我们称这种本地分支为 Tracking Branch 。创建跟踪分支的命令如下:

 

git branch <tracking_branch> -t origin/<remote_branch>

例如:

 

git branch 1.0.0 -t origin/1.0.0

以上命令为:在本地创建 1.0.0 的分支来跟踪远端 1.0.0 分支( 即 'origin/1.0.0 )。然后,可以使用 checkout 命令将当前目录切换到 1.0.0 上去。

 

git checkout 1.0.0

以上两步可以合并为一步,创建 Tracking Branch 同时切过去:

 

git checkout -b 1.0.0 -t origin/1.0.0

注意:与 SVN 不同,checkout 在 git 中不是签出,而是切换到指定分支。签出是 git pull 。

 

5. 从 server 上更新

如果要从 server 上签出更新。首先,切换到想签出的分支上(如果当前不在该分支上),然后签出:

 

git checkout 1.0.0
git pull

git pull 针对于 Tracking Branch,对特征分支( Feature Branch ),需使用 git rebase 。

 

6. 创建特征分支( Feature Branch )

无论何时要对代码进行修改,总是应该先创建特征分支,然后在特征分支上进行修改。

首先,切换到跟踪分支上( 如果当前不在该分支上 ),签出更新:

 

git checkout 1.0.0
git pull

然后,在该跟踪分支上创建特征分支并切换到上面:

 

git checkout -b <feature_branch>

例如:

 

git checkout -b FixForBug1922

此处创建了一个叫 'FixForBug1922' 的特征分支。特征分支的应该总是取有意义的名字,最好能够概括本次修改的目的。远端服务器并不知道这个特征分支的存在,所以如果要对它进行更新,需要使用 git rebase 命令。

 

7.  备份特征分支

特征分支存于本地,如果需要把它备份到服务器上,使用如下命令:

 

git push origin +FixForBug1922:features/abc/FixForBug1922

该命令会将特征分支 'FixForBug1922' 备份至服务器,并称之为 'features/abc/FixForBug1922' 。

注意:此处的 '+' 号。在你 rebase 或 修改了本地代码后,希望再次备份时会产生作用。因为这意味着需要抛弃以前提交的备份,服务器需要知道你确切地知道自己在做什么。如果是第一次备份或没做任何修改,则不需要 '+' 号。

 

如果你要删除某特征分支,也可以选择相应的删除远端的备份:

 

# 删除本地的特征分支
git branch -D FixForBug1922

# 删除远端的对应备份
git push origin :features/abc/FixForBug1922

注意:删除远端备份也使用 push ,只不过这次将空 push 到了远端。

 

8.  提交文件

提交分为两步。首先,将要提交的文件加入( add )到临时区域( staging area )。这使你可以选择性提交( git 甚至允许只提交文件内的某些修改,参见 Pro GIT )。与 SVN 不同,无论对修改的还是新增的文件,都需要执行 add 命令。对 EGit 和 Tortoise 来说,当你选者文件并 commit 的时候,add 会被自动执行。

 

git add file1
git add file2
git commit

如果你十分有把握,目前所有的变化都是要提交的,可以使用一句话的简写:

 

git commit -a

注意:commit 只是提交到本地库。签入到 server 还需要其它步骤。下一步将看到如何修改提交。

 

9. 修改/撤销提交

如果是在同一个工作任务中,最好是修改以前的提交。这样在 code review 时因为只有一次提交需要审查,可以减少审查者的工作量。甚至在 review 以后,如果修改了代码也要修改前一次的提交( 针对同一次任务 )。因为此时你的修改会被放在同一提交中被 review,所有以前的 comments 都会被保留下来,并且还能比较前后的异同。

git add file1
git add file2
git commit --amend

如果要恢复已修改(但还未添加add)的文件,使用git checkout恢复:

git checkout -- <file_name>

如果要撤销已添加(但还未提交commit)的修改,使用git reset恢复:

git reset HEAD <file_name>

如果要撤回已提交(commit)的修改,使用git revert恢复:

# 恢复到最近一次提交
git revert HEAD
# 恢复到指定版本
git revert <commit_id>

 

10. 重新放置( rebase )特征分支

rebase 会将你的修改重新放置到一个更新的代码基础上。更多详情参见 Pro GIT

首先,从 server 上更新跟踪分支:

 

git checkout 1.0.1
git pull

然后重新放置特征分支:

 

git checkout FixForBug1922
git rebase 1.0.1

以上命令首先切换到特征分支 'FixForBug1922',然后将该特征分支上新的提交( commit )应用到 1.0.1 上去。

有可能会有冲突,如果需要,合并冲突,然后:

 

git commit
git add conflicted/file/1
git add another/conflicted/file
git rebase --continue

 

11. 签入代码,进行 review

代码提交完成后就可以上传代码至 Gerrit 并进行 review。Gerrit 是一款 review 工具,同时它也是中心库。命令如下:

 

git push origin FixForBug1922:refs/for/1.0.1/FixForBug1922

注意:如果在 master 上签入,则为:

 

git push origin master:refs/for/master

 

  • "git push origin": 告诉 git 上传更改至 server 上的某个 branch 。
  • "FixForBug1922:refs/for/1.0.1/FixForBug1922": 告诉 git 将本地的 'FixForBug1922' 的更改提交到服务器上 'refs/for/1.0.1/FixForBug1922' 分支上去。 

如果我们不需要 review ,可以将代码提交到 'refs/heads/1.0.1' 分支上。

 

  • "refs/for/1.0.1": 这告诉 Gerrit 有更改需要被 review ,如果 review 通过,代码将被合入到分支 '1.0.1' 中去。
  • "/FixForBug1922": 这是一个可选标签,它能将一系列的 review 组到一起( 如果它们确实应该分在一起 )。

注意:你的特征分支是从哪个分支创建的,就要提交到哪个分支上,否则 Gerrit 会认为你想把一个分支上的所有提交都合并到另一个分支上。

 

12. 向上合并更新

如果要避免一次艰难痛苦的合并,最好的办法是经常合并

我们应该避免只更新部分版本,并且最好是整个分支的进行合并。基于这个理由我们应该总是向上合并而不是向下合并。

例如:你可以合并整个 '1.0.1' 分支到 'master' ,因为 'master' 应该总是包含了 '1.0.1' 分支中的所有更改,而不应该从 'master' 到 '1.0.1' 分支,因为 'master' 中可能包含了很多不稳定的代码。( 假设 '1.0.1' 已经是一个稳定版本 )

所以,在开发中应该遵循以下原则:

 

  1. 经常合并。最理想的情况是每一个稳定的提交都进行合并。
  2. 如果需要更改( 例如需要修正一个 bug ,该 bug 是先前的分支就有了只是现在才发现 )。从尽可能早的版本开始更改,合并。
  3. 沿着版本号挨个向上合并。例如:合并从 1.0.1 -> 1.0.2 -> 1.0.3 -> master ;而不是直接从 1.0.1 -> master 。
  4. 不要挑着更改,合并。

合并命令如下:

 

# 切换到目标分支
git checkout master
# 创建并切换到特征分支
git checkout -b toMergeBugFix1922
# 执行合并
git merge 1.0.1

# 如果出现冲突,解决冲突,然后:
# 1. 使用 add 命令告诉 git 我们已经解决了冲突
git add conflictedfile.txt
git add conflictcode.java
# 2. 提交合并
git commit

# 将合并提交 review
git push origin toMergeBugFix1922:refs/for/master

# 让某些人来做 review
分享到:
评论

相关推荐

    windows xp Git32 安装包 Git-2.10.0-32-bit

    总之,Git-2.10.0-32-bit是Windows XP用户进行版本控制的有力工具,尽管XP系统已经过时,但通过使用这个安装包,开发者仍然可以享受到Git带来的高效和便利。在使用过程中,记得定期检查更新,以获取最新的安全修复和...

    git开发工具Git-2.24.0.2-64-bit

    "Git-2.24.0.2-64-bit" 是Git的一个特定版本,适用于64位操作系统。这个版本可能包含了性能优化、新功能以及已知问题的修复。 Git的核心特性包括: 1. 分布式:每个开发者的本地机器上都有一个完整的版本库,无需...

    git-2.41.0-64-bit window版本

    Git-2.41.0-64-bit window版本是针对Windows操作系统的一个特定构建,提供64位架构的支持。这个版本的发布,意味着用户可以在Windows环境下享受到Git的最新功能和性能优化。 Git的核心特性包括: 1. 分布式:每个...

    Git-2.28.0-64-bit.exeGit-2.28.0-64-bit.exe

    Git-2.28.0-64-bit.exe Git-2.28.0-64-bit.exe Git-2.28.0-64-bit.exe

    Git安装包 Git-2.15.1.2-64-bit和Git-2.15.1.2-32-bit以及常用命令行PDF

    Git-2.15.1.2-64-bit和Git-2.15.1.2-32-bit是Git的两个不同版本,分别针对64位和32位操作系统。这两个安装包包含了完整的Git工具集,允许用户在本地进行版本控制操作,如创建仓库、提交更改、分支管理和合并代码等。...

    Git-2.26.0-64-32.zip

    Git-2.26.0是Git在2020年3月30日发布的最新版本,提供了对64位和32位操作系统的支持,确保了广泛的用户群体可以顺利使用。这个压缩包"Git-2.26.0-64-32.zip"包含了适用于不同系统架构的安装程序,分别是"Git-2.26.0-...

    Git-2.15.0-64-bit.exe

    Git-2.15.0-64-bit.exe 是Git的特定版本,专为Windows 64位操作系统设计。这个版本在2017年10月30日发布,意味着它是最新的维护构建,提供了最新的功能、改进和修复。 Git 2.15.0 版本包含了多项重要的更新和优化,...

    Git官方最新版下载 Git-2.18.0-64-bit 64位Windows版本

    2. Git-2.18.0新特性与改进: - 提高性能:新版本通常会优化内部算法,提升操作速度,例如克隆、提交和合并等。 - 新功能:可能包含了新的命令或对现有命令的增强,以满足更多样化的开发需求。 - 错误修复:修复...

    Git-2.13.2-64-bit

    Git-2.13.2-64-bit是Git的一个特定版本,适用于64位操作系统。在这个版本中,Git可能包含了各种性能优化、新特性和错误修复。 1. **Git的基本概念**: - **版本控制**:Git的核心功能是版本控制,它记录了代码的每...

    rh-git218-git-svn-2.18.2-1.el7.x86_64.rpm

    官方离线安装包,测试可用。使用rpm -ivh [rpm完整包名] 进行安装

    Git安装包Git-2.21.0-64-bit.zip

    Git安装包快速下载;git资源包,Git下载,Git压缩包;Git工具下载;Git-2.21.0-64-bit.zip;Git工具下载

    Git-2.30.1-64-bit

    Git-2.30.1-64-bit是Git的特定版本,适用于64位操作系统,它提供了稳定性和性能的保证,确保开发过程的可靠性和效率。这个版本是在Git的官方网站上发布的,因此可以确保其安全性和兼容性。 Git的核心功能包括: 1....

    Git-2.18.0-64-bit安装包.zip

    Git-2.18.0-64-bit安装包是专为Windows 64位操作系统设计的,确保在高性能的64位环境下运行时,Git的所有功能都能得到充分发挥。 Git的2.18.0版本是一个重要的更新,它可能包含了多项性能优化和新特性。例如,这个...

    Git-2.28.0-64-bit git安装包windos64位官方下载

    Git-2.28.0-64-bit.exe 是适用于Windows 64位操作系统的Git官方安装程序,该版本为2.28.0,意味着它包含了最新的功能和性能改进。 **Git基础概念** 1. **版本控制**:Git的核心功能是版本控制,它能跟踪文件和目录...

    git windows 工具Git-2.30.0-64-bit 最新版

    从git上下载太慢了,整整下了一中午,在此分享给大家,有用的拿去 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个...

    32位Windows版Git安装程序Git-2.11.0-32-bit.exe

    32位Windows版Git安装程序Git-2.11.0-32-bit.exe

    Git-2.12.0-64-bit 64位下载

    Git-2.12.0-64-bit 64位下载

    Git-2.45.2-64-bit.rar

    Git是世界上最流行的分布式版本控制系统,它允许开发人员协作开发软件,并跟踪每一次代码更改。...通过下载并使用"Git-2.45.2-64-bit.rar",开发人员可以确保他们拥有最新的Git版本,从而更好地支持他们的项目需求。

    git安装包git-2.34.0-64-bit.rar

    在安装"Git-2.34.0-64-bit.exe"时,可以选择自定义安装路径、选择是否关联文件类型以及是否在命令行中使用Git Bash。安装完成后,可以通过运行`git --version`命令验证Git是否成功安装。在实际工作中,不断实践和...

    git-lfs-windows-v3.2.0.exe

    git-lfs-windows-v3.2.0.exe

Global site tag (gtag.js) - Google Analytics