阅读
- 第 1 部分:什么是 Git?
- 第 2 部分:Git 入门
- 第 3 部分:创建你的第一个 Git 仓库
- 第 4 部分:如何在 Git 中恢复旧版本文件
- 第 5 部分:3 个 Git 图形化工具
- 第 6 部分:如何构建你自己的 Git 服务器
- 第 7 部分:如何使用 Git 管理二进制大对象
在本文中,我们将介绍一些便捷的附加组件,以帮助你将 Git 舒适地集成到你的日常工作流程中。
我学习 Git 的时候,许多这些花哨的界面还不存在,而且我的工作流程通常是基于文本的,所以 Git 内置的便利功能对我来说已经足够好用了。在我看来,最好始终先了解 Git 的原生工作方式。然而,有选择总是好的,所以这里介绍一些在终端之外开始使用 Git 的方法。
KDE Dolphin 中的 Git
我是 KDE 用户,即使不总是在 Plasma 桌面环境中使用,也会在 Fluxbox 中将其作为我的应用程序层。Dolphin 是一款出色的文件管理器,具有许多选项和许多隐藏的小功能。特别有用的是人们为它开发的所有插件,其中一个插件是几乎完整的 Git 界面。是的,你可以从你自己的桌面舒适地原生管理你的 Git 仓库。
但首先,你需要确保已安装插件。有些发行版预装了功能齐全的 KDE,而另一些发行版只提供基本功能,因此如果你在接下来的步骤中没有看到 Git 选项,请在你的仓库中搜索类似 dolphin-extras 或 dolphin-plugins 的内容。
要激活 Git 集成,请转到任何 Dolphin 窗口中的 设置 菜单,然后选择 配置 Dolphin。
在 配置 Dolphin 窗口中,单击左侧列中的 服务 图标。
在 服务 面板中,滚动浏览可用插件列表,直到找到 Git。
保存你的更改并关闭 Dolphin 窗口。当你重新启动 Dolphin 时,导航到一个 Git 仓库并查看一下。请注意,所有图标现在都有标志:绿色框表示已提交的文件,实心绿色框表示已修改的文件,未跟踪的文件没有图标,等等。
你的右键单击菜单现在在 Git 仓库内调用时具有上下文相关的 Git 选项。你可以在 Dolphin 窗口中单击时启动检出、推送或拉取,甚至可以对你的文件执行 git add
或 git remove
。
你无法在 Dolphin 中克隆仓库或更改远程路径,但必须切换到终端,只需按 F4 即可。
坦率地说,KDE 的这个功能非常酷 [原文如此],这篇文章到此为止都可以了。Git 在你的原生文件管理器中的集成使 Git 的工作变得几乎透明;你需要做的一切自然而然地发生,无论你处于流程的哪个阶段。终端中的 Git,以及当你切换到 GUI 时等待着你的 Git。这简直是完美。
但是等等,还有更多!
Sparkleshare
来自桌面领域的另一边,是 SparkleShare,这是一个使用文件同步模型(“像 Dropbox!”)的项目,由一些 GNOME 开发人员启动。它没有集成到 GNOME 的任何特定部分,因此你可以在所有平台上使用它。
如果你运行 Linux,请从你的软件仓库安装 SparkleShare。其他操作系统应从 SparkleShare 网站下载。你可以安全地忽略 SparkleShare 网站上的说明,这些说明是关于设置 SparkleShare 服务器 的,而这不是我们在这里要做的。如果你愿意,你当然可以设置 SparkleShare 服务器,但 SparkleShare 与任何 Git 仓库兼容,因此你无需创建自己的服务器。
安装完成后,从你的应用程序菜单启动 SparkleShare。逐步完成设置向导,该向导包含两个步骤和一个简短的教程,并且可以选择将 SparkleShare 设置为桌面的启动项。
https://open-source.net.cn/sites/default/files/4_sparklesetup.jpg" title="Creating a SparkleShare account." typeof="foaf:Image" width="520" height="430">
一个橙色的 SparkleShare 目录现在位于你的系统托盘中。目前,SparkleShare 对你计算机上的任何内容都一无所知,因此你需要添加一个托管项目。
要添加一个目录供 SparkleShare 跟踪,请单击系统托盘中的 SparkleShare 图标,然后选择 添加托管项目。
https://open-source.net.cn/sites/default/files/4_sparklehost.jpg" title="New SparkleShare project." typeof="foaf:Image" width="530" height="380">
SparkleShare 可以与自托管的 Git 项目或托管在公共 Git 服务(如 GitHub 和 Bitbucket)上的项目一起使用。为了获得完全访问权限,你可能需要使用 SparkleShare 提供给你的客户端 ID。这是一个 SSH 密钥,充当你用于托管的服务的身份验证令牌,包括你自己的 Git 服务器,该服务器也应使用 SSH 公钥身份验证而不是密码登录。将客户端 ID 复制到你的服务器上 Git 用户的 authorized_hosts 文件中,或复制到你的 Git 主机的 SSH 密钥面板中。
配置好你要使用的主机后,SparkleShare 会下载 Git 项目,包括(如果选择)提交历史记录。在 ~/SparkleShare 中查找文件。
与 Dolphin 的 Git 集成不同,SparkleShare 非常隐形,令人不安。当你进行更改时,它会悄悄地将更改同步到你的远程项目。对许多人来说,这是一个巨大的好处:拥有 Git 的所有强大功能,而无需任何维护。对我来说,这令人不安,因为我喜欢控制我提交的内容以及我使用的分支。
SparkleShare 可能不适合所有人,但它是一个强大而简单的 Git 解决方案,展示了不同的开源项目如何完美和谐地结合在一起,创造出独特的东西。
Git-cola
另一种使用 Git 仓库的模型不太原生,更像是一种监控方法;与其使用集成应用程序直接与你的 Git 项目交互,不如使用桌面客户端来监控你项目中的更改,并以你选择的任何方式处理每个更改。这种方法的一个优点是专注。当你的项目中只有三个文件正在积极处理时,你可能不关心所有 125 个文件,因此将它们置于最前沿是有帮助的。
如果你认为已经有很多 Git Web 主机了,那你还没见过什么。适用于你桌面的 Git 客户端 多如牛毛。事实上,Git 实际上自带一个内置的图形化 Git 客户端。其中最跨平台和最可配置的是开源的 Git-cola 客户端,用 Python 和 Qt 编写。
如果你使用的是 Linux,Git-cola 可能在你的软件仓库中。否则,只需从站点下载并安装它
$ python setup.py install
当 Git-cola 启动时,你会看到三个按钮,用于打开现有仓库、创建新仓库或克隆现有仓库。
无论你选择哪个,最终你都会得到一个 Git 仓库。Git-cola,以及我使用过的大多数桌面客户端,都不会试图成为你进入仓库的界面;它们将此任务留给你的普通操作系统工具。换句话说,我可能会使用 Git-cola 启动一个仓库,但随后我会使用 Thunar 或 Emacs 打开该仓库以开始我的工作。将 Git-cola 打开作为监视器效果很好,因为当你创建新文件或更改现有文件时,它们会出现在 Git-cola 的 状态 面板中。
Git-cola 的默认布局有点非线性。我更喜欢从左到右移动,而且由于 Git-cola 非常可配置,因此你可以随意更改布局。我将我的布局设置为最左侧的面板是 状态,显示对当前分支所做的任何更改,然后在右侧是 Diff 面板,以防我想查看更改,以及用于快速访问常用任务的 操作 面板,最后最右侧的面板是 提交 面板,我可以在其中编写提交消息。
https://open-source.net.cn/sites/default/files/4_gitcola.jpg" title="Git-cola interface." typeof="foaf:Image" width="520" height="312">
即使你使用不同的布局,这也是 Git-cola 的一般流程
更改会出现在 状态 面板中。右键单击一个更改条目,或选择一个文件并单击 操作 面板中的 暂存 按钮,以暂存文件。
暂存文件的图标会变为绿色三角形,表示该文件已被修改并暂存。你可以通过右键单击并选择 取消暂存所选内容,或通过单击 操作 面板中的 取消暂存 按钮来取消暂存文件。
在 Diff 面板中查看你的更改。
当你准备好提交时,输入提交消息并单击 提交 按钮。
操作 面板中还有其他按钮,用于执行其他常见任务,例如 git pull
或 git push
。菜单完善了任务列表,其中包含用于分支、查看差异、变基以及更多操作的专用操作。
我倾向于将 Git-cola 视为文件管理器的浮动面板(并且我只在 Dolphin 不可用时才使用 Git-cola)。一方面,它不如完全集成且具有 Git 感知能力的文件管理器交互性强,但另一方面,它几乎提供了原始 Git 所做的一切,因此实际上更强大。
有很多图形化 Git 客户端。有些是付费软件,没有源代码可用,另一些仅是查看器,还有一些试图用客户端特有的特殊术语重新发明 Git(“同步”而不是“推送”……?),还有一些是特定于平台的。Git-Cola 一直是在任何平台上最易于使用的,也是最接近纯 Git 的一个,这样用户可以在使用它的同时学习 Git,专家也会对界面和术语感到舒适。
Git 还是图形化?
我通常不使用图形化工具来访问 Git;我主要使用我讨论过的这些工具来帮助其他人找到适合他们的舒适界面。但归根结底,这取决于什么适合你的工作方式。我喜欢基于终端的 Git,因为它与 Emacs 集成良好,但如果某天我主要在 Inkscape 中工作,我可能会自然而然地回到在 Dolphin 中使用 Git,因为我反正就在 Dolphin 中。
如何使用 Git 取决于你;最重要的是要记住,Git 旨在让你的生活更轻松,并让你那些疯狂的工作想法更安全地进行尝试。熟悉 Git 的工作方式,然后从你认为最适合你的角度使用 Git。
在我们的下一期中,我们将学习如何设置和管理 Git 服务器,包括用户访问和管理,以及运行自定义脚本。
17 条评论