1. 什么是git?
Git
是一个开源的分布式版本控制系统,是目前世界上最先进、最流行的版本控制系统。可以快速高效地处理从很小到非常大的项目版本管理。
特点:项目越大越复杂,协同开发者越多,越能体现出 Git 的高性能和高可用性!
2. git的特性
Git 之所以快速和高效,主要依赖于它的如下两个特性:
① 直接记录快照,而非差异比较
② 近乎所有操作都是本地执行
3. git 的三种状态
已修改 modified
已暂存 staged
*
已提交 committed
注意:
-
工作区的文件被修改了,但还没有放到暂存区,就是已修改状态。
-
如果文件已修改并放入暂存区,就属于已暂存状态。
-
如果 Git 仓库中保存着特定版本的文件,就属于已提交状态。
4. git的工作流程
基本的 Git 工作流程如下:
① 在工作区中修改文件
② 将你想要下次提交的更改进行暂存
③ 提交更新,找到暂存区的文件,将快照永久性存储到 Git 仓库
5. 使用方法
首先是要去官网,下载符合自己电脑的安装包,安装完成之后我们就要开始配置我们的用户信息
因为安装完 Git
之后,要做的第一件事就是设置自己的用户名和邮件地址。因为通过 Git
对项目进行版本管理的时候,Git
需要使用这些基本信息,来记录是谁对项目进行了操作:
git config --global user.name "itheima"
git config --global user.email "itheima@itcast.cn"
6. Git 的全局配置文件
通过 git config --global user.name
和 git config --global user.email
配置的用户名和邮箱地址,会被写入到 C:/Users/用户名文件夹/.gitconfig
文件中。这个文件是 Git
的全局配置文件,配置一次即可永久生效。可以使用记事本打开此文件,从而查看自己曾经对 Git 做了哪些全局性的配置。
6.1 检查配置信息
除了使用记事本查看全局的配置信息之外,还可以运行如下的终端命令,快速的查看 Git 的全局配置信息:
# 查看所有的全局配置项
git config --list --global
# 查看指定的全局配置项
git config user.name
git config user.email
6.2 获取帮助信息
可以使用 git help <verb>
命令,无需联网即可在浏览器中打开帮助手册,例如:
# 打开 git config 命令的帮助手册
git help config
如果不想查看完整的手册,那么可以用 -h 选项获得更简明的“help”输出:
# 想要获取 git config 命令的快速参考
git config -h
7. git的基本操作
7.1 获取 Git
仓库的两种方式
① 将尚未进行版本控制的本地目录转换为 Git
仓库
② 从其它服务器克隆一个已存在的 Git
仓库
以上两种方式都能够在自己的电脑上得到一个可用的 Git 仓库
7.2 在现有目录中初始化仓库
如果自己有一个尚未进行版本控制的项目目录,想要用 Git
来控制它,需要执行如下两个步骤:
① 在项目目录中,通过鼠标右键打开“Git Bash
”
② 执行 git init
命令将当前的目录转化为 Git
仓库
git init
命令会创建一个名为 .git 的隐藏目录,这个 .git 目录就是当前项目的 Git 仓库,里面包含了初始的必要文件,这些文件是 Git 仓库的必要组成部分
8. git的一些相关指令
8.1 显示文件的状态
git status
# 以精简的方式显示文件状态
git status -s
git status --short
未跟踪文件前面有红色的 ?? 标记
8.2 跟踪新文件
git add
git add index.html
# 如果文件过多,你项跟踪目录下所有文件
git add *.*
8.3 提交更新
git commit -m '新建了一个***.html文件'
提交成功后会显示
再次检查文件会提示
8.4 对已提交的文件进行修改
目前,index.html
文件已经被 Git
跟踪,并且工作区和 Git
仓库中的 index.html
文件内容保持一致。当我们修改了工作区中 index.html
的内容之后,再次运行 git status
和 git status -s
命令,会看到文件 index.html
出现在 Changes not staged for commit
这行下面,说明已跟踪文件的内容发生了变化,但还没有放到暂存区。
注意:修改过的、没有放入暂存区的文件前面有红色的 M 标记。
8.5 移除文件
从 Git 仓库中移除文件的方式有两种:
① 从 Git 仓库和工作区中同时移除对应的文件
② 只从 Git 仓库中移除指定的文件,但保留工作区中对应的文件
# 从 Git仓库和工作区中同时移除 index.js 文件
git rm -f index.js
# 只从 Git 仓库中移除 index.css,但保留工作区中的 index.css 文件
git rm --cached index.css
8.6 忽略文件
一般我们总会有些文件无需纳入 Git
的管理,也不希望它们总出现在未跟踪文件列表。 在这种情况下,我们可以创建一个名为 .gitignore
的配置文件,列出要忽略的文件的匹配模式。
文件 .gitignore
的格式规范如下:
① 以 # 开头的是注释
② 以 / 结尾的是目录
③ 以 / 开头防止递归
④ 以 ! 开头表示取反
⑤ 可以使用 glob 模式进行文件和文件夹的匹配(glob 指简化了的正则表达式)
-
星号 * 匹配零个或多个任意字符
-
[abc]
匹配任何一个列在方括号中的字符 (此案例匹配一个 a 或匹配一个 b 或匹配一个 c) -
问号 ? 只匹配一个任意字符
-
两个星号 ** 表示匹配任意中间目录(比如 a/**/z 可以匹配 a/z 、 a/b/z 或 a/b/c/z 等)
-
在方括号中使用短划线分隔两个字符, 表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)
8.7 查看提交的历史
# 按时间先后顺序列出所有的提交历史,最近的提交在最上面
git log
# 只展示最新的两条提交历史,数字可以按需进行填写
git log -2
# 在一行上展示最近两条提交历史的信息
git log -2 --pretty=oneline
# 在一行上展示最近两条提交历史信息,并自定义输出的格式
# &h 提交的简写哈希值 %an 作者名字 %ar 作者修订日志 %s 提交说明
git log -2 --pretty=format:"%h | %an | %ar | %s"
8.8 回退到指定的版本
# 在一行上展示所有的提交历史
git log --pretty=oneline
# 使用 git reset --hard 命令,根据指定的提交 ID 回退到指定版本
git reset --hard <CommitID>
# 在旧版本中使用 git reflog --pretty=oneline 命令,查看命令操作的历史
git reflog --pretty=onelone
# 再次根据最新的提交 ID,跳转到最新的版本
git reset --hard <CommitID>