155 lines
12 KiB
Markdown
Raw Normal View History

# 10.4. Git
Git 是一个分布式版本控制系统它的目标是速度数据完整性和可扩展性。Git 是免费软件,遵循 GNU 通用公共许可证版本 2或更高版本发布
下面是一些和Git相关的软件包
| 软件包 | 命令 | 说明 |
|------------------|---------------------|-----------------------|
| git | git(7) | Git 快速、可扩展、分布式的版本控制系统 |
| gitk | gitk(1) | 有历史功能的 Git 图形仓库浏览器 |
| git-gui | git-gui(1) | Git 图形界面(无历史功能) |
| git-email | git-send-email(1) | 从 Git 用电子邮件发送收集到的补丁 |
| git-buildpackage | git-buildpackage(1) | 用 Git 自动制作 Debian 包 |
| dgit | dgit(1) | Debian 档案库的 git 交互操作 |
| imediff | git-ime(1) | 交互式的分开 git 提交的辅助工具 |
| stgit | stg(1) | 封装的 git (Python) |
| git-doc | N/A | Git 官方文档 |
| gitmagic | N/A | "Git 魔术",易于理解的 Git 手册 |
## 10.4.1. 配置 Git 客户端
你可以在 "`~/.gitconfig`" 里面设置几个Git接下来需要使用的全局配置比如说你的名字和电子邮件地址。
```Shell
git config --global user.name "Name Surname"
git config --global user.email yourname@example.com
```
你也可以按如下所示定制 Git 的默认行为。
```Shell
git config --global init.defaultBranch main
git config --global pull.rebase true
git config --global push.default current
```
如果你习惯使用 CVS 或 Subversion 命令,你也许希望设置如下几个命令别名。
```Shell
git config --global alias.ci "commit -a"
git config --global alias.co checkout
```
你能够通过如下方式检查你的全局配置:
```Shell
git config --global --list
```
当然你也可以为每个项目单独设置配置,这样的话,你就可以在不同的项目中使用不同的用户名和电子邮件地址了,只需要在项目的根目录下运行上面的命令(去掉--global即可。
## 10.4.2. 基本的 Git 命令
Git 操作涉及几个数据。
- 工作树目录保持面向用户的文件,你可以对它们做出改变。
- 需要被记录的改变,必须明确的被选择并暂存到索引。这是 git add 和 git rm 命令。
- 索引保持暂存文件。
- 在接下来的请求之前,暂存文件将被提交到本地仓库。这个是 git commit 命令。
- 本地仓库保持已经提交的的文件。
- Git 记录提交数据的链接历史并在仓库里面将它们作为分支组织。
- 本地仓库通过 git push 命令发送数据到远程仓库。
- 本地仓库能够通过 git fetch 和 git pull 命令从远程仓库接收数据。
- git pull 命令在 git fetch 后执行 git merge 或 git rebase 命令。
- 这里git merge 联合两个独立分支的历史结尾到一个点。(在没有定制的 git pull ,这个是默认的,同时对上游作者发布分支到许多人时,也是好的
- 这里git rebase 创建一个远程分支的序列历史的单个分支,跟着本地分支。(这是定制 pull.rebase true 的情况,对我们其余的用途有用。)
- 远程仓库保持已经提交的文件。
- 到远程仓库的通信,使用安全的通信协议,比如 SSH 或 HTTPS。
工作树是在 .git/ 目录之外的文件。在 .git/ 目录里面的文件,包括索引、本地仓库数据和一些 git 配置的文本文件。
这里是主要的 Git 命令概览。
| Git 命令 | 功能 |
|--------------------------------|----------------------------------------|
| git init | 创建(本地)存储库 |
| git clone URL | 克隆远程存储库到本地仓库工作目录树 |
| git pull origin main | 通过远程仓库 origin 更新本地 main 分支 |
| git add . | 增加工作树里面的文件仅作为预先存在的索引文件 |
| git add -A . | 增加工作树里面的所有文件到索引(包括已经删除的) |
| git rm filename | 从工作树和索引中删除文件 |
| git commit | 提交在索引中的暂存改变到本地存储库 |
| git commit -a | 添加工作树里的所有的改变到索引并提交它们到本地仓库(添加 + 提交) |
| git push -u origin branch_name | 使用本地 branch_name 分支更新远程仓库 origin初始启用 |
| git push origin branch_name | 使用本地 branch_name 分支更新远程仓库 origin随后调用 |
| git diff treeish1 treeish2 | 显示 treeish1 提交和 treeish2 提交的不同 |
| gitk | VCS 存储库分支历史树的图形界面显示 |
## 10.4.3. Git技巧
| Git 命令行 | 功能 |
|----------------------------------------------------------------------------|-------------------------------------------------------|
| gitk --all | 参看完整的 Git 历史和操作,比如重置 HEAD 到另外一个提交、挑选补丁、创建标签和分支…… |
| git stash | 得到一个干净的工作树,不会丢失数据 |
| git remote -v | 检查远程设置 |
| git branch -vv | 检查分支设置 |
| git status | 显示工作树状态 |
| git config -l | 列出 git 设置 |
| git reset --hard HEAD; git clean -x -d -f | 反转所有工作树的改变并完全清理它们 |
| git rm --cached filename | 反转由 git add filename 改变的暂存索引 |
| git reflog | 获取参考日志(对从删除的分支中恢复提交有用) |
| git branch new_branch_name HEAD@{6} | 从 reflog 信息创建一个新的分支 |
| git remote add new_remote URL | 增加一个由 URL 指向的远程仓库 new_remote |
| git remote remove origin | 移除远程仓库origin |
| git remote rename origin upstream | 远程仓库的名字从 origin 重命名到 upstream |
| git branch -u upstream/branch_name | 设置远程跟踪到远程仓库 upstream 和它的分支名 branch_name。 |
| git remote set-url origin https://foo/bar.git | 改变 origin 的 URL |
| git remote set-url --push upstream DISABLED | 禁止推送到 upstream编辑 .git/config 来重新启用) |
| git checkout -b topic_branch ; git push -u topic_branch origin | 制作一个新的 topic_branch 并把它推送到 origin |
| git branch -m oldname newname | 本地分支改名 |
| git push -d origin branch_to_be_removed | 删除远程分支(新的方式) |
| git push origin :branch_to_be_removed | 删除远程分支(老的方式) |
| git checkout --orphan unconnected | 创建一个新的 unconnected 分支 |
| git fetch upstream foo:upstream-foo | 创建本地可能是孤立的upstream-foo 分支作为upstream 仓库 foo 分支的一个拷贝 |
| git rebase -i origin/main | 从 origin/main 重新排序、删除、压缩提交到一个干净的分支历史 |
| git reset HEAD^; git commit --amend | 压缩最后两个提交为一个 |
| git checkout topic_branch ; git merge --squash topic_branch | 压缩整个 topic_branch 到一个提交 |
| git fetch --unshallow --update-head-ok origin '+refs/heads/*:refs/heads/*' | 反转一个浅克隆到一个所有分支的完整克隆 |
| git ime | 分开最后的提交到一系列单个逐一文件的小提交。(要求 imediff |
| git repack -a -d; git prune | 本地仓库重新打包到一个单独的包中(这可能限制从删除分支里面恢复丢失数据等机会) |
::: danger 警告
⚠️ 不要使用带空格的标签字符串。即使一些工具,如 gitk(1) 允许你使用它,但会阻碍其它 git 命令。
:::
::: warning 注意
如果一个本地分支推送到一个已经变基或者压缩过的仓库,推送这样的分支有风险,并要求 --force 选项。这通常对 main 分支来说不可接受,但对于一个移植到 main 分支前的特定分支,是可以接受的。
:::
::: tip
如果有一个可执行文件 git-foo 在路径环境变量 $PATH 里面,在命令行输入没有中划线的 "git foo",则将调用 git-foo.这是 git 命令的一个特性。
:::
## 10.4.4. Git参考资料
[Git - 简明指南](https://rogerdudler.github.io/git-guide/index.zh.html) 「推荐」
[Git - 官方文档](https://git-scm.com/doc)
[Git - 官方手册](https://git-scm.com/docs)
[廖雪峰老师博客](https://www.liaoxuefeng.com/wiki/896043488029600) 「推荐」
## 10.4.5. GitHub
[GitHub - 官方网站](github.com)
GitHub是一个面向开发者的基于Web的Git版本控制仓库托管服务。它提供了分布式版本控制和源代码管理SCM功能使开发者能够在全球范围内共同协作编写代码和协同开发项目。
在GitHub上开发者可以创建存储库repository来存储其代码和其他项目文件并与其他开发者共享和协作。GitHub还提供了一系列工具和功能包括问题跟踪、代码审核、项目管理、团队协作、持续集成和部署等以帮助开发者更有效地开发和管理项目。
GitHub还是一个开源社区许多项目都是开放源代码的。这使得开发者可以访问和使用其他人的代码了解其他人的代码实践并在这些项目上进行贡献和协作。由于其广泛的社区和丰富的功能GitHub已成为开发者社区的重要组成部分并被广泛用于开源和商业项目的协作和管理。
deepin的开发者们也在GitHub上开发和维护着deepin的各个项目欢迎大家加入我们的开发者社区。
[github上的linuxdeepin](https://www.github.com/linuxdeepin)