Git版本控制系统VCS
Git版本控制系统VCS
一、版本控制系统基本情况说明
版本控制是一种记录一个或者若干个文件内容的变化,以便将来查阅特定版本修订情况的系统
1、作用
记录文件的所有历史变化
随时可回复到任何一个历史状态
多人协作开发或者修改
错误恢复
多功能的并行开发(分支功能、特性-合并操作)
2、分类
本地版本控制系统(local VCS)
集中化的控制系统(Centralizes VCS)
分布式的版本控制系统(Distributed VCS)
3、基本概念
repository——存放所有文件及历史信息
checkout ——取出或者切换到指定版本的文件
version ——记录表示一个版本(编号或者其他代码),某个特定状态下的资源
tag ——记录标识一个主要版本(1.0 2.0 3.0)
4.三种版本控制系统细讲
(1)本地版本控制系统(LVCS)——本地完整仓库(少用)
RCS (Revision Control System)
优点:简单、很多系统中都有配置
适合管理文本文件
缺点:不支持网络
支持类型单一
只适合管理少量文件、不支持基于项目的管理
(2)集中式版本控制系统(CVCS )——服务器完整的仓库
CVS (Concurrent Version System)
Subversion
优点:适合多人团队协作开发
代码集中话管理
缺点:单点故障
必须连网操作,无法单击本地工作
(3)分布式版本控制系统(CVCS)——本地和服务器都有完整的仓库
Git
Mercurial
优点:适合多人团队协作开发
代码集中化管理
可以离线工作
每个计算机都是一个完整仓库
二、Git——一个分布式的版本控制系统
1、Git由来
Git最初开发是为了取代BitKeeper,由linus
Torvalds开发,作为linux内核代码管理系统使用。
Git
设计时考虑了很多方面,除了分布式版本控制系统的优点外,还考虑了一下的设计目标,这些目标都成为git的优点:
速度、简单的设计、对非线性开发模式的强烈支持(分支功能,允许上千个并行开发的分支)、完全分布式、有能力管理类似linux内核一样的强大规模项目。
2、为什么取名git
I'm
an egotistical bastard,and I name all my projects after
myself.First'Linux',now'Git'. ——Linus Torvalds
3、git原理——快照,而非保存区别。
(1)快照,而非保存
每一种版本控制系统都用一种办法追踪不同阶段的文件的变化。
别的:补丁(保存区别)
Git
:快照(链接)snapshot
(2)几乎所有的操作都是在本地执行
(3)通过校验和算法识别文件的变化
Git
使用SHA-1算法对文件内容或者目录结构进行hash运算,用得出的校验值作为识别变化的指纹。
(4)多数操作据为添加数据
4、Git
原理——文件状态及工作区域
Git
respository——最终确定的文件保存到仓库,成为一个新的版本,并且对他人可见
Staging
area(index)——暂存已经修改的文件
Working
Directory——编辑、修改文件
三、Git安装
sudo
apt-get updates
sudo
apt-get install git
四、Git基础设置
1、设置用户名
git
config –-global user.name “IterCast”
2、设置用户邮箱
git
config –global user.email “demo@itercast.com”
(用户名和邮箱是提交代码时的标识)
3、查看设置
git
config –list
4、可以通过以下命令获取git帮助
git
help
可以通过以下的命令获取特定指令的帮助
git
help 特定指令
五、Git操作
(一)初始化一个新的Git仓库
1、创建一个文件夹(或者使用已有的文件夹)
mkdir
git-Demo
2、在文件夹内初始化Git
,创建Git仓库
cd
git-Demo
git
init (实际上就是在这个文件夹下面创建一个隐藏的文件夹.git,所有的git文件都保存在此)
(二)Git
仓库中的文件添加及更新
Git
工作区域: Working
Directory——>Staging area(index)------>Git repository
(1)新添加的文件
hellogit.rb、README
(2)添加到Staging
area
git
add hellogit.rb
git
add README
(3)确定后,添加到Git
repository
git
commit -m “init pro说明信息”
注释:
(1)git
status 查看当前的仓库状态;git
log查看仓库日志。
(2)git
commit -a -m “modify hellogit” 直接一起提交暂存文件。(不会自动提交未追踪的文件)
git
commit -a -m “modify README”
(git
status)
(三)删除文件
1、删除文件(从系统中删除文件)
rm
README
2、从Git中删除文件(让Git不去追踪这个文件)
git
rm README
3、提交操作
git
commit -m “delete README”
注:只是在当前版本中删除,而历史版本中还是存在的
(四)重命名文件
hellogit.rb---------->helloworld.rb
1、git
mv hellogit.rb helloworld.rb
2、git
commit -m “rename hello.rb to helloworld.rb”
注:重命名文件相当于执行下面三条命令
1、mv
hellogit.rb helloworld.rb
2、git
rm hellogit.rb
3、git
add helloworld.rb
六、Git
远程仓库简介
Working
Directory---->Staging area------->Git
repository-----.git仓库文件---->Git仓库文件
1、Git远程仓库——访问协议
Local、SSH
、Git
、HTTP/HTTPS
2、常用Git
仓库实现
(1)使用现有的Git网络仓库服务
github、bitbucket
(2)搭建自己的Git仓库服务器件
声明:本文是在观看苏勇老师在51CTO学院上面的Web开发-苏勇老师Git 版本控制系统精讲视频课程整理而来,大家可以进行视频观看。在此谢过苏勇老师!!
Git版本控制系统VCS的更多相关文章
- Google Code项目代码托管网站上Git版本控制系统使用简明教程
作为一个著名的在线项目代码托管网站,Google Code目前主要支持三种版本控制系统,分别为Git, Mercurial和 Subversion.Subversion即SVN相信大家都已经熟知了,这 ...
- git版本控制系统重新认识
git 版本控制系统 目标:完全搞懂git分布式版本控制系统 搭建git版本控制系统 cvs集中化版本控制系统--集中式管理的服务器 git分布式版本控制系统--会将原始代码仓库镜像下来 新项目使用g ...
- git版本控制系统小白教程(上)
前言:本文主要介绍git版本控制系统的一些基础使用,适合小白入门,因为内容较多,会分为两部分进行分享. Git介绍 Git是目前世界上最先进的分布式版本控制系统.并且它是一个开源的分布式版本控制系 ...
- git版本控制系统小白教程(下)
前言:本文主要介绍git版本控制系统的一些基础使用,适合小白入门,因为内容较多,会分为两部分进行分享,查看上部请点传送门. 删除文件 git删除文件一般有三种情况,第一种是在工作区修改了文件,但是 ...
- 版本控制系统(VCS)简介
简介 版本控制系统(VCS)是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统.使用版本控制系统通常还意味着,就算你乱来一气把整个项目中的文件改的改删的删,你也照样可以轻松恢复到原先 ...
- 初识git版本控制系统
当下git分布式版本控制系统越来越火,掌握git也是必须的一个技能.因此,对git做了如下学习. Git初级指南 1. 先安装git.(ps:在select cmponents处要勾选Git Bash ...
- 如何选择版本控制系统 ---为什么选择Git版本控制系统
版本控制系统 "代码"作为软件研发的核心产物,在整个开发周期都在递增,不断合入新需求以及解决bug的新patch,这就需要有一款系统,能够存储.追踪文件的修改历史,记录多个版本的开 ...
- Git版本控制系统之基本使用
最早是通过接触著名的开源社区Github了解到Git的,但一直没有系统学习过.这次下定决心从头到尾系统的学一学,也将学习过程记录于此,供大家批驳.本篇文章先从以下几个方面简单了解一下Git: Git的 ...
- git版本控制系统更新
版本控制系统: 一.概念: 版本控制系统(Version Control System):是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统. 二.版本控制系统分类 1.本地版本控制 ...
随机推荐
- ServletContext与Web应用以及Spring容器启动
一.ServletContext对象获取Demo Servlet容器在启动时会加载Web应用,并为每个Web应用创建唯一的ServletContext对象. 可以把ServletContext看作一个 ...
- centos6.5下redis的安装与配置
参照官网描述(https://redis.io/download),linux下redis安装步骤如下: $ wget http://download.redis.io/releases/redis- ...
- erlang 洗牌 shuffle
很简单的一个场景:一副扑克(54张)的乱序洗牌 shuffle_list(List) -> [X || {_, X} <- lists:sort([{random:uniform(), N ...
- JavaScript 函数和事件
上面例子中的 JavaScript 语句,会在页面加载时执行. 通常,我们需要在某个事件发生时执行代码,比如当用户点击按钮时. 如果我们把 JavaScript 代码放入函数中,就可以在事件发生时调用 ...
- GoogleMap-------Google Play services SDK的下载和配置
前言:在android开发项目中当要使用GoogleMap需要有Google Maps Android API的支持,而他包含在了Google Play services SDK中,所以本文将介绍如何 ...
- shell bash使用,包括判断文件或文件夹是否存在举例
Linux shell编程——if条件判断 if [ condition ] ;then //一定要注意[] 與裡面的內容要有空格隔开 例如 if [(空格)${a} -eq 3(空格)]; then ...
- iOS 实现从后台切换到前台-复制分享宝贝内容,打开淘宝APP,自动弹出宝贝提示信息
- (void)applicationDidBecomeActive:(UIApplication *)application { NSLog(@"\n ===> 程序重新激活 !&q ...
- IOS时间与日期处理
本文转载至 http://blog.sina.com.cn/s/blog_9cd1705d0102v5x4.html 主要有以下类: NSDate -- 表示一个绝对的时间点NSTimeZone ...
- Win7 maven安装及配置
1. 前期准备 ① jdk 1.8 ② maven 3.5.4 下载地址:http://maven.apache.org/download.cgi 2. 配置maven环境变量 ① maven解压到指 ...
- 《从零开始学Swift》学习笔记(Day 6)——哎呀常量和变量都该什么时候用啊?
原创文章,欢迎转载.转载请注明:关东升的博客 使用var还是let? 在我们开发过程中啊什么时候定义关键字为var,还是定义为let呢? 其实啊都能满足我们的需求,那我们到底应该如何选择? 例如:可以 ...