Git入门,看这一篇就够了

前言

当前的项目开发中,使用的版本管理工具大多数是SVN或者Git,而Git高效灵活、分布式开发的特性也使得其越来越受开发者的青睐,对于开发人员来说,掌握svn之外,学会使用Git也是相当有必要的,本篇文章将对Git的常用命令和场景进行介绍,希望能够给各位读者一个参考。

一、Git概述

(一)Git产生的背景
在讲Git的使用前,我们不妨先了解一下Git是在什么背景下产生的。

Git 诞生于一个极富纷争大举创新的年代。Linux 内核开源项目有着为数众多的参与者。 绝大多数的 Linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2002年间)。 到 2002 年,整个项目组开始启用一个专有的分布式版本控制系统 BitKeeper来管理和维护代码。
到了 2005 年,开发 BitKeeper 的商业公司同 Linux内核开源社区的合作关系结束,他们收回了 Linux 内核社区免费使用 BitKeeper 的权力。 这就迫使 Linux 开源社区(特别是 Linux 的缔造者 Linus Torvalds)基于使用 BitKeeper 时的经验教训,开发出自己的版本系统。 简单来说的话,就是以Linus Torvalds为首的Linux内核开发大佬因为原有的代码版本管理工具不能继续免费使用了,就自己开发了Git出来...

他们对新的系统制订了若干目标:
  • 速度
  • 简单的设计
  • 对非线性开发模式的强力支持(允许成千上万个并行开发的分支)
  • 完全分布式
  • 有能力高效管理类似 Linux 内核一样的超大规模项目(速度和数据量)
(二)Git和Svn的对比

SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而开发人员工作的时候,用的都是自己的电脑,所以首先要从中央服务器下载最新的版本,然后开发,开发完后,需要把自己开发的代码提交到中央服务器。
但集中式版本控制工具存在着:服务器单点故障、容错性差的缺点,一旦中央服务器挂掉了,那么开发人员也就无法进行代码提交和版本更新(也就是需要向svn服务器发起请求的操作都做不了),势必会对项目进度造成影响。当然了,搭建SVN高可用集群在一定程度上也可以避免单点故障的问题。

Svn工作流程图

Git是分布式版本控制系统(Distributed Version Control System,简称 DVCS) ,分为两种类型的仓库:本地仓库和远程仓库。

  • 本地仓库:是在开发人员自己电脑上的Git仓库
  • 远程仓库:是在远程服务器上的Git仓库

我们可以看到,在使用Git进行版本管理的过程中,并不是只有唯一一个仓库,事实上,远程仓库创建后,开发者每次在新的工作区执行clone或者pull动作时,都会新建一个本地仓库。可以这样说,如果你被困在一个不能连接网络的地方时,你仍然能够提交文件,查看历史版本记录,创建项目分支等。

Git工作流程图

流程图中的三个动作解释:

  • Clone:克隆,就是将远程仓库复制到本地
  • Push:推送,就是将本地仓库代码上传到远程仓库
  • Pull:拉取,就是将远程仓库代码下载到本地仓库
(三)Git的工作流程
Git开发工作流程图

1.从远程仓库中克隆代码到本地仓库
2.从本地仓库中checkout代码然后进行代码修改
3.在提交前先将代码提交到暂存区
4.提交到本地仓库。本地仓库中保存修改的各个历史版本
5.修改完成后,需要和团队成员共享代码时,将代码push到远程仓库

(四)Git的下载和安装

下载地址: https://git-scm.com/download

Git官网下载

我们根据自己的系统选择想要下载的版本进行下载安装即可。
安装完毕后,我们点击鼠标右键可以看到Git Gui HereGit Bash Here的话,就说明是安装成功了。
点击右键,可以看到git gui 和git bash两个选项

二、Git的托管服务

我们从上面的介绍中可以得知,Git的仓库分为远程仓库和本地仓库。那么我们如何搭建Git远程仓库呢?我们可以借助互联网上提供的一些代码托管服务来实现,其中比较常用的有GitHub、码云、GitLab等。

