版本控制基础理论

一、本地版本控制

在本地记录文件每次的更新,可以对每个版本做一个快照,或是记录补丁文件,适合个人使用,如RCS.

二、集中式版本控制(代表SVN)

所有的版本数据都保存在服务器上,协同开发者从服务器上同步更新或者上传自己的修改。

所有的版本都存在服务器上,用户的本地只有自己以前所同步的版本。如果不联网的话,用户就看不到历史版本,也无法切换版本验证问题,或者在不同的分支上工作。而且所有的数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样就会丢失所有的数据,当然可以定期备份,代表产品WSVN,CVS,VSS.

三、分布式版本控制(代表Git)

每个人都拥有全部的代码!

所有的版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史,可以离线在本地提交,只需在联网时push到相应的服务器或其他用户那里。由于每个用户那里保存在都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这里增加了本地存储的占用。

不会因为服务器损坏造成不能工作的情况。

<font color=red size=>Git目前是世界上最先进的分布式版本管理系统。

四、Git的基本理论

Git本地有三个工作区域:工作目录(working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。

简单的解释一下相关名词:

Workspace:工作区,就是你平时存放项目代码的地方。

Index/Stage:暂存区,用于临时存放你的改动,事实上他只是一个文件,保存即将提交到文件列表信息

Repository:仓库区(本地仓库),就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中HEAD指向最新放入仓库的版本。

Remote:远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换。

五、Git的工作流程

Git的工作流程一般是这样的:

1、 在工作目录中添加修改文件;

2、将需要进行版本管理的文件放入暂存区域;

3、将暂存区域的文件提交到git本地仓库;

因此,git管理的文件一般有三种状态:已修改(modified)、已暂存(staged)、已提交(committed).

相关推荐
vibecoding日记21 小时前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记1 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger2 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP3 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思3 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat
杰哥技术分享3 天前
Git 仓库迁移技术文档:从 CODING.net 迁移至腾讯云 CNB
git
梅孔立3 天前
Ansible 100 台服务器一键管控实战 进阶版
服务器·git·ansible
qq_426003964 天前
git切换当前分支到远程分支
git
ON10N4 天前
100% 纯 Vibe Coding,我是怎么用 AI 撸出一个 VS Code 插件的
git·ai编程·visual studio code