Git入门学习和应用笔记

关于Git

1.BitMover公司收回Linux社区的BitKeeper免费使用权,Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git。
2.什么是集中式版本控制系统
集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。

中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
集中式和分布式版本控制系统有什么区别?
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。

既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?

比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。

而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。
3.安装Git
如果使用Debian或Ubuntu Linux,通过一条
sudo apt-get install git
就可以直接完成Git的安装;
如果是其他Linux版本,可以直接通过源码安装。
先从Git官网下载源码,然后解压,依次输入:./config,make,sudo make install这几个命令安装就好了。

创建版本库并提交文件

版本库又名仓库,repository,可以简单理解成一个目录,

这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
1.创建一个版本库
首先,选择一个合适的地方,创建一个空目录:


1

2

3

4

mkdir gitrepo

cd gitrepo

pwd

/data/gitrepo

  

第二步,通过git init命令把这个目录变成Git可以管理的仓库:


1

2

$ git init

Initialized empty Git repository in /data/gitrepo/.git/

  

此时当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的。

所有的版本控制系统,其实只能跟踪文本文件的改动,而图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化。

Word格式是二进制格式,因此,版本控制系统是没法跟踪Word文件的改动。

2.添加文件到仓库
第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件


1

$ git add file1.txt file2.txt

第二步,使用命令git commit -m "commit message",完成


1

$ git commit -m "add 2 files"

如果没有设置account,此时会提示配置账户信息:


1

2

3

4

5

6

Please tell me who you are.

Run

git config --global user.email "you@example.com"

git config --global user.name "Your Name"

to set your account's default identity.

Omit --global to set the identity only in this repository.

如果不添加--global参数,这个配置将只在当前的repository生效。

进行版本管理

1.使用git status可以让我们掌握仓库当前的状态
git status命令可以列出当前目录所有还没有被git管理的文件,
以及被git管理且被修改但还未提交(git commit)的文件。
现在我们修改file1.txt的内容并查看当前状态:


1

2

3

4

5

6

7

$ git status

On branch master

Changes not staged for commit:

(use "git add <file>..." to update what will be committed)

(use "git checkout -- <file>..." to discard changes in working directory)

modified: file1.txt

no changes added to commit (use "git add" and/or "git commit -a")

 

file1.txt修改过但还没有添加和提交,同时没有已经添加还没有提交的修改。

2.使用git diff查看对比修改的部分。
git diff顾名思义就是查看difference,
显示的格式正是Unix通用的diff格式顾名思义就是查看difference。


1

2

3

4

5

6

7

8

9

10

11

$ git diff

diff --git a/file1.txt b/file1.txt

index 006547b..078ac30 100644

--- a/file1.txt

+++ b/file1.txt

@@ -1 +1,2 @@

-This is the first file!

\ No newline at end of file

+This is the first file!^M

+It is modified!

\ No newline at end of file

  

3.提交修改和提交新文件是一样的操作
第一步是git add,下一步git commit 。


1

2

$ git add file1.txt

$ git commit -m "add a line"

 

4.使用git log显示从最近到最远的提交日志


1

2

3

4

5

6

7

8

9

$ git log

commit 0ecfc92df82585ebadd42fbd95aed9f48392a343

Author: bingyue <bingyue56@163.com>

Date: Tue Feb 23 03:24:30 2016 -0800

add 3nd line

commit 5963416b6e7f3f6eb51a577327329405cb59d937

Author: bingyue <bingyue56@163.com>

Date: Tue Feb 23 03:22:19 2016 -0800

add a line

  

其中的数字字母组合是git的版本号,是一个SHA1计算出来的一个非常大的数字,用十六进制表示。

每提交一个新版本,实际上Git就会把它们自动串成一条时间线。如果使用可视化工具查看Git历史,就可以更清楚地看到提交历史的时间线:

5.进行版本回退
在Git中,用HEAD表示当前版本,也就是最新的提交,
上一个版本就是HEAD^,上上一个版本就是HEAD^^,
当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id;
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本;
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本;

