0

0

一文带你读懂什么是Git版本管理

WBOY

WBOY

发布时间:2022-02-21 17:53:29

|

3076人浏览过

|

来源于CSDN

转载

本篇文章中给大家带来了关于git版本管理的相关知识,版本管理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态,希望对大家有帮助。

一文带你读懂什么是Git版本管理

Git是一个“分布式版本管理工具”。
版本管理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。
我们在写东西的时候都用过撤消这个功能,但是撤消只能回撤有限步,通常关闭编辑软件后再重新打开,此时的撤销纪录都已被清空了。而“版本管理工具”则不同,它能记录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。

创建仓库

安装git软件后,在任意目录下创建一个新文件夹,打开,然后执行git init来创建新的git仓库(该命令将创建一个名为.git的隐藏子目录)。

检出仓库

执行命令git clone + 远程项目地址,用来克隆远端服务器上的仓库。

Git状态

Git有三种状态,分别是已提交(committed)、已修改(modified)、已暂存(staged)。

  • 已修改(modified):已修改表示修改了文件,但还没保存到数据库中。
  • 已暂存(staged):表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。
  • 已提交(committed):数据已经安全的保存在本地数据库中。

Git的三种状态分别对应本地仓库的三个工作流,本低仓库是由git维护的三棵树组成。

  • 第一个是工作目录,持有实际文件,增删文件和内容;
  • 第二个是暂存区(Index),像个缓存区域,临时保存改动。输入git add+filename,此次改动就放到了暂存区。
  • 第三个是HEAD,指向最后一次提交的结果。输入git commit命令,此次改动就放到了本地仓库。commit之后的可以称为一个版本。
    Git工作流

git基本工作流程:

  • 提出更改(添加到暂存区)
    使用命令git add (针对特定文件)或git add *(针对所有文件)可以提出更改(把它们添加到暂存区)。
  • 提交改动
    使用命令git commit -m “代码提交信息” 来实际提交改动,执行完后改动就提交到了HEAD,但是还没到远端仓库。
  • 推送改动
    使用命令git push origin master 将改动提交到远端仓库master分支(通常不会直接提交到master分支,而是推送到自己的分支,核对无误后再进行merge)。

分支

前面提到了master分支,那么如何直观的了解分支呢?

分支是用来将特性开发绝缘开来的。在创建仓库的时候,master是“默认”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。
在这里插入图片描述

网奇英文商城外贸系统
网奇英文商城外贸系统

网奇Eshop是一个带有国际化语言支持的系统,可以同时在一个页面上显示全球任何一种语言而没有任何障碍、任何乱码。在本系统中您可以发现,后台可以用任意一种语言对前台进行管理、录入而没有阻碍。而任何一个国家的浏览者也可以用他们的本国语言在你的网站上下订单、留言。用户可以通过后台随意设定软件语言,也就是说你可以用本软件开设简体中文、繁体中文与英文或者其他语言的网上商店。网奇Eshop系统全部版本都使用模

下载
git branch test1 创建一个名字为test1的分支。
git checkout test1 切换当前分支到test1
git checkout -b test1 创建一个叫做“test1”的分支,并切换过去。
git checkout master 切换回主分支。
git branch -d test1 把新建的分支删掉。
git push origin 将分支推送到远端仓库。
git merge test 合并分支。

更新与合并

使用命令git pull “远程分支名” 从远程获取代码并合并到本低的版本(在工作目录中获取(fetch)并合并(merge)远端的改动)
使用命令git merge “分支名” 把合并其他分支到当前分支。

前面的两种情况,git都会尝试去自动合并改动。但合并可能会出现冲突(conflicts),需要手动修改文件来合并这些冲突。改动后执行git add 将它们标记为合并成功。在合并改动之前,可以使用git diff 来观察是否存在差异。

替换本地改动

如果操作失误,可以使用命令git checkout – 替换掉本地改动。该命令会使用 HEAD中的最新内容替换掉工作目录中的文件(已添加到暂存区的改动以及新文件都不会受到影响)

远程仓库的移除和重命名

将test重命名为test1:git remote rename test test1
移除远程仓库test1: git remote rm test1

撤销操作

取消暂存的文件:git reset filename
撤销对文件的修改:git checkout –filename

历史纪录

使用git log可以得到本地仓库的历史记录。
使用命令git log --author=bob来只看某个人的提交记录。添加一些参数来修改输出,从而得到自己想要的结果。
查看哪些文件改变了: git log --name-status

推荐学习:《Git教程

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

325

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

232

2023.10.07

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

639

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

526

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

264

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

547

2024.04.09

git怎么对比两个版本的文件内容
git怎么对比两个版本的文件内容

要对比两个版本的 git 文件,请使用 git diff 命令:git diff 比较工作树和暂存区之间的差异。git diff 比较两个提交或标签之间的差异。git diff 输出显示差异块,其中 + 表示添加的行,- 表示删除的行, 表示修改的行。可使用 gitkraken、meld、beyond compare 等可视化工具更直观地查看差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2024.04.09

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

346

2023.06.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.7万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号