版本控制工具

1. Git 基础

核心概念
  • 仓库(Repository):存储项目代码和历史记录的目录。
  • 提交(Commit):记录代码变更的快照,包含唯一哈希值、作者、时间和提交信息。
  • 分支(Branch) :独立开发线,默认分支通常为 mainmaster
  • 合并(Merge):将一个分支的变更整合到另一个分支。
  • 拉取/推送(Pull/Push):从远程仓库获取更新或将本地变更推送到远程。
常用命令
bash 复制代码
# 初始化仓库
git init

# 克隆远程仓库
git clone <仓库URL>

# 查看状态
git status

# 添加文件到暂存区
git add <文件名>  # 或 git add .

# 提交变更
git commit -m "提交信息"

# 查看提交历史
git log

# 创建分支
git branch <分支名>

# 切换分支
git checkout <分支名>  # 或 git switch <分支名>

# 合并分支
git merge <分支名>

# 拉取远程更新
git pull origin <分支名>

# 推送本地变更
git push origin <分支名>

2. GitHub/GitLab 的核心功能

共同点
  • 远程仓库托管:存储代码并支持多人协作。
  • Pull/Merge Request:提交代码变更请求,团队成员审核后合并。
  • Issue 跟踪:管理任务、Bug 报告和需求。
  • CI/CD 集成:自动化测试和部署(如 GitHub Actions、GitLab CI)。
平台差异
功能 GitHub GitLab
免费私有仓库 有限(现为免费) 一直免费支持
内置 CI/CD GitHub Actions GitLab CI/CD
社区生态 更庞大(开源项目首选) 企业级功能更丰富
部署灵活性 需第三方工具(如 Vercel) 内置 Kubernetes 集成

3. 典型工作流程示例

场景:修复 Bug 并提交
  1. 本地操作

    bash 复制代码
    git checkout -b fix-bug-123  # 创建并切换到新分支
    git add .                    # 修改代码后暂存
    git commit -m "修复Bug #123"
    git push origin fix-bug-123  # 推送到远程
  1. 平台操作
    • 在 GitHub/GitLab 创建 Pull/Merge Request
    • 团队成员评审代码,通过后合并到 main 分支。

4. 高级技巧

  • 撤销变更

    bash 复制代码
    git reset --soft HEAD~1  # 撤销提交但保留更改git checkout -- <文件>   # 丢弃文件修改
  • 交互式变基 (合并/重排提交):

    bash 复制代码
    git rebase -i HEAD~3
  • 子模块(Submodule) :嵌套管理其他 Git 仓库。

    bash 复制代码
    git submodule add <仓库URL>

5. 常见问题

  • 冲突解决 :合并时编辑冲突文件 → git addgit commit
  • 忽略文件 :创建 .gitignore 文件,列出需忽略的文件/目录(如 node_modules/)。
  • SSH 密钥配置:避免每次输入密码,生成密钥并添加到平台账户。
相关推荐
mazhafener1236 小时前
智慧照明:集中控制器、单双灯控制器与智慧灯杆网关的高效协同
大数据
打码人的日常分享6 小时前
物联网智慧医院建设方案(PPT)
大数据·物联网·架构·流程图·智慧城市·制造
Morpheon7 小时前
Cursor 1.0 版本 GitHub MCP 全面指南:从安装到工作流增强
ide·github·cursor·mcp
Lansonli8 小时前
大数据Spark(六十一):Spark基于Standalone提交任务流程
大数据·分布式·spark
Rverdoser9 小时前
电脑硬盘分几个区好
大数据
傻啦嘿哟9 小时前
Python 数据分析与可视化实战:从数据清洗到图表呈现
大数据·数据库·人工智能
Theodore_10229 小时前
大数据(2) 大数据处理架构Hadoop
大数据·服务器·hadoop·分布式·ubuntu·架构
LinXunFeng10 小时前
Flutter - GetX Helper 助你规范应用 tag
flutter·github·visual studio code
簌簌曌10 小时前
CentOS7 + JDK8 虚拟机安装与 Hadoop + Spark 集群搭建实践
大数据·hadoop·spark
Jooolin11 小时前
【编程史】Git是如何诞生的?这可并非计划之中...
linux·git·ai编程