Linux - 自定义你的 Terminal

31 Aug 2022  (Last Update on 15 Nov 2022)

linux

Terminal(终端)对于每一个开发者来说都是日常学习和工作中不可或缺的工具,我们需要通过各种 CLI 工具来完成各种任务。因此,配置一个强大、便捷和美观的 Terminal 将有助于提高我们的工作效率,更好地完成工作。在本篇博客中,我将介绍一些常见的 Emulator、Shell、Prompt、Tool,以及如何使用这些工具,配置一个属于你自己的 Terminal。

由于 Terminal 相关的 Emulator、Shell、Prompt、Tool 种类繁多,且作者目前写作时间有限,该博客将缓慢地逐渐完善。:cry:

若各位读者发现了本文中的错误,或对作者对于某些工具的评价持反对态度,请不吝赐教。

TL;DR §

如果你是 macOS 的忠实用户,那么我推荐你使用 iTerm2 作为你的 Emulator,使用 Zsh 作为你的默认 Shell,并通过 Oh My Zsh 来管理和自定义你的 Prompt 和 Tool,并安装 autojumpbatbottombrootcheatdustexafigfzfzellij 等 Tool 来提高你的工作效率。

Emulators §

“A terminal emulator, or terminal application, is a computer program that emulates a video terminal within some other display architecture.”

From Wikipedia

所谓终端模拟器(Terminal Emulator),就是一个可以让用户使用各种命令行命令或程序,同系统进行交互的接口(Interface)或应用(Application)。Windows 系统的 Cmd 和 PowerShell、以及 Linux 和 macOS 系统的 Terminal,就是典型的 Emulator。

在这一部分,我将介绍一些被开发者广为使用且颇受好评的 Emulator,对于我曾使用过的Emulator,我也会对其使用体验进行简要评价。对于各系统内置的 Emulator,相信大家都有亲身使用的体会,在此就不再赘述。

在之后的内容中,对于 Terminal 和 Emulator 的使用不做严格的区分,均代指各类终端模拟器应用程序。

此外,各 Emulator 的相关内容均摘自其仓库或主页。

Alacritty §

Homepage: Alacritty

GitHub Repo: alacritty/alacritty

Alacritty 是一款现代化的终端模拟器,在默认的基本设置外,提供了灵活的自定义配置选项。通过集成其他应用程序(而不是重新实现它们),Alacritty 提供了许多强大的功能。

基本信息:

  • 开发技术:Rust、OpenGL
  • 支持平台:BSD、Linux、macOS、Windows
  • 开源许可:Apache-2.0

功能亮点:

  • Vi模式:Vi模式允许用户像使用 Vi 一样,使用键盘在 Alacritty 的视口内进行导航和滚动,同时提供了对于文本选择、命令提示等其他类 Vi 功能的支持。

    个人感觉这一特性算是 Alacritty 的最大看点。但是为用户提供类似 Vi/Vim 的操作模拟,在很多软件或者插件中都有实现,算不上是一个很突出的特点。

  • 搜索:Alacritty 提供了在视口范围内进行搜索的功能。用户可以通过 Vi 的方式进行搜索,或者通过Ctrl+F的常规方式进行搜索。
  • 提示:用户可以同终端模拟器进行简单的文本交互以获取提示(无需进入 Vi 模式)。提示由正则表达式构成,可以用于出发外部应用,以及 Alacritty 的内置程序。
  • 选择扩展:用户可以对于已选择的文本内容进行扩充。
  • 打开链接:用户可以通过鼠标点击 Alacritty 视口中的 URL,打开浏览器访问相应内容。
  • 多窗口:用户可以在一个 Alacritty 中运行多个窗口。

使用体验:

在初次使用 Alacritty 时,我感觉就是一个升级版的、精练版的 macOS 内置 Terminal。经过短时间的使用,Alacritty 在外观和功能(大多数特性实在算不上亮眼)上并未给我留下很深的印象,相较其他 Emulator 来说乏善可陈。当然,由于我并没有对 Alacritty 进行深度定制,没有发挥出 Alacritty 的优势,这一评价可能会比较片面。

cmder §

Homepage: Cmder

GitHub Repo: cmderdev/cmder

cmder 是为了弥补 Windows 平台缺少可用的控制台模拟器而这一遗憾而被开发的软件。它是基于 ConEmu 改进而来,内置了 Monokai 颜色主题和 Clink,并提供了可以自定义的命令提示符布局。