下面回退到上一个版本:


1

2

$ git reset --hard HEAD^

HEAD is now at 5963416 add a line

重新查看版本库,已经看不到第三次修改了:


1

2

3

4

5

$ git log

commit 5963416b6e7f3f6eb51a577327329405cb59d937

Author: bingyue <bingyue56@163.com>

Date: Tue Feb 23 03:22:19 2016 -0800

add a line 

如果这时想回到回退前的版本,只要找到那次修改的commit id,指定回到某个版本即可:


1

2

$ git reset --hard 0ecfc92df82

HEAD is now at 0ecfc92 add 3nd line

版本号没必要写全,确定唯一即可,Git会自动去寻找。

Git提供了一个命令git reflog用来记录你的每一次命令:


1

2

3

4

$ git reflog

0ecfc92 HEAD@{0}: reset: moving to 0ecfc92df82

5963416 HEAD@{1}: reset: moving to HEAD^

0ecfc92 HEAD@{2}: commit: add 3nd line

使用这个命令可以找回很多撤销的版本号,于是可以恢复到对应的版本。

管理修改

1.工作区和暂存区
Git和其他版本控制系统一个不同之处就是有暂存区的概念,暂存区在Git里非常重要。
工作区(Working Directory)就是你在电脑里能看到的目录,
工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。
你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

2.管理修改
为什么Git比其他版本控制系统设计得优秀,因为Git跟踪并管理的是修改,而非文件。
Git管理的是修改,当你用git add命令后,
在工作区的第一次修改被放入暂存区,准备提交,
但是,在工作区的第二次修改并没有放入暂存区,
所以,git commit只负责把暂存区的修改提交了,
也就是第一次的修改被提交了,第二次的修改不会被提交。
用git diff HEAD -- filename 命令可以查看工作区和版本库里面最新版本的区别,
每次修改,如果不add到暂存区,那就不会加入到commit中。

3.撤销修改

4.删除文件
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。

远程仓库

上面这些都是在本地的repository进行的,但是git的应用场景是远程仓库下的多人协作。
Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。

最开始只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分。
实际情况往往是这样,一台电脑充当服务器的角色,每天24小时开机,

其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。

1.使用Github
2.添加远程库并进行克隆

分支管理

1.创建与合并分支
每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。在Git里,默认的这个分支叫主分支,即master分支。
因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
2.冲突解决
Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容。

当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
用git log --graph命令可以看到分支合并图。

 

时间: 2024-09-27 16:53:02

Git入门学习和应用笔记的相关文章

[收藏学习]Ubuntu Git入门学习

考虑到CVS的一些局限性,最近和同事在公司推行Git.     其实,如果推行SVN的化,可能推行的难度会降低很多.不过lark说既然推行一个新的版本管理工具,总要花费一定的时间进行培训.部署.转换.而推行Git和SVN的代价不如想象中差距那么大.因此,不如就多花些精力推行Git , 可以带来更多的好处. 这个想法说服了我. 然后就开始筹备了. 我发现网上很多git教程对一些基础命令(比如git-reset)的介绍还是不够清楚.另外,介绍git1.5的少,介绍git1.4的多.此外,对于如何基于

安装 Git的方法之git入门笔记

gif入门基础 那么,简单地说,Git 究竟是怎样的一个系统呢?请注意,接下来的内容非常重要,若是理解了 Git 的思想和基本工作原理,用起来就会知其所以然,游刃有余.在开始学习 Git 的时候,请不要尝试把各种概念和其他版本控制系统(诸如 Subversion 和 Perforce 等)相比拟,否则容易混淆每个操作的实际意义.Git 在保存和处理各种信息的时候,虽然操作起来的命令形式非常相近,但它与其他版本控制系统的做法颇为不同.理解这些差异将有助于你准确地使用 Git 提供的各种工具. 直接

移动交互小白零基础入门学习笔记之:手势篇

