zoukankan      html  css  js  c++  java
  • Linux(CentOs6.4)安装Git

    安装之前我们先来了解下git,并且要反问下:我为什么要使用git?svn用的不是很好嘛,我干嘛要换?。。。

    问1:为什么需要版本控制系统?

    版本控制是一种记录若干文件内容变化,以便将来查阅特定版本修订情况的系统。大部分时候我们使用最频繁的还是对源代码文件的版本控制,其实任何文件都可以纳入版本控制系统。

    1).更好备份:相比于将不同版本的文件以时间等命名存储备份,使用版本控制系统能节约更多的磁盘空间,因为版本控制系统不是文件的复制备份,而是差异备份,文件快照备份等等。

    2).更好的回溯:可以将某个文件回溯到之前的任何一个提交状态,甚至将整个项目回退到过去的某个时间点。

    3).更好的团队协作:这是我认为最重要的,团队共同开发一款软件,如果没有版本控制,那是不可想象的,简单点的可以使用文件传输到某一位核心开发者库上进行合并,但如果团队的成员是分散在全国各地的,甚至是世界各地的,比如linux内核的开发,那完全是没办法进行的。使用版本控制后,可以比较文件的变化系统,可以查询是谁提交了新的更新,并且可以由项目负责人管理提交,进行更新的管理。

    问2:相比于svn, git有什么优势?

    其实这里真要说出谁比谁好,真的很难说,从不同的角度和不同的需求可能都会有不同的观点,这里我也只能说明两者的适用情景。

    svn属于集中化的版本控制系统:有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的成员通过客户端连接到这台服务器,进行文件上传和更新。

          优点:a.使用简单,比较符合我们的常规思维(我当年从SVN转向Git也花费了不少时间)。b.同步代码比较简单,只要一步操作即可。

          缺点:a.丢失数据的风险:最显而易见的,由于集中化的特点,如果版本库的服务器磁盘发生故障等,你不能保证所有的数据已经有人提取出来了,最坏的情况是彻底的丢失整个项目的所有历史更改记录。b.网络中断的情况下,协作就无法进行了,因为无法连接服务器进行上传和更新。

    git属于分布式版本控制系统:客户端并不只提取最新版本的文件快照,而是把原始的代码仓库完整地镜像下来。

      优点:a.由于任何人每次提取操作,实际上都是一次对代码仓库的完整备份,因此近乎所有的操作都可以在本地执行,速度就是相当的快,并且可以在网络断开的时候操作仍然不受影响,可以频繁的进行提交更新,等到有网络的时候再上传到远程的镜像仓库就可以了。b.文档很详细,并且命令行的提示也很到位,用起来比较得新应手,而且很多的设置与操作跟linux操作很相近(不亏是linux之父创造的)。c.git的分支模型,相当的轻量级,被称为“必杀技”。

       缺点:a.每个开发人员都拥有所有的代码,不利于核心代码的保密(如果有重要代码需要保密,则不建议使用git)

    git的历史

    当年教授给我们将git历史的时候,感觉特别有意思,还特崇拜linux之父Linus Torvalds。linux内核开发是来自世界各地的热衷于开源的人士,开始他们使用的版本控制系统是一个商业产品BitKeeper,并免费给linux使用,但由于后期开发人员越来越庞大等等原因,而BitKeeper毕竟是商业产品,终于在2005年与linux内核开源社区结束了合作关系,Linus Torvalds一气之下就自己开发了一款适合linux内核开发管理的版本管理系统Git。现在Linus Torvalds其实很少写代码了,而是将别人提交的代码合并到内核中去,更多时间里,就是在对别人提交的代码说“Yes”或者“No”,或是指导别人该在什么地方进行修改。

    git在linux的安装:(以下涉及到的软件基本都使用yum安装,如果你的机子不联网,建议你先建本地yum源:http://www.cnblogs.com/shenliang123/p/3829044.html

    源码安装前先安装GIT所需要的库

    yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel

    1.先从官网 http://git-scm.com/download 上下载GIT最新版我的是git-2.1.0.tar.gz

    2.将文件git-2.1.0tar.gz复制到/opt/git/gitinstall下,并解压

    [root@sl gitinstall]# tar -zxvf git-2.1.0.tar.gz

    3.进行配置安装

    [root@sl gitinstall]# cd git-2.1.0
    [root@sl git-2.1.0]# ./configure
    [root@sl git-2.1.0]# make
    [root@sl git-2.1.0]# make install

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

    但在执行make操作时报错:缺少gcc,yum安装gcc

    [root@sl ~]# yum -y install gcc

    重新执行make操作,还报错,缺少zlib.h。我们可以查看是否存在zlib.h

    [root@sl ~]# whereis zlib

    如果存在则会输出zlib路径。不存在则输出空白,以下是安装详情:

    1.从http://www.zlib.net/下载zlib最新版:zlib-1.2.8.tar.gz

    2.解压,编译

    [root@sl gitinstall]# tar -zxvf zlib-1.2.8.tar.gz
    [root@sl gitinstall]# cd zlib-1.2.8
    [root@sl zlib-1.2.8]# ./configure
    [root@sl zlib-1.2.8]# make
    [root@sl zlib-1.2.8]# make install

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

    重新执行make,make install,无错误输出,验证安装是否成功:

    [root@sl git-2.1.0]# whereis git
    git:/usr/local/bin/git
    [root@sl git-2.1.0]# git -version
    git version 2.1.0

    以上输出就意味着安装成功了!
  • 相关阅读:
    redis的五种常见数据类型的常用指令
    Linux常用的命令
    moco操作
    如何使用GoEasy实现PHP与Websocket实时通信
    浅谈websocket
    nginx 配置虚拟主机访问PHP文件 502错误的解决方法
    集群/分布式环境下5种session处理策略
    nginx 集群
    使用Nginx实现反向代理
    nginx的配置和基本使用命令
  • 原文地址:https://www.cnblogs.com/liuzhi/p/3959372.html
Copyright © 2011-2022 走看看