基本信息:

  • 开发技术:C++、PowerShell
  • 支持平台:Windows

功能亮点:

与其说 cmder 是一个独立的 APP,倒不如说它是一个功能强大的软件包,提供了多种多样的功能支持。同时,它也是完全可移植的,用户可以通过可移动存储设备或云空间随时随地地存储和使用配置文件,用户再也无需使用 Windows 内置的丑陋的 CMD 界面了。此外,cmder 也提供了对于 Git 等其他 Unix 命令行工具的支持。

ConEmu §

Homepage: ConEmu

GitHub Repo: cmderdev/cmder

ConEmu 是一个带有选项卡的 Windows 控制台模拟器,它将多个控制台表示为一个具有各种特性的可定制 GUI 窗口。

基本信息:

  • 开发技术:C++
  • 支持平台:Windows

功能亮点:

作为一个较为古老(可能是针对于 Windows XP 以及 Windows 7 而开发的)的项目,在用户提供了基本的 Emulator 所需要的功能之外,ConEmu 本身并没有很多特别新奇和亮眼的特性。

cool-retro-term §

GitHub Repo:Swordfish90/cool-retro-term

cool-retro-term 是一种模拟在旧式 CRT 显示器上运行终端的 Emulator。是一种美观的、可定制的、轻量化的终端模拟器。

基本信息:

  • 开发技术:QML、Qt
  • 支持平台:Linux、macOS

功能亮点:

cool-retro-term 的主要亮点就是可以模拟终端模拟器运行在旧式 CRT 显示器上的效果,是一个很有创意的 Emulator。对于喜欢复古风的读者,可以一试。

Fluent Terminal §

GitHub Repo: felixse/FluentTerminal

Fluent Terminal 是一个基于 UWP 和 Web 技术的、面向 Windows 平台的终端模拟器。

基本信息:

  • 开发技术:C#、UWP
  • 支持平台:Windows
  • 开源许可:GPL-3.0

功能亮点:

  • 支持 PowerShell、CMD、WSL 以及多种自定义 Shell。
  • 内置的 SSH 和 Mosh 连接支持。
  • 支持多选项卡和多窗口。
  • 支持对于外观和主题的定制。
  • 支持对主题的导入和导出。
  • 支持导入 iTerm 主题。
  • 支持全屏模式。
  • 支持自定义按键绑定。
  • 支持搜索功能。
  • 可以通过配置 Shell 的配置文件快速地进行不同 Shell 的切换。
  • 提供 Explorer 的上下文菜单集成。
  • 提供 VSCode 插件。
  • 提供 i18n 支持。

Hyper §

Homepage: Hyper

GitHub Repo: vercel/hyper

Hyper 的目标是为命令行界面用户创建一个基于开源 Web 标准的、漂亮的、可扩展的终端模拟器。Hyper 关注于速度、稳定性以及为扩展作者开发正确的 API。

基本信息:

  • 开发技术:TypeScript
  • 支持平台:Linux、macOS、Windows
  • 开源许可:MIT

功能亮点:

由于 Hyper 是基于 Web 技术开发的,它为用户提供了灵活多样的插件、主题支持,用户可以直接通过命令行来安装、管理所需的插件和主题。

同时,Hyper 还为开发者提供了相应的 API 进行插件的开发和定制。

使用体验:

Hyper 是作者自第一次尝试便一直使用至今使用了很久的 Emulator,其依托于现代 Web 技术,提供了强大的自定义外观支持,且有着丰富的插件库,个人感觉属于是 Emulator 届的杀手级产品。对于 Hyper 的使用体验,是值得大书特书的。

TBD

iTerm2 §

Homepage: iTerm2

GitHub Repo: gnachman/iTerm2

iTerm2 是 Terminal 的替代品和 iTerm 的继承者。iTerm2 将终端带进了现代时代,具有你从来不知道的,却一直想要的功能。

基本信息:

  • 开发技术:Objective-C
  • 支持平台:macOS
  • 开源许可:GPL-2.0