此贴为零基础入门学习贴,总结和积累些基础知识~ 1.基本手势 触屏设备中多样的手势操作,都是由这10种基本手势组合演变而来. 2.常用动作 基本动作是触屏界面中最常用的动作,如打开.选择等. 与对象有关的动作是对屏幕上某一目标对象的操作,如调整图片的位置大小,选择.删除或移动一个文件等. 导览动作是对屏幕视图的操作,如切换屏幕.滚动屏幕.缩放网页等. 画图示意动作是用画图的方式来示意某些操作,这些图形最好是常见易画的图形,符合用户心理预期,如画勾表示确认,画叉表示取消. 以上都是触屏设备中常用的

Javascript入门学习资料收集整理篇_基础知识

Javascript入门学习第一篇 js基础Javascript入门学习第二篇 js类型Javascript入门学习第三篇 js运算Javascript入门学习第四篇 js对象和数组Javascript入门学习第五篇 js函数Javascript入门学习第六篇 js DOM编程Javascript入门学习第七篇 js dom实例操作Javascript入门学习第八篇 js dom节点属性说明Javascript入门学习第九篇 Javascript DOM 总结jQuery基础教程笔记适合js新手

入门指引 - PHP手册笔记

原文:入门指引 - PHP手册笔记 曾经简单的学习过PHP,看的是<PHP和MySQL Web开发>,还有万能的搜索引擎的帮助.这次准备系统的学习一下,参考资料是PHP Manual. PHP能做什么 PHP主要用于服务端的脚本程序,但PHP的功能远不局限于此.PHP主要用于以下三个领域: 服务端脚本 命令行脚本 编写桌面应用程序(PHP-GTK) 实用的脚本 $_SERVER是一个特殊的PHP保留变量,它包含了web服务器提供的所有信息,被称为超全局变量.可以通过$_SERVER['HTTP

git入门与实践【转】

转自:http://www.cnblogs.com/shenhaocn/archive/2011/03/13/1982957.html 什么是版本控制 要了解什么是git,首先需要了解什么是版本控制(Version Control),版本控制系统(Version Control System,简称VCS)是一种记录一个或多个文件的变化的系统,这样的系统能够方便你今后调用找回某个特定时期(或版本)的文件. 版本控制系统广泛地应用于程序开发等领域,它可以协助你将某个指定的文件(甚至是一整个项目)返回

Javascript教程:入门学习正则表达式

文章简介:正则表达式30分钟入门教程. 本文目标 30分钟内让你明白正则表达式是什么,并对它有一些基本的了解,让你可以在自己的程序或网页里使用它. 如何使用本教程 别被下面那些复杂的表达式吓倒,只要跟着我一步一步来,你会发现正则表达式其实并没有你想像中的那么困难.当然,如果你看完了这篇教程之后,发现自己明白了很多,却又几乎什么都记不得,那也是很正常的--我认为,没接触过正则表达式的人在看完这篇教程后,能把提到过的语法记住80%以上的可能性为零.这里只是让你明白基本的原理,以后你还需要多练习,多使

MySQL入门学习(一)

mysql MySQL入门学习(一)  安装篇   PHP+MySQL+Linux目前已逐渐成为小型web服务器的一种经典组合.在indows环境下构筑和调试MySQL数据库是许多网站开发者的一种首选.本人在Windows98环境下初学MySQL,现将学习过程与经验总结出来供大家参考. 1.下载mysql-3.23.35-win.zip并解压: 2.运行setup.exe;选择d:\mysql,"tyical install" 3.启动mysql,有如下方法:   方法一:使用winm

MySQL入门学习(六)

mysql MySQL入门学习(六) --修改和备份.批处理   有时我们要对数据库表和数据库进行修改和删除,可以用如下方法实现: 1.增加一列: 如在前面例子中的mytable表中增加一列表示是否单身single: mysql> alter table mytable add column single char(1); 2.修改记录 将abccs的single记录修改为"y": mysql> update mytable set single='y' where nam