GitHub( 地址:https://github.com/

GitHub 是一个面向开源及私有软件项目的托管平台,因为只支持Git 作为唯一的版本库格式进行托管,故名gitHub

码云(地址: https://gitee.com/

码云是国内的一个代码托管平台,由于服务器在国内,所以相比于GitHub,码云速度会更快

GitLab (地址: https://about.gitlab.com/

GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务

需要注意的是,由于GitHub的服务器在国外,所以如果我们直接访问的话可以相对来说速度会比较慢,所以下面我们将使用码云作为我们的远程仓库,进行远程仓库创建的演示。

1、 在码云官网上登录我们的账号,然后在我的页面中选择创建仓库
点击创建仓库
2、定义远程仓库初始参数后点击创建

填写仓库初始化信息

这里有一个小细节,因为我们勾选了使用ReadMe文件初始化仓库,所以仓库init完成后,我们会看到项目根路径下会有两个ReadMe的中英文文本文件。

3. 查看远程仓库的地址
查看项目路径

三、Git的常用命令

在使用Git命令之前,我们先创建一个空的文件夹,然后右键点击Git Bash Here,进入Git命令窗口

1. 环境配置

当安装Git后首先要做的事情是设置用户名称和email地址。这是非常重要的,因为每次Git提交都会使用该用户信息

 #设置用户信息 
   git config --global user.name “itcast”
   git config --global user.email “hello@itcast.cn”
 #查看配置信息
   git config --list
   git config user.name

通过上面的命令设置的信息会保存在~/.gitconfig文件中( ~ 表示C盘具体的用户目录下)

查看用户配置信息

2. 获取Git仓库

要使用Git对我们的代码进行版本控制,首先需要获得Git仓库
获取Git仓库一般有两种方式:

2.1从本地直接初始化
git init
本地初始化仓库
2.2从远程仓库克隆

我们只要在指定的文件夹中执行git的克隆命令后,就可以把我们远程的仓库文件拉取下来。

git clone 远程Git仓库地址 
从远程仓库克隆
3.操作本地仓库
在讲解本地仓库前,我们先来理清一下一些概念

版本库:前面看到的.git隐藏文件夹就是版本库,版本库中存储了很多配置信息、日志信息和文件版本信息等
工作目录(工作区):包含.git文件夹的目录就是工作目录,主要用于存放开发的代码
暂存区:.git文件夹中有很多文件,其中有一个index文件就是暂存区,也可以叫做stage。暂存区是一个临时保存修改文件的地方

添加新增文件的步骤

和Svn不同,我们新增、修改、删除的代码并不是直接提交到我们的本地仓库上的,而是需要先执行add命令提交到暂存区,再通过commit命令提交到我们的本地仓库中。

说到这里,有些人可能会比较好奇,为什么Git要有暂存区这个概念呢?为什么不选择直接就把文件提交到本地仓库呢?

查看了网上一些大佬的理解,说到最多的点是保障了提交的原子性: 我们可以分批,按一个个的小功能提交到暂存区,之后再统一提交。这样的话,当你的工作区有多个正在开发的功能,你可以有选择性的选择要提交的文件,保障代码的原子性。不过个人对这种看法还是持保留意见,一开始我还以为执行commit会把所有文件都提交上去,那么这种解释就说得通,但实际上我们还是可以通过commit来选择需要提交的文件。
这样的话,保障提交原子性的观点就站不住脚。只能说姑且把暂存区当做一种Git的特性来使用吧,毕竟这个操作本身也不会浪费什么时间,只是多了一步而已。

$ git commit [file1] [file2] ... -m [message]

接着说Git工作目录下的两种状态:

  • untracked 未跟踪(未被纳入版本控制)
  • tracked 已跟踪(被纳入版本控制)
    • Unmodified 未修改状态
    • Modified 已修改状态
    • Staged 已暂存状态

untracked一般出现在我们新创建的文件上,Unmodified则是仓库中没有变动过的文件,Modified出现在仓库中被修改过的文件, Staged 一般是加入暂存区的文件。

3.1查看文件状态
git status
git status演示
3.2将未跟踪的文件加入到暂存区
git add filename
将cc.txt加入到暂存区
3.3将暂存区的文件取消暂存
# 方法1
git reset filename
#方法2
 git restore --staged  filename
取消暂存区的文件
3.4提交文件至本地仓库
git commit -m [message]
commit命令演示用例
3.5删除文件
git rm filename

使用rm命令删除文件演示

我们可以看到,使用git rm命令后,删除的动作是会直接保存到暂存区的,我们只需要再执行一下commit命令就可以把删除的动作提交到本地仓库。需要注意的是,如果是直接鼠标右键删除的话,那么删除的动作是不在暂存区的,需要我们自己再手动添加到暂存区中。

4.文件忽略列表

一般我们总会有些文件无需纳入Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以在工作目录中创建一个名为 .gitignore 的文件(文件名称固定),列出要忽略的文件模式。下面是一个示例:

# 表示所有以  .a 为后缀(包括子目录)的文件都进行忽略
*.a
# 表示 lib.a 作为特例,当做特殊情况处理
!lib.a
# 忽略当前目录中的TODO文件,但其他目录下的TODO文件不进行忽略
/TODO
# 忽略 build/ 下的所有文件
build/
# 忽略doc目录下的所有.txt文件,但是不包含子目录中的 .txt文件
doc/*.txt
# 忽略 doc/ 下所有 .pdf 后缀的文件
doc/**/*.pdf

注意,在window系统中一般不允许直接创建.开头的文件名,所以这里的话我们可以直接在git窗口下使用touch或者vi进行文件的创建。

5. 查看日志
git log
git log 命令演示
6. 操作远程仓库
6.1查看远程仓库

如果想查看已经配置的远程仓库服务器,可以运行 git remote 命令。 它会列出指定的每一个远程服务器的简写。 如果已经克隆了远程仓库,那么至少应该能看到 origin ,这是 Git 克隆的仓库服务器的默认名字

# 查看远程仓库
git remote    -v  
# 查看指定远程仓库的所有信息  
git remote show 远程仓库缩写  
查看远程仓库
6.2添加远程仓库
git remote add <shortname> <url> 

image.png

这里可能有人会有疑问,本地关联多个远程仓库的意义是什么呢?
我们可以举这么一个场景:如果本地的 git 库,既想 push 到 gitlab ,又想推到 github 上,那么可以使用 remote 相关的命令处理。

6.3从远程仓库克隆

如果你想获得一份已经存在了的 Git 仓库的拷贝,这时就要用到 git clone 命令。 Git 克隆的是该 Git 仓库服务器上的几乎所有数据(包括日志信息、历史记录等),而不仅仅是复制工作所需要的文件。 当你执行 git clone 命令的时候,默认配置下远程 Git 仓库中的每一个文件的每一个版本都将被拉取下来。

git clone [url] 
克隆远程仓库
6.4移除无效的远程仓库
git remote rm 远程仓库缩写
移除远程仓库演示用例

注意:此命令只是从本地移除远程仓库的记录,并不会真正影响到远程仓库

6.5从远程仓库获取最新代码

通常的话我们有两种方式可以拉取远程仓库的代码,分别是pullfetch,区别在于前者会自动merge代码,而后者不会。

使用fetch命令拉取代码

使用pull命令拉取代码

我们可以看到,使用fetch命令拉取代码的话,我们需要再执行merge命令,这样远程仓库的数据才会到我们本地仓库。

注意:如果当前本地仓库不是从远程仓库克隆,而是本地创建的仓库,并且仓库中存在文件,此时再从远程仓库拉取文件的时候会报错(fatal: refusing to merge unrelated histories ),解决此问题可以在git pull命令后加入参数--allow-unrelated-histories

6.5推送到远程仓库

我们在推送代码时,需要指明推送的远程仓库还有具体的分支

git push -u [remote-name] [branch-name]
推送代码案例演示

这里如果是第一次推送的话,会弹出弹框要求你填写账号密码,只要写上你码云上面的账号即可。

7. Git分支

几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线。Git 的master分支并不是一个特殊分支。 它跟其它分支没有区别。 之所以几乎每一个仓库都有 master分支,是因为git init 命令默认创建它,并且大多数人都懒得去改动它。

7.1查看分支
# 列出所有本地分支
$ git branch
# 列出所有远程分支
$ git branch -r
# 列出所有本地分支和远程分支
$ git branch -a
查看所有分支演示
7.2创建分支
git branch branchName
创建分支
7.3切换分支
git checkout branchName
切换git分支演示用例
7.4推送至远程仓库分支
git push  -u  [remote repository name]  [branch name]
推送分支到远程仓库
7.5合并分支
git merge [branch name]
合并分支演示

有时候合并操作不会如此顺利。 如果你在两个不同的分支中,对同一个文件的同一个部分进行了不同的修改,Git 就没办法合并它们,同时会提示文件冲突。此时需要我们打开冲突的文件并修复冲突内容,最后执行git add命令来标识冲突已解决


merge时可能会发生冲突
7.6删除分支
$ git branch -d branch2

删除分支

如果要删除的分支中进行了一些开发动作,此时执行上面的删除命令并不会删除分支,如果坚持要删除此分支,可以将命令中的-d参数改为-D。如果要删除远程仓库中的分支,可以使用命令git push origin –d branchName

强制删除本地分支
8. Git标签

像其他版本控制系统(VCS)一样,Git 可以给历史中的某一个提交打上标签,以示重要。 比较有代表性的是人们会使用这个功能来标记发布结点(v1.0 、v1.2等)。标签指的是某个分支某个特定时间点的状态。通过标签,可以很方便的切换到标记时的状态。

这里或许有读者会有点混淆,Git标签和分支都可以表示某个时间上代码的状态,那么这两者的区别在哪呢?

要想解答这个问题,我们首先要对分支和标签的应用场景做一下区分。在实际应用中标签的作用是记录过去特定重要点的书签,也可以理解为是快照。例如版本发布。而分支是动态变化的,我们为了某个开发任务而创建了一条分支,完成后再进行合并以及删除分支(即标记)。
当然了,你也可以说光创建一条分支然后不再做修改,把它当做某个特定时期的版本来记录。这自然是可以的,但和这个功能的本意不符,也浪费了branch资源。

8.1列出已有的标签
# 列出所有tag
$ git tag
# 查看tag信息
$ git show [tag]
列出已有标签
8.2新建一个标签
git tag [tagName]
新建标签演示
8.3将标签推送至远程仓库
# 提交指定tag
$ git push -u [remote] [tag]
推送标签至远程仓库
8.4检出标签
git checkout -b [branch] [tag]
标签检出演示用例
8.5删除标签
git tag -d [tag]
删除标签用例
8.6删除远程标签
git push origin :refs/tags/[tag]
删除远程标签用例

至此,有关Git的常用命令和概念就介绍到这里了。对于GIt的使用,重点在于理解它的作用流程和重点概念的思想,比如知道标签、分支、远程仓库等具体的含义和使用场景,这样才能在工作中真正做到游刃有余。

参考资料:
为什么要先 git add 才能 git commit ?:
https://www.zhihu.com/question/19946553
标签与Git中的分支有何不同?我应该在哪里使用?:
https://www.imooc.com/wenda/detail/584818

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 前言 欢迎关注公众号,白嫖原创PDF,也可以催更,微信搜:JavaPub,回复:【666】 Git 在生产工作中是...
    JavaPub阅读 416评论 0 0
  • 夜莺2517阅读 127,717评论 1 9
  • 版本:ios 1.2.1 亮点: 1.app角标可以实时更新天气温度或选择空气质量,建议处女座就不要选了,不然老想...
    我就是沉沉阅读 6,886评论 1 6
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,531评论 28 53
  • 兔子虽然是枚小硕 但学校的硕士四人寝不够 就被分到了博士楼里 两人一间 在学校的最西边 靠山 兔子的室友身体不好 ...
    待业的兔子阅读 2,594评论 2 9