1、Git基础概念
1.1、什么是Git
- Git 是一个开源的分布式版本控制系统,是目前世界上最先进、最流行的版本控制系统。可以快读高效地处理从小到非常大地项目版本管理
- 项目越大越复杂,协同开发者越多,越能体现出Git的高性能和高可用性
1.2、Git的特性
- 直接记录快照,而非差异比较
- 近乎所有操作都是本地执行
1.3、SVN的差异比较
- 传统的版本控制系统是基于差异的版本控制,它们存储的是一组基本文件和每个文件随时间逐步累积的差异
- 好处:节省磁盘空间
- 缺点:耗时、效率低
- 在每次切换版本的时候,都需要在基本文件的基础上,应用每个差异,从而生成目标版本对应的文件。
1.4、Git的记录快照
- Git快照是在原有文件版本的基础上重新生成一份新的文件,类似于备份。为了效率,如果文件没有修改,Git不再重新存储该文件,而是只保留一个链接指向之前存储的文件
- 缺点:占用磁盘空间较大
- 优点:版本切换时非常块,因为每个版本都是完整的文件快照,切换版本时直接恢复目标版本的快照即可
- 特点:空间换时间
1.5、Git本地执行
- 在Git中的绝大多数操作都只需要访问本地文件和资源,一般不需要来自网络上其它计算机的信息
- 断网后依旧可以在本地对项目进行版本管理
- 联网后,把本地修改的记录同步到云端服务器即可
1.6 Git中的三个区域
- 使用Git管理的项目,拥有三个区域,分别是工作区、暂存区、Git仓库
1.7 Git中的三种状态
- 已修改:modified表示修改了文件,但是还没将修改的结果放到暂存区
- 已暂存:staged表示对已修改文件的当前版本做了标记,使之包含在下次提交的列表中
- 已提交:committed表示文件已经安全地保存在本地的Git仓库中
1.8 Git工作流程
- 在工作区中修改文件
- 将你想要下次提交的更改进行暂存
- 提交更新,找到暂存区的文件,将快照永久性存储到Git仓库
2、Git基础
2.1、安装并配置Git
https:#git-scm.com/downloads
2.2、配置用户信息
git config --global user.name '用户名'
git config --global user.email '邮箱'
2.3、检查配置信息
# 查看所有的全局配置项
git config --list --global
# 查看指定的全局配置项
git config user.name
git config user.email
2.4、获取帮助信息
# 想要打开 git config 命令的帮助手册
git help config
# 想要获取 git config 命令的快速参考
git config -h
2.5、获取 Git 仓库的两种方式
- 将尚未进行版本控制的本地目录转换为GIT仓库
- 从其它服务器克隆一个已存在的GIT仓库
2.6、初始化仓库
- 在项目目录中,通过鼠标右键打开
Git Bash - 执行 git init 命令将当前的目录转化为 Git 仓库
- git init 命令会创建一个名为 .git 的隐藏目录,这个 .git 目录就是当前项目的 Git 仓库,里面包含了初始的必要文件,这些文件是 Git 仓库的必要组成部分
2.7、工作区中文件的4种状态
- 未跟踪(Untracked)不被Git所管理的文件
- 未修改(Unmodified)在工作区中文件的内容和 Git 仓库中文件的内容保持一致
- 已修改(Modified)在工作区中文件的内容和 Git 仓库中文件的内容不一致
- 已暂存(Staged)工作区中被修改的文件已被放到暂存区,准备将修改后的文件保存到 Git 仓库中
3、Git 的基本操作
3.1、查看文件状态
# 查看文件处于什么状态
git status
# 以精简的方式显示文件状态
git status -s
3.2、跟踪新文件
# 跟踪单个文件
git add index.js
# 跟踪多个文件
git add .
3.3、提交更新
# 执行git commit 命令进行提交,其中 -m 选项后面是本次提交消息,来对提交的内容做进一步描述
git commit -m "描述信息"
# 省略git add直接提交
git commit -a -m "描述信息"
3.4、取消暂存的文件
# 从暂存区中移除对应的文件
git reset HEAD 要移除的文件名称
3.5、移除文件
# 从 Git 仓库和工作区中同时移除 index.js 文件
git rm -f index.js
# 只从 Git 仓库中移除 index.html,但保留工作区中的 index.html
git rm --cached index.html
3.6、忽略文件
- 如果有些文件无需纳入Git的管理,也不希望它们总出现在为跟踪文件列表。
- 可以创建一个名为 .gitgnore 的配置文件,列出要忽略的文件的匹配模式
- 以 # 开头的是注释
- 以 / 结尾的是目录
- 以 / 开头防止递归
- 以 ! 开头表示取反
- 可以使用 glob 模式进行文件和文件夹的匹配
3.7、查看提交历史
# 按时间先后顺序列出所有的提交历史,最近的提交排在最上面
git log
# 只展示最新的两条提交历史,数字可以按需填写
git log -2
# 在一行上展示最近两条提交历史的信息
git log -2 --pretty=oneline
# 在一行上展示最近两条提交历史的信息,并自定义输出的格式
# %h 提交的简写哈希值 %an作者名字 %ar作者修订日期,按多久以前的方式显示 %s提交说明
git log -2 --pretty=format: "%h | %an | %ar | %s"
3.8、回退到指定的版本
# 在一行上展示所有的提交历史
git log --pretty=oneline
# 使用 git reset --hard 命令,根据指定的提交 ID 回退到指定的版本
git reset --hard <CommitID>
4、Github远程仓库
4.1、远程仓库的两种访问方式
- HTTPS:零配置;但是每次访问仓库时,需要重复输入 Github 的账号和密码才能访问成功
- SSH:需要进行额外的配置;但是配置成功后,每次访问仓库时,不需重复输入 Github 的账号和密码
4.2、基于HTTPS将本地仓库上传到 Github
本地没有现成的 Git 仓库:
# 使用终端命令创建 README.md 文档,并写入初始内容为 #project
echo "#project" >> README.md
# 初始化 Git 仓库
git init
# 跟踪README.md文件
git add README.md
# 提交文件
git commit -m "first commit"
# 将本地仓库和远程仓库进行关联,并把远程仓库命名为 origin
git remote add origin https://github.com/GodLovesYou/studytest.git
# 将本地仓库中的内容推送到远程的 origin 仓库中
git push -u origin master
本地有现成的 Git 仓库:
# 将本地仓库和远程仓库进行关联,并把远程仓库命名为 origin
git remote add origin https://github.com/GodLovesYou/studytest.git
# 将本地仓库中的内容推送到远程的 origin 仓库中
git push -u origin master
4.3、远程仓库使用 SSH Key
- SSH Key 的作用:实现本地仓库和Github之间免登录和加密数据传输
- SSH Key 的好处:免登录身份认证、数据加密传输
- SSH Key由两部分组成,分别时:
- id_rsa (私钥文件,存放于客户端的电脑中即可)
- id_rsa.pub (公钥文件,需要配置到 Github中)
4.3.1 生成SSH Key
- 打开 Git Bash
- 输入命令:ssh-keygen -t rsa -b 4096 -C “电子邮箱地址”
- 连续3次回车,即可在 C:\Users\用户名.ssh 目录中生成 id_rsa 和 id_rsa.pub 两个文件
4.3.2 配置 SSH Key
- 使用记事本打开 id_rsa.pub 文件,复制里面的文本内容
- 在浏览器中登录 Github,点击头像 -> Settings -> SSH and GPG Keys -> New SSH Key
- 将 id_rsa.pub 文件中的内容,粘贴到 Key 对应的文本框中
- 在 Title 文本框中任意填写一个名称,来标识这个 Key 从何而来
4.3.3 检测 Github 的SSH key是否配置成功
# 打开 Git Bash,输入如下的命令并回车执行:
ssh -T git@github.com
# 如能看到类似消息,证明 SSH Key 已经配置成功了
Hi ***! You've successfully authenticated, but GitHub does not provide shell access.
4.3.4 基于 SSH 将本地仓库上传到 Github
本地没有现成的 Git 仓库:
# 使用终端命令创建 README.md 文档,并写入初始内容为 #project
echo "#project" >> README.md
# 初始化 Git 仓库
git init
# 跟踪README.md文件
git add README.md
# 提交文件
git commit -m "first commit"
# 将本地仓库和远程仓库进行关联,并把远程仓库命名为 origin
git remote add origin git@github.com:GodLovesYou/studytest.git
# 将本地仓库中的内容推送到远程的 origin 仓库中
git push -u origin master
本地有现成的 Git 仓库:
# 将本地仓库和远程仓库进行关联,并把远程仓库命名为 origin
git remote add origin git@github.com:GodLovesYou/studytest.git
# 将本地仓库中的内容推送到远程的 origin 仓库中
git push -u origin master
4.4、将远程仓库克隆到本地
# 打开 Git Bash,输入如下的命令并回车执行
git clone 远程仓库的地址
5、Git 分支
5.1、分支的概念
- 分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN
- 如果两个平行宇宙互不干扰,那对现在的你也没啥影响
- 不过,在某个时间点,两个平行宇宙合并了,结果,你即学会了Git有学会了SVN
5.2、分支在实际开发中的作用
- 在进行多人协作开发的时候,为了防止互相干扰,提高协同开发的体验,建议每个开发者都基于分支进行项目功能的开发
5.3、master 主分支
- 在初始化本地 Git 仓库的时候,Git 默认已经帮助我们创建了一个名字叫做 master 的分支。通常我们把这个 master 分支叫做主分支
- master主分支主要用来保存和记录整个项目已完成的功能代码
- 不允许程序员直接在master主分支上修改代码,这样做风险太高,容易导致整个项目崩溃
5.4、功能分支
- 程序员不能直接在 master 分支上进行功能的开发,所以就有了功能分支的概念
- 功能分支指的是专门用来开发新功能的分支,它是临时从 master 主分支上分叉出来的,当新功能开发并且测试完毕后,需要合并到master主分支上
5.5、查看分支列表
# 使用如下命令,可以查看当前 Git 仓库中所有分支列表
git branch
分支名字前面的*号表示当前所处的分支
5.6、创建新分支
# 使用如下命令,可以基于当前分支,创建一个新的分支,此时,新分支中的代码和当前分支完全一样
git branch 分支名称
5.7、切换分支
# 使用如下的命令,可以切换到指定的分支上进行开发
git checkout dev_base
5.8、分支的快速创建和切换
# 使用如下命令可以创建指定名称的新分支,并立即切换到新分支上
# -b 表示创建一个新分支
# checkout 表示切换到刚刚新建的分支上
git checkout -b 分支名称
5.9、合并分支
# 1. 切换到 master 分支
git checkout master
# 2. 在 master 分支上运行 git merge 命令,将 dev_base 分支的代码合并到 master 分支
git merge dev_base
5.10、删除分支
# 当把功能分支的代码合并到 master 主分支上以后,就可以使用如下的命令,删除对应的功能分支
git branch -d 分支名称
5.11、遇到冲突时的分支合并
- 如果在两个不同的分支中,对同一个文件进行了不同的修改,Git就没法干净的合并它们。
- 此时需要打开这些包含冲突的文件然后手动解决冲突
# 假设:在把 dev_base 分支合并到 master 分支期间,代码发生了冲突
git checkout master
git merge dev_base
# 打开包含冲突的文件,手动解决冲突之后,再执行如下的命令
git add .
git commit -m "解决了分支合并冲突的问题"
6、远程分支操作
6.1、将本地分支推送到远程仓库
# -u 表示把本地分支和远程分支进行关联,只在第一次推送的时候需要带 -u 参数
git push -u 远程仓库的别名 本地分支名称:远程分支名称
# 实际案例
git push -u origin payment:pay
# 如果希望远程分支的名称和本地分支名称保持一致,可以对命令进行简化
git push -u origin payment
注意:第一次推送分支需要带 -u 参数,此后可以直接使用 git push 推送代码到远程分支
6.2、查看远程仓库中所有的分支列表
# 通过如下的命令,可以查看远程仓库中,所有的分支列表的信息
git remote show 远程仓库名称
6.3、跟踪远程分支
# 从远程仓库中,把对应的远程分支下载到本地仓库,保持本地分支和远程分支名称相同
git checkout 远程分支的名称
# 示例:
git checkout pay
# 从远程仓库中,把对应的远程分支下载到本地仓库,并把下载的本地分支进行重命名
git checkout -b 本地分支名称 远程仓库名称/远程分支名称
# 示例:
git checkout -b payment origin/pay
6.4、拉去远程分支的最新代码
# 从远程仓库,拉取当前分支最新的代码,保持当前分支的代码和远程分支代码一致
git pull
6.5、删除远程分支
# 删除远程仓库中,指定名称的远程分支
git push 远程仓库名称 --delete 远程分支名称
# 示例:
git push origin --delete pay
|