3 个 Git 图形化工具

7 位读者喜欢这篇文章。
Media ladder

Opensource.com

阅读

在本文中,我们将了解一些便捷的附加组件,以帮助您将 Git 舒适地集成到您的日常工作流程中。

我学习 Git 的时候,许多这些花哨的界面还不存在,而且我的工作流程通常也是基于文本的,所以 Git 的大多数内置便利性对我来说都非常合适。在我看来,始终最好先了解 Git 的原生工作方式。但是,有选择总是好的,所以这里有一些在终端之外开始使用 Git 的方法。

KDE Dolphin 中的 Git

我是一名 KDE 用户,即使不总是在 Plasma 桌面环境中使用,也会在 Fluxbox 中使用 KDE 作为我的应用层。Dolphin 是一款出色的文件管理器,具有许多选项和大量不为人知的小功能。特别有用的是人们为其开发的所有插件,其中一个插件几乎是一个完整的 Git 界面。是的,您可以从舒适的桌面环境中原生管理您的 Git 仓库。

但首先,您需要确保已安装这些附加组件。某些发行版预装了功能齐全的 KDE,而另一些发行版只提供基本功能,因此如果您在接下来的几个步骤中没有看到 Git 选项,请在您的仓库中搜索类似 dolphin-extrasdolphin-plugins 的内容。

要激活 Git 集成,请转到任何 Dolphin 窗口中的 设置 菜单,然后选择 配置 Dolphin

配置 Dolphin 窗口中,单击左侧列中的 服务 图标。

服务 面板中,滚动浏览可用插件列表,直到找到 Git

Dolphin plugins.

保存您的更改并关闭 Dolphin 窗口。当您重新启动 Dolphin 时,导航到 Git 仓库并环顾四周。请注意,现在所有图标都有了标志:绿色框表示已提交的文件,实心绿色框表示已修改的文件,没有图标表示未跟踪的文件,依此类推。

当在 Git 仓库内调用时,您的右键单击菜单现在具有上下文相关的 Git 选项。您可以在 Dolphin 窗口内单击时启动检出、推送或拉取,甚至可以对文件执行 git addgit remove 操作。

Git commands in Dolphin.

您无法在 Dolphin 中克隆仓库或更改远程路径,但您需要切换到终端,只需按 F4 即可。

坦率地说,KDE 的这个功能非常酷 [原文如此],以至于这篇文章可以到此结束。Git 与您的原生文件管理器集成使 Git 的工作几乎是透明的;无论您处于流程的哪个阶段,您需要做的每件事都自动发生。终端中的 Git,以及当您切换到 GUI 时等待您的 Git。这真是完美。

但是等等,还有更多!

Sparkleshare

来自桌面领域的另一边是 SparkleShare,这是一个使用文件同步模型(“就像 Dropbox!”)的项目,由一些 GNOME 开发人员启动。它没有集成到 GNOME 的任何特定部分,因此您可以在所有平台上使用它。

如果您运行的是 Linux,请从您的软件仓库安装 SparkleShare。其他操作系统应从 SparkleShare 网站下载。您可以安全地忽略 SparkleShare 网站上的说明,这些说明是关于设置 SparkleShare 服务器 的,这不是我们在这里要做的。如果您愿意,您当然可以设置 SparkleShare 服务器,但 SparkleShare 与任何 Git 仓库兼容,因此您无需创建自己的服务器。

安装完成后,从您的应用程序菜单启动 SparkleShare。逐步完成设置向导,它包括两个步骤和一个简短的教程,并可选择将 SparkleShare 设置为桌面的启动项。

创建 SparkleShare 账户。https://open-source.net.cn/sites/default/files/4_sparklesetup.jpg" title="创建 SparkleShare 账户。" typeof="foaf:Image" width="520" height="430">

橙色的 SparkleShare 目录现在位于您的系统托盘中。目前,SparkleShare 对您计算机上的任何内容都一无所知,因此您需要添加一个托管项目。

要添加 SparkleShare 要跟踪的目录,请单击系统托盘中的 SparkleShare 图标,然后选择 添加托管项目

新的 SparkleShare 项目。https://open-source.net.cn/sites/default/files/4_sparklehost.jpg" title="新的 SparkleShare 项目。" 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 恰好非常可配置,因此您可以随意更改布局。我将我的布局设置为最左侧的面板是 状态,显示对当前分支所做的任何更改,然后在右侧,是 差异 面板,以防我想查看更改,以及 操作 面板,用于快速访问常用任务的按钮,最后最右侧的面板是 提交 面板,我可以在其中编写提交消息。

Git-cola 界面。https://open-source.net.cn/sites/default/files/4_gitcola.jpg" title="Git-cola 界面。" typeof="foaf:Image" width="520" height="312">

即使您使用不同的布局,这也是 Git-cola 的一般流程

更改出现在 状态 面板中。右键单击更改条目,或选择一个文件并单击 操作 面板中的 暂存 按钮,以暂存文件。

暂存文件的图标变为绿色三角形,表示该文件已被修改和暂存。您可以通过右键单击并选择 取消暂存所选,或单击 操作 面板中的 取消暂存 按钮来取消暂存文件。

差异 面板中查看您的更改。

当您准备好提交时,输入提交消息并单击 提交 按钮。

操作 面板中还有其他按钮,用于其他常见任务,如 git pullgit 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 服务器,包括用户访问和管理,以及运行自定义脚本。

