重新学习 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)

相关推荐
深海鱼在掘金4 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc5 天前
关于Git Flow
git
蜜獾云5 天前
在Git中配置用户名和密码
git
scx_link5 天前
通过git bash在本地创建分支,并推送到远程仓库中
开发语言·git·bash
南大白5 天前
IntelliJ IDEA 运行时的 JVM 本地内存溢出崩溃
git
码农小旋风5 天前
Claude Code 基础用法大全:对话、分析、修改、测试、Git 和工作流
人工智能·git·chatgpt·claude
南大白5 天前
Git 撤回提交完整方案
git
像风一样的男人@5 天前
python --实现代理服务器
git·ui
sbjdhjd5 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
码云数智-大飞5 天前
Go Channel 详解:并发通信的正确姿势
前端·数据库·git