Git简介以及Git在CentOS上设置共享Repository

MedeUz 2012-02-01

   一直使用SVN至今,现在正好 SVN 的服务器硬盘挂掉了,再加上SVN早就用着不是很爽了(由其是在每一个目录下都会生成.svn目录、另外它的分支管理和切换更是麻烦),于是便尝试将公司的SCM工具 SVN切换至 GIT。对于GIT以前主要还是在github上fetch、pull开源代码时用用,很少把它用到实际工作管理中,这里是 Why Git is Better than X,可以看出GIT比起同类SCM确实不错,现在很多知名的项目都已经投向了git,如eclipse、ROR、andorid、iteye等等之类的。 

Git 简单介绍安装 Git 至Centos5创建团队共享资源库Git客户端工具 git-Tortoise-windowsGit hubGit常用命令

Git简单介绍

Git作为SCM工具与SVN最大的一个特点就是,SVN是基于服务器,而Git是分布式的(EverythingisLocal理念)。这便意味每个开发者本地都可以是"gitserver"库,能够[color=red]离线在本地进行版本管理,每个人都可以不受任何影响地维护自己的本地资源库(如果你希望的话,也可以合并他人或共享给其他人)。而SVN是每个人写完代码后都及时的checkin到服务器上,然后再checkout,然后再进行合并,在过程都需要依赖于服务器。

另外Git的好处实际上还有很多,可以看看http://whygitisbetterthanx.com、5-fundamental-differences-between-git-svn,其中还包括了与一些SCM工具如hgbzrsvnperforce进行对比。

安装Git至Centos5

在centos上安装git也是非常简单。几个简单的命令就可以搞定,我这里是centos5.5-x86_64-2.6.18core。

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. yum install git  

如果提示无法找到gitpackage的话,则执行以下命令,加入源信息:

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. vi /etc/yum.repos.d/epel.repo  

将以下信息粘贴至该文件中:

    
Conf代码  Git简介以及Git在CentOS上设置共享Repository
  1. [epel]  
  2. name=Extra Packages for Enterprise Linux 5 - $basearch  
  3. #baseurl=http://download.fedoraproject.org/pub/epel/5/$basearch  
  4. mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=epel-5&arch=$basearch  
  5. failovermethod=priority  
  6. enabled=1  
  7. gpgcheck=1  
  8. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL  
  9.   
  10. [epel-debuginfo]  
  11. name=Extra Packages for Enterprise Linux 5 - $basearch - Debug  
  12. #baseurl=http://download.fedoraproject.org/pub/epel/5/$basearch/debug  
  13. mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=epel-debug-5&arch=$basearch  
  14. failovermethod=priority  
  15. enabled=0  
  16. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL  
  17. gpgcheck=1  
  18.   
  19. [epel-source]  
  20. name=Extra Packages for Enterprise Linux 5 - $basearch - Source  
  21. #baseurl=http://download.fedoraproject.org/pub/epel/5/SRPMS  
  22. mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=epel-source-5&arch=$basearch  
  23. failovermethod=priority  
  24. enabled=0  
  25. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL  
  26. gpgcheck=1  

然后再执行:

Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. yum install git git-daemon  

如果安装完成之后提示了以下红色信息:

DownloadingPackages:

(1/3):perl-Error-0.17010-1.el5.noarch.rpm|26kB00:00

(2/3):perl-Git-1.7.4.1-1.el5.x86_64.rpm|28kB00:00

(3/3):git-1.7.4.1-1.el5.x86_64.rpm|4.5MB01:07

--------------------------------------------------------------------------------------------------------------------------------------------

Total68kB/s|4.6MB01:09

warning:rpmts_HdrFromFdno:HeaderV3DSAsignature:NOKEY,keyID217521f6

GPGkeyretrievalfailed:[Errno5]OSError:[Errno2]Nosuchfileordirectory:'/etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL'

原因是因为/etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL文件不存在,执行以下命令重新安装即可:

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. cd /etc/pki/rpm-gpg;wget http://download.fedora.redhat.com/pub/epel/RPM-GPG-KEY-EPEL; yum install git git-daemon;  

如果一切安装完成的话输入下面命令,即可以看到当前git版本:

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. git --version  