功能亮点:

  • 窗口拆分:用户可以对窗口进行水平或者垂直的拆分,通过灵活的布局以运行不同的 Shell 会话。

    类似 tmux 的窗口复用。

  • 热键窗口:在运行其他应用时,用户可以通过热键立即将 iTerm2 拉起到前台。

    很实用的功能。

  • 搜索:iTerm2 提供了稳定的页内搜索功能(search-on-page)。同时支持正则表达式搜索。
  • 自动补全:根据 Shell 的输入输出历史,iTerm2 提供了对所有键入文本进行自动补全的功能。

    很有趣的功能,通常对于所有文本的自动补全只有一些 Plugin 才会提供。

  • 复制模式:用户可以对已选择的文本内容进行删减或扩充。
  • 粘贴历史:用户重新访问最近复制或粘贴的文本。用户甚至可以选择将黏贴历史保存到磁盘上,以防止其丢失。

    很实用的功能。

  • 即时回放:用户可以回退到之前的时间点,以获取已不在窗口中显示的文本。

    很实用的功能。

  • 可配置:iTerm2 为用户提供了大量的配置选项,以满足不同的需求。
  • Unixyness:iTerm2 为 Unix 用户提供了良好的无鼠标操作体验。
  • 24-bit 色彩:iTerm2 同时提供了 24-bit 和 8-bit 的颜色支持。
  • 可读性:iTerm2 通过智能色彩和最小化对比度的方式,增强了光标在复杂颜色环境下的辨识度。
  • 鼠标回报:用户可以通过鼠标来完成光标定位和文本高亮等功能。
  • 提示中心支持:用户可以通过 macOS 的提示中心,来获取 Shell 活动或作业的相关提示。

    很有趣的功能,通常对于提示中心的集成只有一些 Plugin 才会提供。

  • 全局搜索:用户可以在所有选项卡的范围内进行搜索。
  • 标签化配置文件:用户可以根据连接主机的不同,通过添加标签对 iTerm2 进行不同的配置。
  • i18n 支持:iTerm2 提供了包括 Unicode、全角字符和 Emoji 的支持。
  • 触发器:iTerm2 支持用户定义的触发器,这些触发器在接收到匹配相应正则表达式的文本时被执行。可以触发的功能包括高亮显示文本、自动响应、事件提示等。

    很有趣的功能。

  • 智能选择:iTerm2 可以通过识别光标下的内容来突出显示URL、电子邮件地址、文件名等。
  • Shell 集成:iTerm2 可以与 Shell 集成,以获取 Shell 提示符的位置、输入的命令、所在的主机以及当前目录等信息。
  • 自动配置文件切换:iTerm2 可以根据用户当前的工作和身份,对配置文件进行自动切换。
  • 行内图片:iTerm2 可以在行内显示图片,甚至是动态的 GIF 图片。
  • 时间戳:用户可以获取每条命令的最后修改时间,以获知相应作业的持续时间。
  • 密码管理器:iTerm2 通过集成 macOS 的 Keychain 应用,提供了内置的密码管理器。

    很实用的功能。

  • 高级粘贴:用户可以在粘贴文本之前,对其进行修改或转化到 base64 编码等。
  • 注释:用户可以选择一段文本,并对其添加注释

    很有趣的功能。

  • 标签:用户可以在窗口的右上角添加一个标签,用以显示当前会话的相关信息。
  • 输出捕获:iTerm2 可以根据用户定义的正则表达式,捕获 Shell 的相应输出。

    很实用的功能。

使用体验:

在使用了 iTerm2 之后,作者抛弃了之前使用了很久的 Hyper,因为 iTerm2 提供了太多 Hyper 所不具备的功能。

TBD

Tabby §

Homepage: Tabby

GitHub Repo: Eugeny/tabby

Tabby(前身是 Terminus)是一个高度可配置的终端模拟器,SSH 和串行客户端。

基本信息:

  • 开发技术:TypeScript
  • 支持平台:Linux、macOS、Windows
  • 开源许可:MIT

功能亮点:

  • 集成了 SSH 和 Telnet 客户端,以及相应的连接管理器。
  • 集成了串行终端。
  • 提供了多种主题和配色方案。
  • 提供了可配置的快捷键绑定。
  • 支持面板切分。
  • 提供了选项卡记忆功能。
  • 支持包括 PowerShell、WSL、Git-Bash、Cygwin、MSYS2、Cmder、以及 CMD 在内的多种 Shell。
  • 支持使用 Zmodem 在 SSH 会话中进行文件传递。
  • 支持包括双宽字在内的所有 Unicode 编码。
  • 具有良好的快速输出性能。
  • 通过 Clink 在 Windows 平台上提供了良好的 Shell 使用体验。
  • 集成了用于处理 SSH 密钥和凭据的加密容器。

