文章目录
1 版本控制工具应该具备的功能
- 协同修改
- 多人并行不悖的修改服务器端的同一个文件。
- 数据备份
- 不仅保存目录和文件的当前状态,还能够保存每一个提交过的历史状态。
- 版本管理。
- 在保存每一个版本的文件信息的时候要做到不保存重复数据,以节约存储空间,提高运行效率。这方面 SVN 采用的是增量式管理的方式,而 Git 采取了文件系统快照的方式。
- 权限控制
- 对团队中参与开发的人员进行权限控制。
- 对团队外开发者贡献的代码进行审核 -> Git 独有。
- 历史记录
- 查看修改人、修改时间、修改内容、日志信息。
- 将本地文件恢复到某一个历史状态。
- 分支管理
- 允许开发团队在工作过程中多条生产线同时推进任务,进一步提高效率。
2 版本控制简介
2.1 版本控制
工程设计领域中使用版本控制管理工程蓝图的设计过程。在 IT 开发过程中也可以使用版本控制思想管理代码的版本迭代。
2.2 版本控制工具
思想:版本控制
实现:版本控制工具
集中式版本控制工具:
CVS、SVN、VSS …
分布式版本控制工具:
Git、Mercurial、Bazaar、Darcs …
3 Git 简介
3.1 Git 的简史
3.2 Git 官网和 Logo
官网地址:https://git-scm.com/
3.3 Git 的优势
- 大部分操作在本地完成,不需要联网
- 完整性保证
- 尽可能添加数据而不是删除或修改数据
- 分支操作非常快捷流畅
- 与 Linux 命令全面兼容
3.4 Git 的安装
参考链接文章:https://www.cnblogs.com/chenmingjun/p/10160410.html
注:
1、安装到一个没有中文和没有空格的目录
2、Git的默认编辑器:建议使用Vim编辑器
3.5 Git 的本地结构
3.6 Git 和代码托管中心
代码托管中心的任务:维护远程仓库。
- 局域网环境下
- GitLab 服务器
- 外网环境下
- GitHub
- 码云
- Coding
3.7 本地仓库和远程仓库
3.7.1 团队内部协作
3.7.2 跨团队协作
4 Git 命令行操作
4.1 本地仓库初始化
命令:git init
效果:
注:
.git目录中存放的是本地库相关的子目录和文件,不要删除,也不要胡乱修改。
4.2 设置签名
形式:
用户名:tom
Email地址:goodMorning@atguigu.com
作用:区分不同开发人员的身份。
辨析:这里设置的签名和登录远程库(代码托管中心)的账号、密码没有任何关系。
命令:
项目级别/仓库级别:仅在当前本地库范围内有效
git config user.name tom_pro
git config user.email goodMorning_pro@atguigu.com
设置的信息保存位置:./.git/config 文件
系统用户级别:登录当前操作系统的用户范围
git config --global user.name tom_glb
git config --global user.email goodMorning_glb@atguigu.com
设置的信息保存位置:~/.gitconfig 文件
级别优先级:
就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别的签名。
如果只有系统用户级别的签名,就以系统用户级别的签名为准。
二者都没有不允许。
实际开发中我们设置的是系统用户级别较多
。
4.3 基本操作
4.3.1 状态查看
git status
查看工作区、暂存区状态
4.3.2 添加
git add [filename]
将工作区的“新建/修改”添加到暂存区
4.3.3 提交
git commit -m “commit message” [filename]
将暂存区的内容提交到本地仓库
以上三个命令的实际操作图解如下:
4.3.4 查看历史记录
git log
多屏显示控制方式:
空格向下翻页
b 向上翻页
q 退出
git log --pretty=oneline
git log --oneline
git reflog
HEAD@{移动到当前版本需要多少步}
4.3.5 版本的前进后退
本质:
基于索引值操作[推荐]
git reset --hard [局部索引值]
git reset --hard c433284
使用^符号:只能后退
git reset --hard HEAD^
注:一个表示后退一步,n个表示后退n步
使用~符号:只能后退
git reset --hard HEAD~n
注:表示后退n步
查看文件的最后3行数据:
tail -n 3 good.txt
4.3.6 reset命令的三个参数对比
打开Git命令的本地帮助文档:
$ git help reset
注:打开的是本地的帮助文档
–soft 参数
表示仅仅在本地库中移动HEAD指针
–mixed 参数
表示在本地库移动HEAD指针
且重置暂存区(修改)
–hard 参数
表示在本地库移动HEAD指针
且重置暂存区(index file)
且重置工作区(working tree)
4.3.7 删除文件并找回
演示前提:删除前,文件存在的状态是已提交到了本地库后再进行删除操作。
操作:git reset --hard [指针位置]
删除操作已经提交到本地库:指针位置指向历史记录
删除操作尚未提交到本地库:指针位置使用HEAD
任何一个已经提交
的版本操作,就会在本地版本库中有一个确定的记录,记录着该文件的操作,即便我们做的是提交删除
的操作,那么该记录也是不可磨灭的。
Git只会增加版本,而不会把任何一个版本删除。
本地库 == 本地仓库 == 本地版本库
[删除操作已经提交到本地库]完整截图如下:
找回[删除操作已经提交到本地库]完整截图如下:
[删除操作尚未提交到本地库]完整截图如下:
找回[删除操作尚未提交到本地库]完整截图如下:
4.3.8 比较文件差异
git 是以行为单位进行文件管理的。
git diff [文件名]
将工作区中的文件和暂存区中的文件进行比较
git diff [本地库中某一历史版本] [文件名]
将工作区中的文件和本地库历史记录进行比较
注:不指定具体文件名时候表示比较多个文件。