概念:版本控制系统是软件开发必备的代码管理工具,主要用于解决以下四个方面的问题:①代码备份 ②版本控制 ③协同开发 ④责任追溯。版本控制工具可以分为两种:集中式版本控制系统(如SVN)和分布式版本控制系统(如Git)。
集中式版本控制系统的代码仓库位于中央服务器,开发人员在进行工作时,需要从中央服务器下载所需的项目文件(如代码文件),并在工作完成后将相应的文件(如代码文件)上传回中央服务器。在这种模式下,中央服务器充当“仓库”的角色,而这也就导致了以下问题:①开发人员在进行工作时需要保持网络畅通。②文件不具备冗余性。
分布式版本控制系统的代码仓库位于本地终端(本地仓库)和中央服务器(远程仓库),开发人员在进行工作时,需要通过中央服务器克隆远程仓库/更新本地仓库,并在工作完成后将本地仓库的内容同步回中央服务器。在这种模式下,中央服务器更多充当“交换站”的角色,而这也就有效地解决了集中式版本控制系统存在的不足:①开发人员可以基于本地仓库开展工作。②每一个本地仓库都是远程仓库的备份。因此,企业开发通常基于分布式版本控制系统。
注:大多数情况下,一个项目对应一个代码仓库。
Git的基本结构:
①本地仓库。本地仓库可以划分为以下三个部分:
工作目录(Working Tree):开发者的工作目录(即“.git目录”所在目录)。
暂存区(Index):工作目录中的文件(如代码文件)/目录提交到本地历史版本仓库前的临时存储空间(位于“.git目录”中)。
本地历史版本仓库(Repository):存放不同版本项目的存储空间(位于“.git目录”中)。
②远程仓库。
所谓远程仓库,与本地仓库并无区别,只不过远程仓库更多以项目(代码)托管平台的形式存在(Web端GUI页面)。常见的项目(代码)托管平台有GitHub(https://github.com)、码云(https://gitee.com)等。
分布式版本控制系统下,开发者的工作流程如下:
流程一:通过中央服务器克隆远程仓库到本地(即生成本地仓库)→将工作目录的项目文件切换到所需的版本→创建分支并基于此分支开展工作→工作完成后将此分支合并到master分支→评审后将本地仓库“push”到远程仓库(为了防止代码冲突,需要先通过“pull”命令更新本地仓库)
流程二:通过中央服务器更新本地仓库→将工作目录的项目文件切换到所需的版本→创建分支并基于此分支开展工作→工作完成后将此分支合并到master分支→评审后将本地仓库“push”到远程仓库(为了防止代码冲突,需要先通过“pull”命令更新本地仓库)
Git的分支:
①master分支:master分支是Git仓库默认创建的分支,每个Git仓库都有自己的master分支。master分支主要用于管理项目已投入使用/即将投入使用的版本。
②自定义分支:自定义分支是开发者手动创建的分支。自定义分支主要用于管理项目测试阶段的版本。(以创建“dev为例”)
分支合并前:
dev分支合并到master分支后(这里进行了dev分支的删除操作,如果仅仅是合并,dev分支不会消失。):
注:同一个Git仓库下的所有分支共享该仓库的资源(工作目录、暂存区、历史版本仓库)。需要注意的是,各分支下已经“commit”的文件/目录在工作目录、历史版本仓库中逻辑隔离。
Git的下载与安装:
①根据当前OS下载相应的安装包(网址:https://git-scm.com/download/)。
②安装Git(所有配置保持默认即可)。
Git常用命令(在工作目录/项目目录下使用):
①git init ——将当前目录初始化为Git仓库。
②git status ——查看当前仓库下文件/目录的状态。(注:在任意分支下均能看到该仓库(即所有分支)未添加到暂存区的文件、已添加到暂存区未提交到历史版本仓库的文件。)
③git add 文件名 ——将指定文件/目录添加到暂存区。(注:在任意分支下均能将该仓库(即所有分支)的文件/目录添加到暂存区。)
④git rm 文件名 ——将指定文件/目录的删除指令添加到暂存区。(因此对于“暂存区”的另一种理解是:用于临时存储开发者对文件(如代码文件)/目录的更改。)
⑤git commit -m ‘提交注释’——将暂存区中的所有文件/目录提交到本地历史版本仓库。(注:在任意分支下均能将暂存区中的所有文件/目录提交到本地历史版本仓库。在哪个分支下提交,这些文件/目录就属于哪个分支。)
⑥git branch ——查看当前仓库拥有的全部分支以及开发者正在使用的分支。
⑦git branch 分支名 ——创建分支。
⑧git checkout 分支名 ——切换分支。
⑨git branch -d 分支名 ——删除分支。(注:分支上所有版本的项目都会随分支删除。)
⑩git reset --hard commit_id(索引值) ——将工作目录(当前分支的)回退到某个历史版本。(回退工作目录下的所有文件,“.git文件除外”。)
⑪git log ——查看Git日志。(注:通过此命令只能查看当前分支的“commit操作”。)
⑫git reflog ——查看Git日志。(注:通过此命令可以查看所有分支的“commit操作”和“reset操作”,并可以看到开发者切换分支的记录。)
⑬git merge 分支名 ——将指定分支合并到master分支。(注:该命令需要在master分支下执行。)
⑭git config user.name(查看“Git”用户名) git config user.mail(查看“Git”邮箱) git config --global user.name “用户名”(设置“Git”用户名,并使其对该终端下所有本地仓库生效) git config --global user.mail “邮箱”(设置“Git”邮箱,并使其对该终端下所有本地仓库生效)
⑮git push 远程仓库链接 本地仓库分支名:远程仓库分支名 ——将本地仓库指定分支合并到远程仓库指定分支。
⑯git clone 远程仓库链接 ——将远程仓库克隆到当前目录下
⑰git pull 远程仓库链接 远程仓库分支名:本地仓库分支名 ——将远程仓库指定分支合并到本地仓库指定分支(即更新本地仓库)。
⑱ssh-keygen -t 密钥类型(一般为rsa) -C “密钥注释”(用于识别密钥) ——为当前终端生成密钥对。
⑲cd ~/.ssh ——将当前目录切换到存放公钥和私钥的目录(用于查看当前终端是否存在公钥和私钥)。需要注意的是,该终端下的所有本地仓库都可以使用这一对密钥。
IDEA集成Git:
①在IDEA中依次点击“File→setting”。
②在弹出的选项卡中依次点击“Version Control→Git”,并在“Path to Git executable”一栏中粘贴“git.exe”文件的路径(位于Git安装目录的“bin目录”下)。
之后点击右侧的“Test”按钮,如果配置无误,IDEA会在下方显示Git的版本。