目录
- 核心概念
- 基本命令
- 工作流程
- Commit message
Git 是一个分布式版本控制系统,用于跟踪在软件开发过程中对文件的修改。它允许多个开发者协作处理项目,并且可以有效地管理代码的历史记录。以下是 Git 的一些核心概念和功能:
核心概念
-
仓库 (Repository)
- 一个 Git 仓库是一个存储项目所有文件的地方,包括所有历史记录。每个仓库都有一个工作目录,用于存放项目的实际文件。
-
提交 (Commit)
- 提交是 Git 中的一个快照,表示在特定时间点上的项目状态。每次提交都会包含一个描述变更的提交信息(commit message)。
-
分支 (Branch)
- 分支是开发中的独立线路。通过创建新的分支,开发者可以在不影响主分支的情况下进行实验或开发新功能。
-
合并 (Merge)
- 合并是指将一个分支的更改整合到另一个分支中。这是团队合作中常见的操作,用于将特性分支的更改集成到主分支。
-
暂存区 (Staging Area)
- 暂存区是 Git 中的一个特殊区域,用于准备下一次提交。你可以选择性地将文件添加到暂存区,然后再提交。
-
远程仓库 (Remote Repository)
- 远程仓库是指托管在网络上的 Git 仓库,允许多个开发者共享同一个项目。常见的远程仓库服务有 GitHub、GitLab 和 Bitbucket。
基本命令
git init
:初始化一个新的 Git 仓库。git clone <url>
:克隆一个远程仓库到本地。git add <file>
:将文件添加到暂存区。git commit -m "message"
:提交暂存区的更改到仓库。git branch
:列出所有本地分支。git checkout -b <branch>
:创建并切换到新分支。git merge <branch>
:将指定分支合并到当前分支。git push <remote> <branch>
:将本地分支的更改推送到远程仓库。git pull <remote> <branch>
:从远程仓库拉取最新的更改并合并到本地分支。
工作流程
- 克隆仓库:使用
git clone
命令从远程服务器克隆仓库到本地。 - 创建分支:基于当前的工作创建一个新分支来开发新功能或修复错误。
- 编辑文件:在新分支上进行开发,编辑项目文件。
- 暂存更改:使用
git add
将更改的文件添加到暂存区。 - 提交更改:使用
git commit
将暂存区的更改提交到本地仓库。 - 合并更改:当开发完成时,将新分支的更改合并回主分支(如
master
或main
)。 - 推送更改:使用
git push
将本地更改推送到远程仓库。
Commit message
每次提交,Commit message 都包括三个部分:Header,Body 和 Footer,例:fix(server-renderer): provide __filename to vm for webpack
。
<type>(<scope>): <subject>
// 空一行
<body>
// 空一行
<footer>
type | 说明 |
---|---|
feat | 新功能(feature) |
fix | 修补bug |
docs | 文档(documentation) |
style | 格式(不影响代码运行的变动) |
refactor | 重构(即不是新增功能,也不是修改bug的代码变动) |
test | 增加测试 |
chore | 构建过程或辅助工具的变动 |
参考:
https://www.ruanyifeng.com/blog/2016/01/commit_message_change_log.html
https://github.com/vuejs/vue