美文网首页
Git 介绍

Git 介绍

作者: scarlett_888 | 来源:发表于2019-05-08 15:46 被阅读0次

一、简述

Git是目前世界上最先进的分布式版本控制系统(没有之一)。

Git的特点:高端大气上档次!

Git的诞生:Linus用C写的分布式版本控制系统。

Git的优势:(1)不需要联网;(2)有极其强大的分支管理能力。

二、安装

Linux、macOS、Windows、Solaris、Raspberry Pi等操作系统上都可以安装Git,本文只介绍前三种常用等操作系统。

1、在Linux上安装Git

首先,你可以试着输入git,看看系统有没有安装Git:

$ git
The program 'git' is currently not installed. You can install it by typing:
sudo apt-get install git

像上面的命令,有很多Linux会友好地告诉你Git没有安装,还会告诉你如何安装Git。

或者可以直接通过源码安装:先从Git官网下载源码,然后解压,依次输入:./configmakesudo make install这几个命令安装。

2、在Mac OS X上安装Git

有两种安装Git的方法:

(1)第一种方法是安装homebrew,然后通过homebrew安装Git。

具体方法请参考homebrew的文档:http://brew.sh/

(2)第二种方法更简单,也是推荐的方法:直接从AppStore安装Xcode,Xcode集成了Git。

选择菜单“Xcode”->“Preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点“Install”就可以完成安装了。

Xcode是Apple官方IDE,功能非常强大,是开发Mac和iOS App的必选装备,而且是免费的!

3、在Windows上安装Git

可以从Git官网直接下载安装程序,(网速慢的同学请移步国内镜像),然后按默认选项安装即可。

安装完成后,在开始菜单里找到“Git”->“Git Bash”,蹦出一个类似命令行窗口的东西,就说明Git安装成功!


安装完成后,还需要最后一步设置,在命令行输入:

$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"

三、创建版本库

版本库又名仓库,也就是一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

所以,创建一个版本库非常重要。

(1)首先,选择一个合适的地方,创建一个空目录:

$ mkdir learngit
$ cd learngit
$ pwd
/Users/michael/learngit

pwd命令用于显示当前目录。

在Mac上,这个仓库位于/Users/michael/learngit。

在Windows系统中,为了避免遇到各种莫名其妙的问题,请确保目录名(包括父目录)不包含中文。

(2)其次,通过git init命令把这个目录变成Git可以管理的仓库:

$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/

这样Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),且当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。

如果你没有看到.git目录,那是因为这个目录默认是隐藏的,用ls -ah命令就可以看见。

把文件添加到版本库

Git可以跟踪文本文件的改动,比如TXT文件,网页,所有的程序代码等等。而图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来,也就是只知道图片从100KB改成了120KB,但是到底改了啥,版本控制系统不知道,也没法知道。

然而,Microsoft的Word格式是二进制格式,因此,版本控制系统是没法跟踪Word文件的改动,如果要真正使用版本控制系统,就要以纯文本方式编写文件。强烈建议使用标准的UTF-8编码,所有语言使用同一种编码,既没有冲突,又被所有平台所支持。当然也不要使用Windows自带的记事本来编辑任何文本文件,否则会遇到很多不可思议的问题。建议下载Notepad++代替记事本,不但功能强大,而且免费!记得把Notepad++的默认编码设置为UTF-8 without BOM即可:

把一个文件放到Git仓库只需要两步。

(1)第一步,用命令git add告诉Git,把文件添加到仓库:

$ git add readme.txt

第二步,用命令git commit告诉Git,把文件提交到仓库:

$ git commit -m "wrote a readme file"
[master (root-commit) eaadf4e] wrote a readme file
 1 file changed, 2 insertions(+)
 create mode 100644 readme.txt

git commit命令,-m后面输入的是本次提交的说明,这样就可以从历史记录里找到改动记录。

git commit命令执行成功后会告诉你,1 file changed:1个文件被改动(我们新添加的readme.txt文件);2 insertions:插入了两行内容(readme.txt有两行内容)。

