Bootstrap

分布式版本控制系统:Git

1 Git概述

Git官网:https://git-scm.com/

  • Git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目
  • Git易于学习,占地面积小,性能极快。它具有廉价的本地库、方便的暂存区域和多个工作流分支等特性
1.1 何为版本控制

版本控制是一种记录文件内容变化,以便将来查阅特定版本修订情况的系统

版本控制其实最重要的是可以记录文件修改历史纪录,从而让用户能够查看历史版本

1.2 为什么需要版本控制

个人开发过渡到团队协作

1.3 版本控制工具
(1)集中式版本控制工具

如CVS、SVN、VSS……

集中化的版本控制系统,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连接到这台服务器,取出最新的文件或提交更新

  • 好处:每个人都可以在一定程度上看到项目中其他人正在做些什么,而管理员也可以轻松掌握每个开发者的权限,并且管理一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易
  • 缺点:中央服务器的单点故障。
(2)分布式版本控制工具

如Git、Dares……

分布式版本控制工具,客户端提取的不是最新版本的文件快照,而是把代码仓库完整地镜像下来(本地库)这样任何一处协同工作的文件发生故障,事后都可以用其他客户端的本地仓库进行恢复,因为每个客户端的每一次文件提取操作,实际上都是一次对整个文件仓库的完整备份

分布式的版本控制系统出现之后,解决了集中式版本控制系统的缺陷:

  1. 服务器断网的情况下也可以进行开发(因为版本控制是在本地进行的)
  2. 每个客户端保存的也都是整个完整的项目(包含历史记录,更加安全)
1.4 Git工作机制

在这里插入图片描述

一旦生成历史版本就不能删除了

1.5 Git和代码托管中心

代码托管中心是基于网络服务器的远程代码仓库,一般简单称为远程库

  • 局域网:GitLab
  • 互联网:GitHub、Gitee

2 Git安装

略……

3 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 设置用户签名
1)基本语法

git config --global user.name 用户名

git config --global user.email 邮箱

2)说明

Git首次安装必须设置一下用户签名,否则无法提交代码

这里设置的用户签名和登录GitHub(或其他代码托管中心)的账号没有任何关系

3.2 初始化本地库
1)基本语法

git init

2)结果

生成一个 .git 的隐藏文件夹

  • git status:查看当前状态
3.3 添加暂存区
1)基本语法

git add 文件名

2)删除暂存区中的文件

git rm --cached 文件名

3.4 提交本地库

将暂存区的文件提交到本地库

1)基本语法

git commit -m “日志信息” 文件名

3.4 修改文件

修改后的文件没有添加到暂存区

3.5 版本穿梭
1)查看版本 基本语法

git reflog:查看版本信息

git log:查看版本详细信息

2)版本穿梭 基本语法

git reset --hard 版本号

4 Git分支操作

4.1 什么是分支

在版本控制过程中,同时推进多个任务,我们就可以为每个任务创建单独的分支。

使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行

4.2 分支的好处·

同时并行推进多个功能开发,提高开发效率

各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可

4.3 分支的操作
4.3.1 基本命令
命令名称作用
git branch 分支名创建分支
git branch -v查看分支
git checkout 分支名切换分支
git merge 分支名把指定分支合并到当前分支上
4.3.2 合并分支(正常合并)

直接通过 git merge 分支名 合并

4.3.3 合并分支(冲突合并)

产生冲突的原因:合并分支时,两个分支在同一文件有两种不同的修改

此时,Git无法替我们决定使用哪一个,必须人为决定新代码内容

修改内容后需要重新执行add和commit命令,仅修改了当前分支的内容

5 GitHub操作

5.1 推送本地分支到远程仓库

git push 远程仓库地址/别名 分支

5.2 将远程仓库项目拉取到本地

git pull 远程仓库地址/别名 分支

拉取操作会自动提交本地库

5.3 克隆远程仓库到本地

git clone 远程仓库地址

5.4 邀请加入团队

GitHub仓库中:

settings → Collaborators → add people → 输入邮箱即可添加成员,然后复制邀请链接,被邀请者可以通过邀请链接加入团队

5.5 跨团队协作

GitHub中右上角的fork……

;