1.Git零基础使用详解

一、git概述


目前最流行的版本控制工具

  1. 版本控制概念
    在代码开发过程中,往往需要对源码进行多次的修改操作,这样一来同一份代码就产生了多个版本,在开发过程中通常需要对这些多个版本代码进行管理,以便于在需要时进行 代码回滚、多版本间比较、多人协作开发、代码分支、分支合并 等操作。
    这样的需求大量的存在,而随着软件越来越复杂、代码越来越多、参与开发者越来越多,版本管理也变的越来越有难度,此时就需要专业的软件来对版本进行管理,这个过程就称之为版本控制,实现版本控制的软件就称之为版本控制软件。

  2. 版本控制软件分类
    集中式版本控制
    在集中式版本控制中,版本库是集中存放在中央服务器的,开发者在开发之前要先从中央服务器取得最新的版本,然后开始工作,工作完成后,再把自己的代码推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
    优点:
    便于集中式的代码管理
    便于进行权限控制
    缺点:
    需要联网才可以工作,而且项目庞大的情况下对带宽的要求比较高
    中心服务器存在单节点故障风险

CVS、SVN

分布式版本控制
在分布式版本控制系统中,没有“中央服务器”的概念,每个人的电脑上都是一个完整的版本库。而在多人协同工作时,通过推送各自的修改,保证多人间的版本一致。
但其实,在实际开发中,很少真的在两个电脑间进行修改的推送,而是选择一台充当“中央服务器”,但这个服务器仅仅是为了使用便利,本质上和其他机器没有任何区别,即使宕机,整个分布式版本控制仍然可以工作。

优点

  1. 不需要联网也可以工作
  2. 不存在单节点故障风险

缺点
无法实现严格的权限控制

Git

  1. git历史
    Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
    Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?
    在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!
    你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。
    不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。
    安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。
    Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:
    Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。
    Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。
    历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

二、git安装配置


  1. 下载Git
    Git最早只支持Linux,目前已经能够支持Linux、Unix、Windows、OS系统之上。
    下载地址:
    https://git-scm.com/

  2. 安装Git
    Linux上安装Git
    解压Linux版源码包
    依次执行

./config
make
sudo make install

Windows上安装Git
1. 下载安装包
2. 双击执行默认安装
3. 双击 Git Bush 即可启动Git

  1. 初始配置Git
    因为Git是一款分布式的版本控制软件,多用户之间的互相通信需要确定身份,所以安装Git后需要先配置当前用户的名称和邮箱,才可以使用
		$ git config --global user.name "Your Name"
		$ git config --global user.email "email@example.com"

三、创建版本库


  1. 版本库的概念
    版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

  2. 创建版本库
    在任意位置创建一个文件夹,位置可以任意,但是强烈建议目录路径中不要包含中文。

			$cd e:
			$pwd
			$mkdir gitdemo01
			$cd gitdemo01

通过git命令将该目录变为git所管理的仓库

$ git init

命令执行后,该目录下会多出一个.git的目录,这个目录是Git来跟踪管理版本库的,请勿手动修改。
也可以在一个非空的文件夹中创建仓库,但是在学习阶段先不要这样做。

四、工作区 、版本库、暂存区、分支 概念


工作区:存放文件的位置
版本库:工作区中.git文件夹,其中包含暂存区 和 分支区
暂存区:版本库中 包含暂存区 git add命令 或 git rm 命令加入的操作 被记录在暂存区内
分支区:版本库中 包含分支区 是最终版本信息保存的位置 git commit命令将暂存区内记录的操作 提交到分支中
可以配置多个分支,如果不指定则默认为master分支,并有一个head指针指向master分支的最新位置

五、版本管理


  1. 提交新文件
    注意,所有版本控制系统只能跟踪文本文件的改动,比如TXT文件,网页,所有的程序代码等等,Git也不例外。而图片、视频这些二进制文件,虽然也能由版本控制系统管理,但无法跟踪文件内容的变化,只能查看文件信息变化,如大小、更新时间等。

将需要管理的文件放置到仓库目录下

			    test.txt
				This is test

查看版本库状态

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值