版本控制系统

概念:版本控制系统是软件开发必备的代码管理工具,主要用于解决以下四个方面的问题:①代码备份 ②版本控制 ③协同开发 ④责任追溯。版本控制工具可以分为两种:集中式版本控制系统(如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的版本。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容