综上,添加文件到Git仓库,分两步:
(1)使用命令git add <file>,添加多个文件放在暂存区;
(2)使用命令git commit -m <message>,将暂存区等文件提交到仓库。

四、版本回退

HEAD指向的版本就是当前版本,HEAD^表示上一版本,HEAD^^表示上上版本。

因此,Git允许我们在版本的历史之间穿梭,使用命令git reset -- hard commit_id

穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。

要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

五、工作区和暂存区

暂存区

git add命令实际上就是把要提交的所有修改放到暂存区。

工作区

就是在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:

git commit命令实际上就是把要暂存区的所有修改放到工作区。

六、管理修改

修改但未add

  • 比较工作区与暂存区(即上次git add的内容)的不同

比较所有修改文件的不同

$ git diff

比较指定修改文件的不同

$ git diff <file-name>

修改 已add 但未commit

  • 比较暂存区与仓库分支(上次git commit)的不同
$ git diff --staged

$ git diff --cached

七、撤销修改

  • 场景1——工作区已修改但未add到暂存区
$ git checkout -- <file-name>

其实就是用版本库里的版本替换工作区的版本

  • 场景2——工作区修改且已经git add到暂存区,分两步
$ git reset HEAD <file-name>

回到场景1,再按场景1操作

  • 场景3:已经commit但没有推送到远程库——版本回退

八、删除文件

假设文件原已commit,目前情况是——已经在目录下手动或$ rm <file-name>删除文件

  • 选择一:确实要从版本库中删除该文件,分两步

第一步

$ git rm <file-name>

git add <file-name>

第二步

$ git commit -m "description"
  • 选择二:删错了,要恢复
$ git checkout -- <file-name>

其实就是用版本库里的版本替换工作区的版本

九、远程仓库

创建SSH Key

$ ssh-keygen -t rsa -C "youremail@example.com"

补充 在用户主目录下(cd)

$ ls -ah可见.ssh目录

$ cd .ssh可见id_rsa(私钥不能泄露)和id_rsa.pub(公钥可公开)

关联远程仓库

$ git remote add origin git@github.com:username/repositoryname.git

$ git remote add origin https://github.com/username/repositoryname.git

远程库默认名字为origin

删除已经关联的远程库

git remote rm remote-name

若远程库默认名字为origin,则

git remote rm origin

推送到远程仓库

  • 第一次推送到GitHub
$ git push -u origin master

推送master分支

  • 后续推送
$ git push origin master

不再使用参数-u

从远程库克隆

$ git clone git@github.com:username/repositoryname.git

$ git clone https://github.com/username/repositoryname.git

十、分支管理

查看分支

$ git branch

创建分支

$ git branch <branch-name>

切换分支

$ git checkout <branch-name>

创建+切换分支

$ git checkout -b <branch-name>

合并某分支到当前分支

$ git merge <branch-name>

普通模式合并分支

$ git merge --no-ff -m "description" <branch-name>

通常进行分支合并时,如果可以,Git会使用Fast forward模式,删除分支后,分支历史信息会丢失

--no-ff表示禁用Fast forward模式,能看出曾做过合并

删除分支

$ git branch -d <branch-name>

强行删除分支

$ git branch -D <branch-name>

查看分支合并图

$ git log --graph

简洁查看

$ git log --graph --pretty=oneline --abbrev-commit

十一、Bug分支

假设场景——设A为游戏软件

  1. master 上面发布的是A的1.0版本
  2. dev 上开发的是A的2.0版本
  3. 这时,用户反映 1.0版本存在漏洞,有人利用这个漏洞开外挂
  4. 需要从dev切换到master去填这个漏洞,正常必须先提交dev目前的工作,才能切换
  5. 而dev的工作还未完成,不想提交,所以先把dev的工作stash一下。然后切换到master
  6. 在master建立分支issue101并切换
  7. 在issue101上修复漏洞
  8. 修复后,在master上合并并删除issue101
  9. 切回dev,恢复原本工作,继续工作

