重新学习 Git:从版本控制系统说起

准备重新学习一遍git,查漏补缺,一起学习进步。

1. 什么是版本控制系统(VCS)?

版本控制系统(Version Control System, VCS)是一种用于追踪文件变更、管理历史版本、支持多人协作开发的工具。它的核心价值在于解决三大痛点:

  • 文件修改混乱(改来改去不知道哪个是最新/最好的)
  • 历史记录丢失(删了重要内容却无法找回)
  • 多人协作冲突(同事覆盖了你的代码,你覆盖了他的设计)

简而言之,你可以把 VCS 想象成一个自动存档 + 时光机

举个例子:

你正在写一篇作文或者文章。如果没有 VCS,你可能会这样操作:

  • "作文-初稿.doc"
  • "作文-修改1.doc"
  • "作文-修改2-加结尾版.doc"
  • "作文-最终版-真的最终版.doc"

最后你面对一堆文件,根本分不清哪一版最好,还容易误删。

而有了版本控制系统,它会自动帮你:

  • 记录每一次修改的内容和时间
  • 标注是谁做了这次更改
  • 允许你一键回退到任意历史版本
  • 在多人协作时智能合并不同人的修改,避免互相覆盖

总结一句话 :VCS 让你安全地记录变化,方便回溯和协作

虽然程序员最常用它管理代码,但其实任何文件(文档、设计稿、论文、配置文件等)都可以用 VCS 管理。


2. 集中式 vs 分布式:两种 VCS 架构

版本控制系统主要分为两类:集中式 (Centralized) 和 分布式 (Distributed)。它们最大的区别在于:历史记录存在哪里?能不能在没网的时候工作?


集中式版本控制系统(CVCS)

代表工具:SVN(Subversion)

类比:图书馆借书

  • 所有书籍(代码 + 完整历史)都存放在中央服务器(图书馆)。
  • 你要看书,必须联网去"借"最新版本。
  • 看完要"还"回去,才能让别人看到你的修改。
  • 如果图书馆关门了(服务器宕机)或路上封路了(断网),你就既不能借书,也不能还书

特点:

  • ✅ 结构简单,权限管理集中
  • 严重依赖网络
  • 单点故障风险高(服务器一崩,全员停工)
  • ❌ 本地通常只有当前版本,看不到完整历史

就像班级群里共享一个在线文档------所有人围着同一个文件操作,稍不注意就覆盖别人的内容。


分布式版本控制系统(DVCS)

代表工具Git

当你参与一个 Git 项目时,你会通过 git clone 命令完整复制整个仓库到本地,包括:

  • 当前所有文件
  • 全部历史版本
  • 每次提交的作者、时间、修改内容

这意味着:

  • 无需网络也能工作:你可以在无网环境里反复提交、创建分支、对比版本。

    • 小故事:现在国内信号覆盖广,很少出现这种断网情况,没网的环境还工作嘛?确实有些保密企业不能联网,还记得刚毕业第一份工作,第一个月去客户拉单晶硅车间,就要上交手机,电脑断网,电气同事向日葵被ban,懂的都懂(゚∀゚)。
  • 完整备份:每个协作者的电脑都是一份完整备份,不怕服务器丢失数据

  • 灵活协作 :改好了再联网,用 git push把你的成果同步到远程仓库(如 GitHub、GitLab)

相关推荐
fakerth4 分钟前
Git 完全指南:从入门到精通
git
XiaoHu02071 小时前
Linux网络编程套接字
linux·服务器·网络·git
AlexDeng1 小时前
Git 实战:我用 git worktree 一次性拉取多个工作目录
git
import_random2 小时前
[git版本控制]git pull origin main
git
ShallowLin2 小时前
Git 的分支管理
git
chen_2276 小时前
搭建git工作流
git
Rabbit_QL9 小时前
【git reset】个人分支一次精准撤回 git push 的实战记录
git
掘金忠实用户程序员9 小时前
Git多仓库协作场景
git
少年攻城狮9 小时前
Git系列---【git拉代码时报getaddrinfo() thread failed to start】
git
cicada1510 小时前
分享一个git日常开发流程
大数据·git·elasticsearch