简单方便Git的艰难第一步

简介:         现在Git已经是铺天盖地了,如果再不用尝试真的是要out了。于是决定在新的项目中应用Git。奋战了一个下午加另外2个小时,终于搞定。发现Git真的真的是很简单,超出我的意料。可是既然简单,为什么又是艰难的呢?因为从之前CVS、SVN的思路和使用习惯转过来的确有点费劲。

        现在Git已经是铺天盖地了,如果再不用尝试真的是要out了。于是决定在新的项目中应用Git。奋战了一个下午加另外2个小时,终于搞定。发现Git真的真的是很简单,超出我的意料。可是既然简单,为什么又是艰难的呢?因为从之前CVS、SVN的思路和使用习惯转过来的确有点费劲。

        问题一:Git的服务器版本是什么样的?如何安装?

        SVN是有一个svnserver,可以通过yum或者apt-get直接安装,那么Git的服务器版本是什么呢?通过yum search git,只发现了gitolite和gitosis好像和Server有点关系,而gitosis现在已经逐渐被gitolite所取代了。在Github上找到了gitolite的安装说明:http://sitaramc.github.com/gitolite/install.html,简单的不可思议,做了一遍后发现才发现的确是够用了,一句废话没有。

         在进行安装gitolite之前,需要安装git

# yum -y install git

         在服务器上安装gitolite的过程是:

         1. 以root身份登录,新建一个git用户,这个用户的主目录会用来存放Git Repository。 这个用户名并非一定要叫git,可以任意指定,只不过git是比较常用的,一看就知道这个账户的作用。        

# useradd -d /home/git git
# passwd git

          2. 以git身份登录服务器,安装gitolite。

$ git clone https://github.com/sitaramc/gitolite

 上面是先从Github获取gitolite,地址中的中https也可以替换成http或者git。 执行下面的命令完成安装:

$ gitolite/install -ln
上面的命令要求存在/home/git/bin目录,并且该目录在git账户的$PATH变量中。
       至此安装就告一段落了,接下来就是配置了。


       问题二、如何配置gitolite?

       之前在使用SVN时,为了通过HTTP访问,需要对Apache进行配置。那么gitolite是否也需要进行配置呢?答案当然是肯定的。

       前提是要先在管理员(以后负责维护Git的人员)上产生ssh public key,我是在Win7上有putty产生的,命名为kmeng.pub,上传到服务器上git的home目录下。然后执行下面命令:

$ gitolite setup -pk kmeng.pub
出乎意料的得到了一堆异常信息:

FATAL: have errors but logging failed!

open log failed: No such file or directory
die kmeng.pub must have exactly one line


请教了之前用过的同事,原来是因为这个是通过putty产生的,格式不正确,需要通过下面的命令转化openssh格式的:

$ ssh-keygen -i -f kmeng_o.pub > kmeng.pub
$ gitolite setup -pk kmeng.pub

命令执行完成后就会产生在/home/git目中在产生repositories目录。kmeng就作为管理员的名字了,也是git repository的第一个用户。

到现在配置也完成了,下面就是用法了。


         问题三、既然安装配置都完成了,应该怎么样新建一个项目呢?

         这个真的是有点出乎我的意料。Gitolite吧对服务器的维护也采用了普通的repository方式。首先在管理员的本地电脑上,克隆(相当于SVN的checkout)一份gitolite-admin项目:

git clone git@192.168.0.100:gitolite-admin

在本地就会签出一个gitolite-admin目录,其中包含了conf和keydir两个文件夹,conf中就是存放用户对不同repository的访问权限的配置,而keydir中就是用户的public key,现在里面就只包含了kmeng.pub.

        新建一个repository的方式实在出乎意料。首先编辑conf中的gitolite.conf,修改为:

repo gitolite-admin myapp
       RW+        =        kmeng

repo testing
       RW+        =        @all

其中的myapp就是新增加的,然后执行git的commit和push命令就完成了新repository的新建。

$ git commit -a
$ git push

         再登陆到服务器上,查看/home/git/repositories,发现里面对了一个myapp.git的目录。


         以后就只用Git了,真是太简单了。

         








目录
相关文章
|
7月前
|
存储 前端开发 Java
Git 仓库越来越大?不要慌!试试这个简单方法,轻松秒瘦身
Git 仓库越来越大?不要慌!试试这个简单方法,轻松秒瘦身
|
7月前
|
存储 缓存 开发工具
Git 拉取合并代码流程和多人协同开发的问题解决方法
Git 拉取合并代码流程和多人协同开发的问题解决方法
295 0
|
7月前
|
缓存 开发工具 数据安全/隐私保护
git-学习git,这一篇就足够了(初学者视角实战教程)
git-学习git,这一篇就足够了(初学者视角实战教程)
223 0
|
开发工具 git
git clone避坑的万能步骤
git clone避坑的万能步骤
2201 1
|
算法 Java Linux
注意!不看太后悔了!未来工作中如何多人协作?让我用git给你演示!
目前,我们的仓库中只有一个 master 主分支,但在实际的项目开发中,在任何情况下其实都是不允许直接在 master 分支上修改代码的,这是为了保证主分支的稳定。这时推送失败,因为你的小伙伴的最新提交和你推送的提交有冲突,解决办法也很简单,Git已经提示我们,先用 git pull 把最新的提交从origin/dev 抓下来,然后,在本地进行合并,并解决冲。要说明的是,我们切换到的是本地的 dev 分支,根据示例中的操作,会将本地分支和远程分支的进行关系链接。冲突,就使用我们之前讲的冲突处理解决掉冲突。
151 0
|
IDE 开发工具 git
使用gitee做为仓库管理项目,适合新手,详细有图
使用gitee做为仓库管理项目,适合新手,详细有图
194 0
使用gitee做为仓库管理项目,适合新手,详细有图
|
缓存 前端开发 JavaScript
一份工作4年前端的Git备忘指南
一份工作4年前端的Git备忘指南
一份工作4年前端的Git备忘指南
|
存储 安全 前端开发
|
前端开发 Java 程序员
用手画了11张图终于搞明白了Git工作流,我怀疑你用的是假 Git
用手画了11张图终于搞明白了Git工作流,我怀疑你用的是假 Git
用手画了11张图终于搞明白了Git工作流,我怀疑你用的是假 Git
|
前端开发 安全 Linux
搞!分享3个Git应用案例的骚操作,赶紧用!
搞!分享3个Git应用案例的骚操作,赶紧用!
搞!分享3个Git应用案例的骚操作,赶紧用!