标签
Seth Kenlon
Seth Kenlon 是一位 UNIX 极客、自由文化倡导者、独立多媒体艺术家和 D&D 爱好者。他曾在电影和计算机行业工作,通常同时从事这两个行业。

17 条评论

我在如何使用 Git(以及一般的版本控制)方面倾向于折衷。我喜欢从命令行执行所有版本控制操作……但是,图形环境往往提供最简单(也最有吸引力)的方式来导航项目的历史记录(或该项目中的文件)。例如,在使用 Mercurial 时,我已经非常习惯使用 TortoiseHg 的 Workbench 来实现此目的。不幸的是,我还没有找到相应的 Git 图形化工具……虽然 Git-cola 看起来很有希望。

您提出了一个很好的观点。在 GUI 中查看项目的历史记录更美观,尤其是在我们谈论图形时。而且,正如我想我在文章中提到的那样,我实际上确实发现自己积极使用 GUI 前端的一次是在我处理图形文件时。也许不是巧合。

回复 ,作者:Jason van Gumster

适用于 MacOS 的 Github 桌面客户端非常不错。它的功能有限,但涵盖了最常见的内容,并且它所做的事情都做得非常好。我仍然偶尔会回到命令行(最常见的是执行 squash merge),但我使用 UI 完成大多数 Git 任务。

我见过它,并没有刻意介绍它,不仅因为我没有 Mac,还因为我发现(在这里并没有*太*夸张)他们对常见任务使用不同的术语是不可原谅的,就好像是为了训练用户不理解 Git 一样;例如,在推送时,您单击“同步”按钮。我知道这对于新用户来说表面上比“推送”更熟悉,但是如果我每次都必须将我的问题从“您推送了您的更改吗?”修改为针对 Github 桌面用户的“您同步了您的更改吗?”,我就会得到一美元……UI 中还有一些其他东西背叛了纯 Git,但这是我想到的一个。但除此之外,是的,对于那些被困在封闭源平台上的用户来说,这是一个不错的 GUI。

回复 ,作者:faseidl

还有 gitg

https://wiki.gnome.org/Apps/Gitg

它与 git-cola 类似,但我发现界面更简洁,更易于使用。浏览历史记录很容易,树结构的表示也非常有用。

有一些不错的 Git UI,而且我认为(如果我没记错的话)我最终介绍了 git-cola,因为以我的经验来看,它真的很容易在任何平台上启动和运行,因为它只是 Python、PyQt 和 Git 的简单组合。不确定在其他平台上启动 gitg 需要什么,但它确实很不错。我在一家我做咨询的公司里看到一些人在使用它。

回复 ,作者:anonymous (未验证)

我唯一使用过的 GUI Git 工具是(闭源的)SmartGit 和 GitHub 的桌面应用程序。两者都很有用,但对于像我这样的非技术人员来说,使用命令行还是有一些好处的。话虽如此,我想我会看看 Git-cola。

是的,看到有这么多 Git UI 真令人难以置信。开源的、闭源的、查看器、插件。这就是我所说的“健康”的生态系统。

回复 ,作者:ScottNesbitt

很棒的文章,Seth!我已经使用 KDE 近十年了,直到现在我才知道 Dolphin 支持 Git。我倾向于从 CLI 进行大部分 Git 操作,因为我经常远程登录,但我肯定会使用它。

我主要通过命令行使用 Git。但是当查找更改历史记录时,我更喜欢 GUI,我使用 gitk。我可以在终端中发出 gitk 命令以在 GUI 窗口中浏览历史记录。

Gitk 是一个不错的小查看器。我没有在本文中介绍它,因为它*只是*一个查看器,但拥有它很好……这很方便,因为它包含在标准的 Git 安装中。是的,我同意:gitk 的编写方式使其功能可以通过其 GUI 或 Unix shell 获得,这非常好。

回复 ,作者:Junaid (未验证)

虽然不是开源的,但有一个工具 GitKraken 看起来很有希望。

嗯,如果说有什么的话,它的名字很聪明!鉴于 Git 客户端基本上不生成任何数据(Git 会生成数据,客户端只是连接到它),我“愿意”使用非开源 Git 客户端……但由于有这么多优秀的开源客户端(上面文章中提到了 3 个),我觉得没有理由关注闭源客户端。我没有用过 GitKraken,但我确实很欣赏它是完全跨平台的(不像 Github 桌面客户端那样)。

回复 ,作者:Ash Bike (未验证)

我纯粹从终端使用 Git,但评论部分的人提到 GUI 可以处理历史记录或版本控制。老实说,我从来没有做过超出 Github 的提交部分的版本控制。我想我不是一个真正的开发人员……开个玩笑,这很有趣。

有一些工具可以在 shell 中使用 Git 查看历史记录。我想我从来没有真正考虑过“正确”的方法来做这件事(我应该参考 https://git-scm.cn/book/en/v2 并查找它),但我通常使用 `git log --oneline | less` 和 `git blame`。这显示了提交历史记录,如果您对单个文件进行“取证”,这通常过于宽泛,但 Git 允许使用双破折号语法获得更好的粒度,例如 `git log -- path/to/file` 和一些其他技巧。我不太担心分叉和分支之类的事情,因为在工作中,我们将所有提交变基到公共主干,因此分支和偏差或多或少都包含在每个合并的分支中。我想我想说的是,我也不是真的使用 GUI 工具进行版本控制取证,但我确实打算尝试一下。

回复 ,作者:RaveYoda

Creative Commons License本作品根据知识共享署名-相同方式共享 4.0 国际许可协议获得许可。
© . All rights reserved.