
Pro Git
Scott Chacon
*
2010-03-25
*
This is the PDF file for the Pro Git book contents. It is licensed under the Creative Commons Attribution-
Non Commercial-Share Alike 3.0 license. I hope you enjoy it, I hope it helps you learn Git, and I hope you’ll
support Apress and me by purchasing a print copy of the book at Amazon: http://tinyurl.com/amazonprogit


目录
1 起步 1
1.1 关于版本控制 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1.1 本地版本控制系统 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1.2 集中化的版本控制系统 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1.3 分布式版本控制系统 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.2 Git 的历史 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.3 Git 基础要点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.3.1 直接快照,而非比较差异 . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.3.2 近乎所有操作都可本地执行 . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.3.3 时刻保持数据完整性 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.3.4 多数操作仅添加数据 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.3.5 三种状态 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.4 安装 Git . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.4.1 从源代码安装 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.4.2 在 Linux 上安装 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.4.3 在 Mac 上安装 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.4.4 在 Windows 上安装 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.5 初次运行 Git 前的配置 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.5.1 用户信息 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.5.2 文本编辑器 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.5.3 差异分析工具 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.5.4 查看配置信息 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.6 获取帮助 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.7 小结 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
2 Git 基础 11
2.1 取得项目的 Git 仓库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.1.1 从当前目录初始化 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.1.2 从现有仓库克隆 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.2 记录每次更新到仓库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.2.1 检查当前文件状态 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.2.2 跟踪新文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.2.3 暂存已修改文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
2.2.4 忽略某些文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.2.5 查看已暂存和未暂存的更新 . . . . . . . . . . . . . . . . . . . . . . . . . . 16
2.2.6 提交更新 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
iii

2.2.7 跳过使用暂存区域 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.2.8 移除文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.2.9 移动文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.3 查看提交历史 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.3.1 限制输出长度 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
2.3.2 使用图形化工具查阅提交历史 . . . . . . . . . . . . . . . . . . . . . . . . . 25
2.4 撤消操作 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
2.4.1 修改最后一次提交 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
2.4.2 取消已经暂存的文件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
2.4.3 取消对文件的修改 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
2.5 远程仓库的使用 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
2.5.1 查看当前的远程库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
2.5.2 添加远程仓库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
2.5.3 从远程仓库抓取数据 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
2.5.4 推送数据到远程仓库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
2.5.5 查看远程仓库信息 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
2.5.6 远程仓库的删除和重命名 . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
2.6 打标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
2.6.1 列显已有的标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
2.6.2 新建标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
2.6.3 含附注的标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
2.6.4 签署标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
2.6.5 轻量级标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
2.6.6 验证标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
2.6.7 后期加注标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
2.6.8 分享标签 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
2.7 技巧和窍门 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
2.7.1 自动完成 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
2.7.2 Git 命令别名 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
2.8 小结 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
3 Git 分支 39
3.1 何谓分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.2 基本的分支与合并 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
3.2.1 基本分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
3.2.2 基本合并 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
3.2.3 冲突的合并 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
3.3 分支管理 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
3.4 分支式工作流程 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
3.4.1 长期分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
3.4.2 特性分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
3.5 远程分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
3.5.1 推送 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
3.5.2 跟踪分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
3.5.3 删除远程分支 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
3.6 衍合 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
iv

3.6.1 衍合基础 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
3.6.2 更多有趣的衍合 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
3.6.3 衍合的风险 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
3.7 小结 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
4 服务器上的 Git 63
4.1 协议 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
4.1.1 本地协议 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
优点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
缺点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
4.1.2 SSH 协议 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
优点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
缺点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
4.1.3 Git 协议 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
优点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
缺点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
4.1.4 HTTP/S 协议 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
优点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
缺点 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
4.2 在服务器部署 Git . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
4.2.1 将纯目录转移到服务器 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
4.2.2 小型安装 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
SSH 连接 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
4.3 生成 SSH 公钥 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
4.4 架设服务器 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
4.5 公共访问 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
4.6 网页界面 GitWeb . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
4.7 权限管理器 Gitosis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
4.8 Git 进程 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
4.9 Git 托管服务 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
4.9.1 GitHub . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
4.9.2 建立账户 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
4.9.3 建立新仓库 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
4.9.4 从 Subversion 中导入项目 . . . . . . . . . . . . . . . . . . . . . . . . . . 81
4.9.5 开始合作 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
4.9.6 项目页面 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
4.9.7 派生(forking)项目 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
4.9.8 GitHub 小节 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
4.10 小节 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
5 分布式 Git 87
5.1 分布式工作流程 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
5.1.1 集中式工作流 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
5.1.2 集成管理员工作流 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
5.1.3 司令官与副官工作流 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
5.2 为项目作贡献 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
v