创建共享资源库

虽然刚才说道Git是“EverythingisLocal”,但是在实际的工作项目开发中,还是需要为每项目建立一个Git中央资源库,方便term中的开发人员进行开发协作。

创建一个repository也是非常简单的,只需要新建一个目录,然后使用gitinit即可:

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. cd /usr/local/;mkdir repos;cd repos;  
  2. git init   

    Initialized empty Git repository in /usr/local/repos/.git/ 

提示上以语句表示一个本地的repository已经创建好了,怎么样?简单吧。

当第一次创建好respository之后,如果我们将一些已有工程导入至该仓库中(类似svn中的import操作),只需要将工程目录copy至该repository下,然后通过:

   
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. git add .  
  2. git commit  

在commit时会提示让你加入提交注释,填写完注释之后直接:wq退出vi后,git会为你自动commit。当然你也可以直接使用-m参数添加注释,一步完成提交。

如果add的时候希望根据规则指定的部分文件,可通过:

  
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. git add -l .   

Adduntracked>>?

Prompthelp:

1-selectasingleitem

3-5-selectarangeofitems

2-3,6-9-selectmultipleranges

foo-selectitembasedonuniqueprefix

-...-unselectspecifieditems

*-chooseallitems

-(empty)finishselecting

git会列出所有untracked的文件,然后你可以用以上各种形式加入文件,如根据文件编号、根据前缀、正则等。

当我们的repository创建好之后,你可以在团队内共享该资源库。意思是让其它人能够对该资源库进行pull(checkout)或push(checkin)操作。对于git来说,有很多方式可以达到该目的(这篇文章列出来8种方式)。另外SVN共享respository的方式基于ApacheDAV模块方式;当然git也是支持这种方式的,不过我觉得最简单的方式是使用gitdeamon的方式,当然对于linuxer开发者来莫过于ssh方式比较适合。如果我们希望刚才的respository被其它人能够访问到,可通过使用以下命令启动git服务:

   
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. git daemon --reuseaddr --base-path=/usr/local/repos --export-all --verbose --enable=receive-pack &  

该命令会共享/usr/local/repos目录下的所有gitrepository,比如我在该目录下创建了一个"gitTest"repository,如果其它成员需要pull(checkout)的话则使用:

    
Shell代码  Git简介以及Git在CentOS上设置共享Repository
  1. git clone git://192.168.1.115/gitTest  

     Cloning into gitTest... 

remote:Countingobjects:3,done.

remote:Total3(delta0),reused0(delta0)

Receivingobjects:100%(3/3),done.

完成之后在当前目录clone一个名为gitTest的本地repository,在这个目录中可进行pull或push等任何操作,关于repository目录结构分析可以看看:http://book.git-scm.com/1_git_directory_and_working_directory.html

不得不说的是使用git-daemon方式话对于repository的用户、权限、访问控制等没有ssh或apacheDAV全面。

Git客户端工具gitTortoise-windows

对于在windows下使用过svn来说Tortoise肯定是不会陌生的,没错,它现在也有了forgit的Tortoise,可以从http://code.google.com/p/tortoisegit/找到它。当然在使用tortoisegit时它只作为一个git的guitools,你仍然需要在windows安装gitforwindows.

Github

这里需要值的一提的是GitHub,GitHub可以托管各种git库,并提供一个web界面,但与其它像SourceForge或GoogleCode这样的服务不同,GitHub的独特卖点在于从另外一个项目进行分支的简易性。为一个项目贡献代码非常简单︰首先点击项目站点的“fork”的按钮,然後将代码检出并将修改加入到刚才分出的代码库中,最後通过内建的“pullrequest”机制向项目负责人申请代码合并。已经有人将GitHub称为代码玩家的MySpace︰

 在GitHub进行分支就像在Myspace(或Facebook[...])进行交友一样,在社会关系图的节点中不断的连线。(参考百度百科)

Git常用命令

对于git的常用命令,就不再copy了,可以收藏以下url,需要的话可以查阅,当然最好用的莫过于githelp来的快。:

http://book.git-scm.com/index.html

http://git.or.cz/course/svn.html

http://www.kernel.org/pub/software/scm/git/docs/everyday.html

http://gitready.com/

相关推荐