使用体验:

类似 Hyper 和 iTerm2,Tabby 也是一个值得深度体验和发掘的 Emulator。

TBD

Warp §

Homepage: Warp

GitHub Repo: warpdotdev/Warp

Warp 是一款基于 GPU 加速的终端模拟器,凭借其快速的特性,可以提高你和你的团队的生产力。

基本信息:

  • 开发技术:Rust
  • 支持平台:目前仅 macOS,未来会陆续支持 Linux、Windows 和 Web
  • 开源许可:Warp目前是一款闭源软件,但是开发者已在考虑开源的可能性

功能亮点:

TBD

使用体验:

TBD

Wez’s Terminal §

Homepage: Wez’s Terminal

GitHub Repo: wez/wezterm

Wez’s Terminal 是一款跨平台的、GPU 加速的终端模拟器和复用器。

基本信息:

  • 开发技术:Rust
  • 支持平台:BSD、Linux、macOS、Windows
  • 开源许可:MIT

功能亮点:

  • 在本地或远程主机上,提供了支持原生鼠标和回滚操作的复用终端面板、选项卡和窗口。
  • 支持连字、彩色表情符号和备用字体,具有真彩色和动态配色方案。
  • 支持超链接。
  • 提供了可搜索的回滚操作支持。
  • 支持使用鼠标和键盘进行选择和黏贴。
  • 在 vim 和 tmux 中提供了 SGR 风格的鼠标回报。
  • 支持包括下划线、双下划线、斜体、粗体、删除线在内的多种字体渲染。
  • 支持通过配置文件进行配置和热加载。
  • 支持面板切分。
  • 支持串行终端。

Windows Terminal §

GitHub Repo: microsoft/terminal

Windows Terminal 是一款广为赞誉的、面向 Windows 平台的终端模拟器,它在很大程度上解决了 Windows 长期以来因为命令行体验不佳而被诟病的问题。可以说是 Windows 平台最受欢迎的现代化终端模拟器。

基本信息:

  • 开发技术:C++
  • 支持平台:Windows
  • 开源许可:MIT

功能亮点:

TBD

使用体验:

作为 Windows 平台首屈一指的 Emulator,很难有其他的产品能同 Windows Terminal 相提并论,将其称之为对其他产品的降维打击也不为过。

Other §

在整理 Emulator 相关资料时,发现了很多其他曾经非常受欢迎,但是已经因为各种原因而停止更新的 Emulator,这里也做一个简单的整理,供给感兴趣的读者以参考。

  • eDEX-UI:这是一个跨平台(Linux、macOS、Windows),面向全屏场景、且支持触屏的终端模拟器。它的设计收到了科幻电影的启发,具有很强的未来感。该项目于2021年10月停止更新。
  • upterm:Upterm(前身为 Black Screen)是终端世界中的一个 IDE。严格来说,它既是一个终端仿真器,又是一个基于 Electron 的交互式 Shell。被作者称为21世纪的终端模拟器。但是由于缺乏维护者和社区贡献,该项目于2019年5月停止更新。

Shells §

TBD

Prompts §

TBD

Tools §

TBD

样例 §

在该章节,我将基于不同的使用场景和工具集,简要描述两个我自己配置 Terminal 的例子。

为个人电脑配置Terminal §

TBD

为服务器配置Terminal §

TBD

常见问题 §

启动Terminal时未执行~/.bashrc中包含的内容 §

问题描述

我在为服务器配置 Terminal 时遇到了这个问题。问题的具体表现是在我已经向~/.bashrc添加了所需的内容的情况下(例如环境变量、别名和工具的相关配置),退出 SSH 并重新登录后,添加的内容并未生效,仍需要手动source .bashrc才可以生效。

问题原因

这个问题是由于我并未配置~/.bash_profile文件,而bash在通过不同方式启动会话时(login 或者 non-login),会执行不同的配置文件,这就导致在通过 SSH 登陆时(通常情况下这是个 login 会话),这就导致bash在启动时,默认执行~/.bash_profile~/.bash_login~/.profile等配置文件,而并未执行~/.bashrc

问题解决

创建~/.bash_profile(或者~/.bash_login~/.profile),向其中添加以下内容:

if [ -f "$HOME/.bashrc" ]; then
    . "$HOME/.bashrc"
fi

这会使得在bash启动时,通过执行~/.bash_profile,进而执行~/.bashrc

参考 §