第一章 Git概述
Git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。
Git易于学习,占地面积小,性能极快。它具有廉价的本地库,方便的暂存区域和多个工作流分支等特性。其性能优于Subversion、CVS、Perforce和ClearCase等版本控制工具。
何为版本控制
版本控制是一种记录文件内容变化。以便将来查阅特定版本修订情况的系统。
版本控制其实最重要的是可以记录文件修改历史记录,从而能让用户查看历史版本,方便版本切换
为什么需要版本控制
从个人开发过渡到团队协作
版本控制工具
集中式版本控制工具
CVS、SVN(Subversion)、VSS…
集中化的版本控制系统诸如CVS、SVN等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。多年以来,这已成为版本控制系统的标准做法。
这种做法带来了许多好处,每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易。
事分两面,有好有坏。这么做显而易见的缺点是中央服务器的单点故障。如果服务器宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。
分布式版本控制工具
Git、Mercurial、Bazaar、Darcs… . .
像Git这种分布式版本控制工具,客户端提取的不是最新版本的文件快照,而是把代码仓库完整地镜像下来(本地库)。这样任何一处协同工作用的文件发生故障,事后都可以用其他客户端的本地仓库进行恢复。因为每个客户端的每一次文件提取操作,实际上都是一次对整个文件仓库的完整备份。
分布式的版本控制系统出现之后,解决了集中式版本控制系统的缺陷:
1.服务器断网的情况下也可以进行开发(因为版本控制是在本地进行的)
2.每个客户端保存的也都是整个完整的项目(包含历史记录,更加安全)
Git简史
Git工作机制
Git和代码托管中心
代码托管中心是基于网络服务器的远程代码仓库,一般简单称为远程库
局域网
GitLab
互联网
GitHub(外网)
Gitee(国内网站)
第二章 安装教程
(21条消息) Git最新本版安装步骤(保姆级教程+解释)git version 怎么下载最新版本!0 !的博客-CSDN博客
07_尚硅谷_Git_安装_安装和客户端的使用_哔哩哔哩_bilibili
第三章 Git常用命令
命令名称 | 作用 |
---|---|
git config–global user.name 用户名 | 设置用户签名 |
git config–global user.email 邮箱 | 设置用户签名 |
git init | 初始化本地库 |
git status | 查看本地库状态 |
git add | 添加到暂存区 |
git commit-m “日志信息” 文件名 | 提交到本地库 |
git reflog | 查看历史记录 |
git reset–hard 版本号 | 版本穿梭 |
3.1 设置用户签名
3.2 初始化本地库
git init
Ctrl+ins | 复制 |
---|---|
Shift+ins | 粘贴 |
Ctrl+w | 删除左边的元素 |
3.3查看本地库状态
3.4添加暂存区
从暂存区删除
3.5 提交本地库
3.6修改文件
3.7历史版本
版本穿梭
确定要穿梭的版本号
git reset --hard 版本号
第四章 Git的分支操作
4.1 什么是分支
同时推进多个任务,为每个任务我们就可以创建每个任务的单独分支。
使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。
(分支底层其实也是指针的引用)
4.2 分支的好处
同时推进多个功能开发,提高开发效率。
各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响
4.3 分支的操作
命令名称 | 作用 |
---|---|
git branch 分支名 | 创建分支 |
git branch -v | 查看分支 |
git checkout 分支名 | 切换分支 |
git merge 分支名 | 把指定的分支合并到当前分支上 |
4.3.1查看分支
4.3.2创建分支
4.3.3修改分支
4.3.4切换分支
4.3.5合并分支
4.3.6产生冲突
4.3.7解决冲突
4.4 创建分支和切换分支图解
第五章 Git团队协作机制
团队内协作
跨团队协作
第六章 GitHub操作
6.1 创建远程仓库
6.2 远程仓库操
6.2.1 创建远程仓库库别名
6.2.2 推送本地分支到远程仓库
git push 别名 分支
6.2.3 克隆远程仓库到本地
clone会做如下操作
- 拉取代码
- 初始化本地仓库
- 创建别名
6.2.4 邀请加入团队
团队内协作
跨团队协作
6.2.5 拉取远程库内容
6.3 跨团队协作
6.4 SSH免密登录
远程从仓库有一个SSH的地址,因此我们还可以使用SSH进行访问
![在这里插入图片描述](https://img-blog.csdnimg.cn/2538875db45642dab22705b8fd2d1761.png#pic_center