保存工作现场

$ git stash

查看保存的工作现场

$ git stash list

恢复工作现场

$ git stash apply

删除工作现场

$ git stash drop

恢复并删除工作现场

git stash pop

十二、Feature分支

每添加一个新功能,最好新建一个feature分支,在上面开发完成后,合并,最后,删除该feature分支

十三、多人协作

多人协作通常的工作模式

  1. 先试图推送自己的修改git push
  2. 若推送失败,则远程分支比本地分支更新,git pull拉取远程分支试图合并
  3. 若合并有冲突,则解决冲突,并在本地提交(addcommit)
  4. 若没有冲突或解决了冲突,再次推送git push

查看远程库信息

$ git remote

详细查看

git remote -v

本地推送分支

$ git push origin <branch-name>

在本地创建和远程分支对应的分支

$ git checkout -b <branch-name> origin/<branch-name>

建立本地分支和远程分支的关联

$ git branch --set-upstream <branch-name> origin/<branch-name>

$ git branch --set-upstream-to=origin/<branch-name> <branch-name>

从远程抓取分支

$ git pull

十四、Rebase“变基”

$ git rebase

把分叉的提交历史“整理”成一条直线,看上去更直观。缺点是本地的分叉提交已经被修改过了。

只对尚未推送或尚未分享给别人的本地修改执行变基操作清理历史,从不对已推送至别处的提交执行变基操作

十五、标签管理

发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本

将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。所以,标签也是版本库的一个快照

创建标签

$ git tag <tag-name>

在最新commit上打一个标签

$ git tag <tag-name> commit-id

在对应的commit_id上打一个新标签

创建带有说明的标签

$ git tag -a <tag-name> -m "description" commit-id

-a指定标签名,-m指定说明文字

查看所有标签

$ git tag

查看对应标签的信息

$ git show <tag-name>

注意标签总是和某个commit挂钩。如果这个commit既出现在master分支,又出现在dev分支,那么在这两个分支上都可以看到这个标签。

操作标签

推送某个标签到远程

$ git push origin <tag-name>

一次性推送全部尚未推送的标签到远程

git push origin --tags

删除一个本地标签

$ git tag -d <tag-name>

删除一个远程标签

先从本地删除

$ git tag -d <tag-name>

再从远程删除

$ git push origin :refs/tags/<tag-name>

相关文章

  • 2018-05-17

    Git介绍及注册 git介绍 git(https://github.com/) 是分布式版本控制技术 SVN是集中...

  • git介绍

    gitbook下载 git教程廖雪峰 本篇博客部分来自pro git 和廖雪峰的gitl教程 版本控制 本控制系统...

  • Git介绍

    关于Git,下面这幅图准确的描述了Git的整个框架: 在平时的开发过程中,可能经常为了某一个功能,而将整个目录进行...

  • Git 介绍

    Git开发流程 Git就是版本控制管理工具,还有一个叫做svn。 可以在命令行使用(大部分都在这是用) 也可以使用...

  • git 介绍

    一 git 的版本控制原理 像subversion等cvs,使用记录版本差异的形式来进行版本控制,如下图所示: g...

  • git ——介绍

    什么是 Git? Git 是由 Linux 之父 Linus Tovalds 为了更好地管理linux内核开发而创...

  • git介绍

    一种常见的版本控制工具 获取 克隆仓库 git支持以ssh或者http的方式来标识远程仓库 以上两条命令作用相同,...

  • Git介绍

    Git简单介绍 什么是GitGit是一款源代码管理工具(版本控制工具) 什么又是源代码:凡是由我们手写的代码都称之...

  • Git介绍

    它是一款免费的、开源的、目前世界上最先进的分布式版本控制系统!

  • Git介绍

    一、Git诞生 同生活中的许多伟大事件一样,Git 诞生于一个极富纷争大举创新的年代。1991年,Linus创建了...

网友评论

      本文标题:Git 介绍

      本文链接:https://www.haomeiwen.com/subject/kfmmoqtx.html