git的介绍

git概念:

Git是一个免费的,开源的分布式版本控制系统,可以快速高效地处理从小型到大型的项目。

什么是版本控制?

版本控制是一种记录一个或者若干文件内容变化,以便将来查阅特定版本修订情况的系统。

为什么要使用版本控制?

软件开发中采用版本控制系统是个明智的选择。
使用它可以将某个文件回溯到之前的状态,甚至将整个项目都回退到过去某个时间点的状态。
就算乱删乱改,也可以轻松回复到原来的样子。
但是额外增加的工作量微乎其微,你可以比较某个文件的变化细节,查出最后是谁修改了哪个地方,从而找出导致怪异问题出现的原因,又可以找到谁导致了功能的缺陷。

版本控制系统的分类:

1.集中化的版本控制系统


集中化的版本控制系统诸如cvs、svn以及Perforce等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。管理员也可以轻松掌握每个开发者的权限,并且黄历一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易。

  • 缺点:
    1.如果中央服务器出现单点故障,那么在这一个小时之内,将无法提交更新,也就无法协同工作。
  1. 必须要联网才能工作,如果在局域网内还好,带宽勾搭,速度够快,如果在互联网中,遇到网速慢的话,可能提交一个10M的文件就需要5分钟。这个时间太长了。

2.分布式的版本控制系统。

由于上面的集中化版本控制系统的那些缺点,于是分布式版本控制系统面世了。
在这类系统中,像git,刻划断并不只是提取最新版本的文件快照,而是把代码仓库完整地 镜像下载下来。
(使用的是最优的压缩算法,将文件的信息进行压缩。极致的压缩算法)

(包含了一个去中心化的思想)
更进一步,许多这类系统都可以指定和若干不同的远端代码仓库进行交互,这样,你就可以在同一个项目中分别和不同工作小组的人互相协作。
分布式的版本控制系统在管理项目时存放的不是项目版本与版本之间的差异,它存放的是索引(所需磁盘空间很少,所以每个客户端都可以下载整个项目的历史记录)
简单的说:集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器好比是一个图书馆,你要改一本书,必须先从图书馆里借出来这本书,然后回到家里,自己修改,改完了,再放回到图书馆里

分布式和集中式的区别?

分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样你工作的时候,就不需要联网,因为版本库记就在你电脑上,如果是多人协作,可以将各自的修改推送给对方,就可以互相看淡对方的修改。

  • 安全性更高,因为每个人的电脑上都有一个完整的版本库,某一个人的电脑坏了不要紧,随便从其他人哪里复制一个就可以了,而集中式版本控制系统的中央服务器要是出了问题,所有人都没有办法工作。
  • 有一台电脑充当“中央服务器”的角色,用来方便大家交换修改

git和SVN的区别?

Git不仅仅是一个版本控制系统,特使一个内容管理系统,工作管理系统。
区别:

  • 1.Git是分布式的,SVN不是
  • 2.Git把内容按元数据方式存储,而SVN是按文件进行存储。
  • 3.Git分支和SVN分支不同:分支在SVN中一点都不特别,因为他就是版本库中的另一个目录。
  • 4.Git没有一个全局的版本号,而SVN有。
  • 5.Git内容完整性要优于SVN:Git的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

git的发展历史

创造者:林纳斯本纳第克特托瓦兹
linux --》使用的bitkeeper----〉将linux管理在git上--》开源免费。

posted @ 2021-08-02 00:14  King-DA  阅读(56)  评论(0)    收藏  举报