以文本方式查看主题 - 中文XML论坛 - 专业的XML技术讨论区 (http://bbs.xml.org.cn/index.asp) -- 『 操作系统原理 』 (http://bbs.xml.org.cn/list.asp?boardid=63) ---- [分享]Linux内核开发的版本控制工具Git中文教程 (http://bbs.xml.org.cn/dispbbs.asp?boardid=63&rootid=&id=57841) |
-- 作者:longshentailang -- 发布时间:1/8/2008 7:51:00 PM -- [分享]Linux内核开发的版本控制工具Git中文教程 介绍 Git --- The stupid content tracker, 傻瓜内容跟踪器。Linus 是这样给我们介绍 Git 的。 Git 是用于 Linux 内核开发的版本控制工具。与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持,使源代码的发布和交流极其方便。 Git 的速度很快,这对于诸如 Linux kernel 这样的大项目来说自然很重要。 Git 最为出色的是它的合并跟踪(merge tracing)能力。 实际上内核开发团队决定开始开发和使用 Git 来作为内核开发的版本控制系统的时候, 世界开源社群的反对声音不少,最大的理由是 Git 太艰涩难懂,从 Git 的内部工作机制来说,的确是这样。 但是随着开发的深入,Git 的正常使用都由一些友好的脚本命令来执行,使 Git 变得非常好用, 即使是用来管理我们自己的开发项目,Git 都是一个友好,有力的工具。 现在,越来越多的著名项目采用 Git 来管理项目开发,例如:wine, U-boot 等,详情看 http://www.kernel.org/git 作为开源自由原教旨主义项目,Git 没有对版本库的浏览和修改做任何的权限限制。 它只适用于 Linux / Unix 平台,没有 Windows 版本,目前也没有这样的开发计划。 本文将以 Git 官方文档 Tutorial, core-tutorial 和 Everyday GIT 作为蓝本翻译整理,但是暂时去掉了对 Git 内部工作机制的阐述, 力求简明扼要,并加入了作者使用 Git 的过程中的一些心得体会,注意事项,以及更多的例子。 建议你最好通过你所使用的 Unix / Linux 发行版的安装包来安装 Git, 你可以在线浏览本文 ,也可以通过下面的命令来得到本文最新的版本库,并且通过后面的学习用 Git 作为工具参加到本文的创作中来。 $ git-clone http://www.bitsun.com/git/gittutorcn.git 创建一个版本库:git-init-db 创建一个 Git 版本库是很容易的,只要用命令 git-init-db 就可以了。 现在我们来为本文的写作创建一个版本库: $ mkdir gittutorcn git 将会作出以下的回应 defaulting to local storage area 这样,一个空的版本库就创建好了,并在当前目录中创建一个叫 .git 的子目录。 你可以用 ls -a 查看一下,并请注意其中的三项内容: * 一个叫 HEAD 的文件,我们现在来查看一下它的内容: $ cat .git/HEAD 现在 HEAD 的内容应该是这样: ref: refs/heads/master 我们可以看到,HEAD 文件中的内容其实只是包含了一个索引信息, 并且,这个索引将总是指向你的项目中的当前开发分支。 一个叫 objects 的子目录,它包含了你的项目中的所有对象,我们不必直接地了解到这些对象内容, 我们应该关心是存放在这些对象中的项目的数据。 一个叫 refs 的子目录,它用来保存指向对象的索引。 具体地说,子目录 refs 包含着两个子目录叫 heads 和 tags, 就像他们的名字所表达的意味一样:他们存放了不同的开发分支的头的索引, 或者是你用来标定版本的标签的索引。 请注意:master 是默认的分支,这也是为什么 .git/HEAD 创建的时候就指向 master 的原因,尽管目前它其实并不存在。 git 将假设你会在 master 上开始并展开你以后的工作,除非你自己创建你自己的分支。 另外,这只是一个约定俗成的习惯而已,实际上你可以将你的工作分支叫任何名字, 而不必在版本库中一定要有一个叫 master 的分支,尽管很多 git 工具都认为 master 分支是存在的。 现在已经创建好了一个 git 版本库,但是它是空的,还不能做任何事情,下一步就是怎么向版本库植入数据了。 为了简明起见,我们创建两个文件作为练习: $ echo "Hello world" > hello 我们再用 git-add 命令将这两个文件加入到版本库文件索引当中: $ git-add hello example git-add 实际上是个脚本命令,它是对 git 内核命令 git-update-index 的调用。 因此上面的命令和下面的命令其实是等价的: $ git-update-index --add hello example 如果你要将某个文件从 git 的目录跟踪系统中清除出去,同样可以用 git-update-index 命令。例如: $ git-update-index --force-remove foo.c Note 应该建立一个清晰的概念就是,git-add 和 git-update-index 只是刷新了 git 的跟踪信息,hello 和 example 这两个文件中的内容并没有提交到 git 的内容跟踪范畴之内。 既然我们刷新了 Git 的跟踪信息,现在我们看看版本库的状态: $ git-status 我们能看到 git 的状态提示: # 提示信息告诉我们版本库中加入了两个新的文件,并且 git 提示我们提交这些文件, 我们可以通过 git-commit 命令来提交: $ git-commit -m "Initial commit of gittutor reposistory" 查看当前的工作:git-diff git-diff 命令将比较当前的工作目录和版本库数据库中的差异。 现在我们编辑一些文件来体验一下 git 的跟踪功能。 $ echo "It's a new day for git" >> hello 我们再来比较一下,当前的工作目录和版本库中的数据的差别。 $ git-diff 差异将以典型的 patch 方式表示出来: diff --git a/hello b/hello 此时,我们可以再次使用组合命令 git-update-index 和 git-commit 将我们的工作提交到版本库中。 $ git-update-index hello 实际上,如果要提交的文件都是已经纳入 git 版本库的文件,那么不必为这些文件都应用 git-update-index 命令之后再进行提交,下面的命令更简捷并且和上面的命令是等价的。 $ git-commit -a -m "new day for git" 管理分支:git-branch 直至现在为止,我们的项目版本库一直都是只有一个分支 master。 在 git 版本库中创建分支的成本几乎为零,所以,不必吝啬多创建几个分支。 下面列举一些常见的分支策略,仅供大家参考: * 创建一个属于自己的个人工作分支,以避免对主分支 master 造成太多的干扰, 也方便与他人交流协作。 当进行高风险的工作时,创建一个试验性的分支,扔掉一个烂摊子总比收拾一个烂摊子好得多。 合并别人的工作的时候,最好是创建一个临时的分支,关于如何用临时分支合并别人的工作的技巧, 将会在后面讲述。 创建分支 下面的命令将创建我自己的工作分支,名叫 robin,并且将以后的工作转移到这个分支上开展。 $ git-branch robin 删除分支 要删除版本库中的某个分支,使用 git-branch -D 命令就可以了,例如: $ git-branch -D branch-name 查看项目的发展变化和比较差异 这一节介绍几个查看项目的版本库的发展变化以及比较差异的很有用的命令: 我们现在为 robin, master 两个分支都增加一些内容。 $ git-checkout robin $ git-checkout master git-show-branch 命令可以使我们看到版本库中每个分支的世系发展状态, 并且可以看到每次提交的内容是否已进入每个分支。 $ git-show-branch 这个命令让我们看到版本库的发展记录。 * [master] Some fun 譬如我们要查看世系标号为 master^ 和 robin 的版本的差异情况, 我们可以使用这样的命令: $ git-diff master^ robin 我们可以看到这两个版本的差异: diff --git a/hello b/hello Note 我们现在再用 git-whatchanged 命令来看看 master 分支是怎么发展的。 $ git-checkout master diff-tree 1d2fa05... (from 3ecebc0...) Some fun :100644 100644 f24c74a... 7f8b141... M example diff-tree 3ecebc0... (from 895f09a...) a new day for git :100644 100644 557db03... 263414f... M hello 从上面的内容中我们可以看到,在 robin 分支中的日志为 "Some work" 的内容, 并没有在 master 分支中出现。 既然我们为项目创建了不同的分支, 那么我们就要经常地将自己或者是别人在一个分支上的工作合并到其他的分支上去。 现在我们看看怎么将 robin 分支上的工作合并到 master 分支中。 现在转移我们当前的工作分支到 master,并且将 robin 分支上的工作合并进来。 $ git-checkout master 合并两个分支,还有一个更简便的方式,下面的命令和上面的命令是等价的。 $ git-checkout master 但是,此时 git 会出现合并冲突提示: Trying really trivial in-index merge... Automatic merge failed; fix up by hand git 的提示指出,在合并作用于文件 hello 的 'Some fun' 和 'some work' 这两个对象时有冲突, 具体通俗点说,就是在 master, robin 这两个分支中的 hello 文件的某些相同的行中的内容不一样。 我们需要手动解决这些冲突,现在先让我们看看现在的 hello 文件中的内容。 $ cat hello 此时的 hello 文件应是这样的,用过其他的版本控制系统的朋友应该很容易看出这个典型的冲突表示格式: Hello World 我们用编辑器将 hello 文件改为: Hello World 现在可以将手动解决了冲突的文件提交了。 $ git-commit -i hello 以上是典型的两路合并(2-way merge)算法,绝大多数情况下已经够用。 但是还有更复杂的三路合并和多内容树合并的情况。详情可参看: git-read-tree, git-merge 等文档。 git-reset 命令就是为这样的任务准备的。 它将当前的工作分支的 头 定位到以前提交的任何版本中,它有三个重置的算法选项。 git-reset [--mixed | --soft | --hard] [<commit-ish>] --mixed 一个重要技巧--逆转提交与恢复 可能有人会问,--soft 选项既不重置头索引的位置,也不改变工作树中的内容, 那么它有什么用呢?现在我们介绍一个 --soft 选项的使用技巧。 下面我们用例子来说明: $ git-checkout master 这里我们创建了一个 master 的拷贝分支 softreset, 现在我们可以看到两个分支是在同一起跑线上的。 ! [master] Merge branch 'robin' 我们为 文件增加一些内容并提交。 $ echo "Botch, botch, botch" >> hello 我们可以看到此时 softreset 比 master 推进了一个版本 "some botch" 。 ! [master] Merge branch 'robin' 现在让我们来考虑这样的一种情况,假如我们现在对刚刚提交的内容不满意, 那么我们再编辑项目的内容,再提交的话,那么 "some botch" 的内容就会留在版本库中了。 我们当然不希望将有明显问题的内容留在版本库中,这个时候 --soft 选项就很有用了。 为了深入了解 --soft 的机制,我们看看现在 softreset 分支的头和 ORIG_HEAD 保存的索引。 $ cat .git/refs/heads/softreset .git/ORIG_HEAD 结果如下: 5e7cf906233e052bdca8c598cad2cb5478f9540a 现在用 --soft 选项逆转刚才提交的内容: git-reset --soft HEAD^ 现在让我们再看看 .git/ORIG_HEAD 的中保存了什么? $ cat .git/ORIG_HEAD 结果如下: 5e7cf906233e052bdca8c598cad2cb5478f9540a 看!现在的 .git/ORIG_HEAD 等于逆转前的 .git/refs/heads/softreset 。 也就是说,git-reset --soft HEAD^ 命令逆转了刚才提交的版本进度, 但是它将那次提交的对象的索引拷贝到了 .git/ORIG_HEAD 中。 我们再编辑 hello 文件成为下面的内容: Hello World 我们甚至可以比较一下现在的工作树中的内容和被取消了的那次提交的内容有什么差异: $ git-diff ORIG_HEAD 结果如下: diff --git a/hello b/hello 接着,我们可以恢复刚才被取消了的那次提交了。 $ git-commit -a -c ORIG_HEAD 注意,这个命令会打开默认的文本编辑器以编辑原来提交的版本日志信息,我们改为 "nice work" 。 大家可以自行用 git-show-branch 命令来查看一下现在的分支状态。 并且我们还可以不断地重复上述的步骤,一直修改到你对这个版本进度满意为止。 git-reset 命令还有很多的用途和技巧,请参考 git-reset ,以及 Everyday GIT with 20 commands or So 。 |
-- 作者:longshentailang -- 发布时间:1/8/2008 8:00:00 PM -- 不知道大家是否用过这个版本控制工具,GIT也有Windows版本的,在http://code.google.com/p/msysgit/ 可看到链接,有网络下载版本和直接安装版本. WinGit即http://msysgit.googlecode.com/files/WinGit-0.1-alpha.exe 网上还有个视频很不错哈,是全英文的哈! |
W 3 C h i n a ( since 2003 ) 旗 下 站 点 苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》 |
8,574.707ms |