简明开发环境配置指南

作为开发者,我们每天都会使用各种机器。一个配置良好的开发环境可以显著提高生产力,让编码变得更加愉快。本指南将指导您配置一个舒适且高效的工作空间。此文主要面向初学者,但经验丰富的开发者也可能受到启发。

为什么开发环境配置很重要

过去,我的终端未经配置,是一个无聊的黑框框,它不能激发我的任何兴趣。但经过配置后,我现在使用的终端是彩色的,并且功能丰富 —— 只需键入几个字母,曾经输入过的命令就会弹出;命令的各部分都会以不同颜色高亮,我可以从颜色上轻松判断一个程序是否存在或一个文件是否可以执行...这是一个简单的例子。相信我,一个好的开发环境真的能 make your life easier!

我的终端

终端配置只是开发环境配置的一小部分。往大了说,各种各样的配置可能会很复杂,但本指南试图为初学者提供一个路线图。需要注意的是,这份指南不是一个逐步教程,这意味着我不会展示如何下载和安装各个应用程序。您可能需要自行参考本文中提到的各种软件的官方网站以了解如何安装和使用它们。

本文的灵感来源于:

网络配置:永远的第一步

在深入开发环境设置之前,确保您的网络正常工作。您需要一个稳定的(国际)互联网连接来下载各种工具和软件包。(是的,“国际” 互联网,我们有太多国外软件要使用了!)

您可能需要一个代理,来帮助您进行 “中继” 以获得更好的网络连接。

当您打开代理软件并开启其中的 “系统代理” 选项时,浏览器会读取这些配置并自动地应用它,这样您的网络流量就会通过代理服务器中转。但是,对于我们的终端工具,这并不适用 —— 它们一般不会自动读取系统代理设置,相反,它们一般会读取一些代理相关的环境变量。所以,为了在终端环境中使用代理,您需要设置这些环境变量。

一般而言,您可以在您的代理软件中找到 “复制环境变量” 之类的按钮来复制上述设置环境变量的命令。如果您的代理软件运行于 127.0.0.1:7890,其设置环境变量的命令可能是这样的:

export https_proxy=http://127.0.0.1:7890 http_proxy=http://127.0.0.1:7890 all_proxy=socks5://127.0.0.1:7890

Tip

如果您使用的是 WSL,您需要进行一些配置使其能够访问您在 Windows 上的代理。请编辑您的用户目录下的 .wslconfig 文件:

[wsl2]
networkingMode=mirrored
autoProxy=true

详情参考:

更多参考资料:

客户端配置:Windows、macOS 和 Linux

当我说 “客户端” 时,我指的是您正在使用的本地机器,即您的 PC 或 Mac。

在 Mac 上,您的操作系统一般是 macOS,而在 PC 上,可能是 Windows 或 Linux。大多数类 Unix 操作系统(如 macOS 或 Linux)上的配置是相似的,而在 Windows 上可能有所不同。作为开发者,我们更多地使用类 Unix 系统(大多数是 Linux)而不是 Windows。然而,作为 IT 领域的初学者(例如一名国内的计科学生),您可能只有一台运行 Windows 的 PC。

在本指南中,我充分理解这一点,所以我会尝试使您的 Windows 更加 “Unix 化”。此处我指的是纯粹的 Windows 环境而非虚拟机(例如 VMWare 或 WSL)。

Tip

尽管本文中提到了让 Windows 更加 “Unix 化” 的一些办法,但我仍然建议,如果可以的话,您应该使用 WSL,并按照本文中提到的 适用于 Linux 或 Unix 的一般方法 来配置它。这样做的好处至少有两点:

  • 避免一些 Windows 特有的问题
  • 更好的性能(不知出于什么原因,在 Windows 上的相同配置远不及其他平台的性能好)

添加用户账户

本节适用于 Linux 用户。当您安装好一个新的 Linux 系统时,您可能只有一个 root 账户。我们不建议使用 root 账户进行日常工作,因为它有点太 “万能” 了,如果您一不小心输错了命令或者犯了别的什么错误,可能会一下子导致严重的问题。通常,我们建议您创建一个新账户使用。

Tip

如果您使用的是 WSL,在您首次启动时系统会要求您输入用户名和密码。在那种情况下,您可以 跳过 这个步骤。

具体请参考:

您可以使用以下命令创建一个新账户(将 username 替换为您想要的用户名):

useradd -m username

useradd 命令是一个 POSIX 兼容的命令,用于创建新用户账户。-m 标志为新用户创建一个主目录。运行此命令后,您可以使用 passwd 命令为新用户设置密码。您可能还想让新用户成为 sudoer,这可以通过将用户添加到 sudo 组来完成:

usermod -a -G sudo username

Tip

取决于发行版,默认的 sudo 用户组的名称并不相同。上文提到的 sudo 组是 Debian 系,而在 Arch Linux 中,这个用户组的名称是 wheel

或者您可以通过运行 visudo 手动编辑 sudoers 文件。

如果您使用的是 Ubuntu,您可以使用 adduser 命令。一步一步按照它给出的指示操作即可,会更容易:

adduser username # 添加用户
adduser username sudo # 使之成为一个 sudoer

选择合适的字体

一个好的编程字体可以带来巨大的不同。寻找具有以下特征的字体:

  • 等宽
  • 易于区分的字符(例如,您可以轻松区分 1lIO0 等)
  • 连字支持(可选,只是为了美观,我个人比较喜欢这种)

此外,一个名为 “Nerd Fonts” 的字体集合提供了许多带有图标的修补字体,这在终端中非常有用。

Nerd Fonts

FiraCode Nerd Font 是我的最爱。如果您有选择困难症,不知道从上面的列表中选哪一个,那就试试我喜欢的这个吧!

终端、控制台和终端模拟器

您可能听说过 “终端(Terminal)” 或 “控制台(Console)” 这些词。这些词源于计算机巨大且昂贵的年代。当时,整个建筑可能只有一台计算机,终端被放置在不同房间里,以便人们可以与那台计算机交互。终端是一个基于文本的界面,而控制台是一个物理设备。

另一个概念是 TTY(Teletypewriter),它最初是指电传打字机,这种设备允许用户通过键盘输入命令,并从打印机或显示器上查看计算机的输出。在现代计算机中,TTY 不仅指代传统的物理终端设备,还包括软件模拟的终端接口。每个终端设备在 Unix/Linux 系统中都有一个对应的 TTY 设备文件,例如 /dev/tty1/dev/pts/0 等。与此相关的是 伪 TTY(Pseudo Terminal,PTY),它是一对字符设备,包括伪终端主设备(master)和伪终端从设备(slave)。伪 TTY 用于模拟终端功能,使得多个用户或进程能够共享同一物理终端的输入输出。它在现代操作系统中广泛应用于终端模拟器、远程连接(如 SSH)和多路复用器(如 tmux),使得用户能够灵活地进行命令行操作。

终端模拟器(Terminal Emulator) 是模拟终端的软件,基本上它是一个看起来像终端的 GUI 应用程序。现代操作系统中的终端窗口(如 GNOME Terminal、Konsole 等)都属于这一类。当您使用这些终端模拟器时,实际上是在与 TTY 和伪 TTY 接口进行交互。

如今,您可以在许多上下文中互换使用这些术语,因为它们的含义已经变得模糊。我将在本文中使用 “终端” 这个词。

无论您使用什么操作系统,您都有一个内置的终端,例如 Mac 上的 Terminal.app 和 Windows 上的 Windows Terminal。然而,第三方提供了更多的功能和自定义选项。考虑使用下面的第三方终端模拟器:

Alacritty 是一个跨平台、高性能且高度可定制的终端模拟器。您也可以在 Mac 上使用 Alacritty,但我更喜欢在 Mac 上使用 iTerm2

这是我在 Windows 上的 Alacritty 配置文件:

working_directory = "D:\\Documents"

[shell]
program = "C:\\Program Files\\Git\\bin\\bash.exe"
args = ["--login", "-i"]

[font]
bold = { family = "FiraCode Nerd Font Mono", style = "Bold" }
normal = { family = "FiraCode Nerd Font Mono", style = "Light" }
size = 12
offset = { x = 0, y = 4 }

[window]
dimensions = { columns = 80, lines = 30 }
padding = { x = 12, y = 12 }

主题是一组更改应用程序外观的配置。您可以使用主题使您的终端工具更好看,更易于使用。例如,在 Vim 中设置 colorscheme。然而,我更喜欢在终端模拟器中设置主题,这样所有的终端工具都共享相似的外观。我在 AlacrittyiTerm2 中都使用了 Dracula 主题。Dracula 主题也适用于许多其他应用程序,例如 VS Code 和 JetBrains IDEs。共享的主题使您的开发环境更加一致和美观。除了 Draculacatppuccin 这个主题我也非常喜欢。

Shell:您与系统内核之间的桥梁

在终端中运行的程序称为 Shell,它是用户与系统内核之间的桥梁。在大多数 Linux 上,默认的 Shell 是 bash,而在 macOS 上是 zsh。在 Windows 上有两个 Shell,cmdPowerShell

我推荐在所有系统上使用 zsh。您可以将其视为 bash 的超集,具有更多功能。这里是我的配置。在其中,我:

  • 使用 oh-my-zsh 框架使 zsh 配置更容易
  • 使用主题 powerlevel10k 自定义命令提示符
  • 使用许多其他插件和配置

值得一提的是其中的一个自定义命令,用于快速打开、关闭及检查代理的状态:

proxy() {
  if [[ "$1" == "--disable" ]]; then
    unset https_proxy http_proxy all_proxy
    echo "Proxy disabled"
  elif [[ "$1" == "--check" ]]; then
    if command -v wget &> /dev/null; then
      wget --spider --proxy=on http://google.com -q -T 10
      if [ $? -eq 0 ]; then
        echo "Proxy is working"
      else
        echo "Proxy is not working"
      fi
    elif command -v curl &> /dev/null; then
      curl --proxy http://127.0.0.1:7890 http://google.com -s -m 10 --connect-timeout 10
      if [ $? -eq 0 ]; then
        echo "Proxy is working"
      else
        echo "Proxy is not working"
      fi
    else
      echo "Neither wget nor curl is installed, cannot check proxy"
    fi
  else
    export https_proxy=http://127.0.0.1:7890 http_proxy=http://127.0.0.1:7890 all_proxy=socks5://127.0.0.1:7890
    echo "Proxy enabled"
  fi
}

除了在上文中提到的 powerlevel10k 可以用于自定义命令提示符,您也可以看看 starship,这是一个使用 Rust 写的跨平台跨终端命令提示符配置工具,性能非常好。

Tip

命令提示符实际上是通过名为 PS1 环境变量定义的,可以参考:

如果您不想使用 zsh,因为它需要一些配置,您也可以试试 fish(我之前用的就是 fish)。然而,fish 不是 POSIX 兼容的,这意味着您可能会遇到一些 Shell 脚本的兼容性问题。这就是我更喜欢 zsh 的原因。但对于初学者来说,这没问题。

在大多数类 Unix 系统上,您已经安装了 bash,并且很容易在这些平台上安装 zshfish。但在 Windows 上,这有点棘手。

如果您想在 Windows 上安装 bash,您可以使用 git bash。当您在 Windows 上安装 git(一个流行的版本控制系统)时,它会被自动安装。此外,您也可以在 Windows 上使用 zsh。以下文章可能会有所帮助:

我还没有找到在 Windows 上安装 fish 的好方法。如果您知道如何做到这一点,请通过留言或发送电子邮件告诉我。

Caution

另一个您可能需要注意的问题是您 Windows 平台上使用的字符集。如果您是一个使用中文 Windows 的国内的计科学生,您的系统默认字符集通常不是 UTF-8。因此,您可能会遇到 乱码 问题。您可以在 ~/.zshrc 的开头添加以下几行指令以在终端中启用 UTF-8,进而解决该问题:

# 将 Windows 代码页设置为 65001(UTF-8)。
if [[ "$OSTYPE" == "msys" ]]; then
    chcp.com 65001 &> /dev/null
fi

安装您喜欢的 Shell 后,您可以通过运行以下命令将其设置为默认 Shell(仅适用于 Unix 类系统):

chsh -s $(which zsh)

补充说明一下 PowerShell。Windows 上的 PowerShell 是一个强大的 Shell,但它的语法和 bash 有很大不同。如果您想使用 PowerShell,我建议您使用 PowerShell Core,它是一个更新的、跨平台的版本。您需要自行安装这个版本,参考下面的官方文档:

然后,通过一些配置(例如参考我的配置),使其更加符合您的需求。

包管理器:开发者的应用商店

包管理器基本上扮演了应用商店的角色。“包(Package)” 这个术语意味着一堆文件。一个可执行的应用程序基本上是一堆文件,所以您可以将应用程序视为一个包。

在包管理器的帮助下,您不再需要去特定应用程序的官方网站,点击下载然后安装它,而是只需一行简单的命令。

在不同版本的 Linux 上有不同的包管理器,例如,Ubuntu 上最流行的包管理器是 apt,而 Arch 上是 pacman。它们在 Linux 系统准备就绪时就为您安装好了。

然而,在 Mac 上,您需要下载并安装一个包管理器。最流行的是 Homebrew。Windows 也没有自带的包管理器。您可以自己下载并安装 scoopchoco

上面解释的 “包管理器” 这个概念实际上非常不严谨。更准确地说,上述包管理器是系统范围的。在各种技术栈中还有许多其他包管理器。例如,node.js 项目中的 npm 和 rust 项目中的 cargo 等。

Tip

对于国内用户来说,一个常见的头痛问题是与服务器的物理距离,导致网络信号差,从而下载速度慢,甚至超时,最终无法使用包管理器正确下载包。在这种情况下,除了上面提到的使用代理,您也可以使用镜像站点。过去,我们必须手动修改不同包管理器的一堆配置文件,但现在,您可以使用一个名为 chsrc 的工具。

Gsudo:Windows 的第三方 sudo

本节仅适用于 Windows 用户。sudo 是 Unix 类系统中的一个命令,允许您以 sudoer 身份(基本上就是超级用户身份)运行命令。Windows 没有 sudo 命令,但您可以使用 gsudo 作为替代。

一个常见的用例是当您想使用 choco 安装一个包时,您运行一个类似 choco install xxx 的命令,但您可能会因为没有权限安装包而遇到错误。在这种情况下,您可以使用 gsudo !! 以管理员身份运行命令。(!!zsh 中的一个快捷方式,表示上一个命令。)

TLDR:速查手册

在 Unix 类系统上,您可以使用 man 命令查看命令的手册。然而,手册通常太长且难以理解。我只想知道命令的基本用法,但 man 提供了比我需要的更多的信息。

tldr-pages 项目填补了这一需求。运行 tldr xxx 将为您提供如何使用 xxx 命令的示例,涵盖最常见的用例。

我推荐使用 tealdeer 客户端,它基于 tldr pages 项目,但用 Rust 编写。它比原始的 tldr 客户端快得多。

tealdeer 的介绍图片

Vim 和 VS Code:我主要使用的两个编辑器

我每天都使用 Vim 和 VS Code。我使用 Vim 进行快速和小的编辑,使用 VS Code 进行大型项目。即使在 VS Code 中,我也在使用 Vim 扩展来启用 Vim 键绑定。

我的 Vim 配置在这里

要在 Ubuntu 上将 Vim 设置为默认编辑器,您可以以 root 身份运行以下命令:

update-alternatives --config editor # 并在菜单中选择 vim

环境的版本控制

这里我不是在谈论像 git 这样的版本控制系统,而是您使用的软件的版本。例如,您可能在您的机器上安装了 Node 20,但您的项目需要 Node 14。如何快速有效地在同一软件的不同版本之间切换?这些工具可以帮助您:

除了上面提到的软件专用的版本控制工具,您还可以使用 asdfmise 这样的工具来管理多个软件的版本。下面是一个使用 mise 来管理多个 Node.js 版本的例子:

mise install node@22
mise install node@20

mise ls # 列出已安装的各个软件及其版本

mise use -g node@20 # 全局切换到 Node 20
node --version # -> v20.18.1

mise use -g node@22 # 全局切换到 Node 22
node --version # -> v22.11.0

如果您正在 Windows 平台上使用 Scoop 作为您的包管理器,您也可以使用 scoop reset 命令来快速切换版本,下面是一个使用它来管理 Python 版本的例子(来自官方 Wiki

scoop bucket add versions # 如果您还没有添加 versions 桶,添加它

scoop install python27 python
python --version # -> Python 3.6.2

# 切换到 python 2.7.x
scoop reset python27
python --version # -> Python 2.7.13

# 切换回 3.x
scoop reset python
python --version # -> Python 3.6.2

Dotfiles:持久化您的应用配置

许多 Unix 类系统上的程序使用以 . 开头的文件作为其配置文件。例如,bash.bashrcvim.vimrc。所以您可以将这些文件保存在某个地方(比如 GitHub 仓库)并同步到您的新机器上。如果您在 GitHub 上搜索 dotfile,您会发现许多具有类似名称的仓库。更多信息请参见 dotfiles.github.io

我的 dotfiles 在这里

服务器端配置

在服务器上,Linux 是最流行的操作系统。因此,一般来说,您只需要将基于 Linux 的客户端配置复制到服务器端。

SSH:轻松连接到服务器

SSH(Secure SHell)是一种网络协议,允许您安全地连接到远程服务器。它在 IT 行业中被广泛使用。您可以在本地机器上使用 ssh 命令连接到服务器。例如:

ssh username@hostname

默认情况下,您每次连接到服务器时都必须输入密码。您可以通过使用 SSH 密钥省略这个烦人的步骤。为此:

  1. 使用 ssh-keygen 命令在本地机器上生成一对密钥。输入以下命令后不断按回车键,直到完成:
ssh-keygen -t ed25519
  1. 使用 ssh-copy-id 命令将公钥复制到服务器:
ssh-copy-id username@hostname

您将被提示最后一次输入密码,然后就可以在不输入密码的情况下连接到服务器

Note

注意:我将关于 SSH 的部分放在服务器端配置中,但我们在这里使用的命令应该在客户端运行。

总结

配置一个高效的开发环境是一个持续的过程。随着时间的推移,您会发现新的工具和方法来进一步优化您的工作流程。希望本指南能为您提供一个良好的起点,并帮助您在开发过程中更加高效和愉快。如果您有任何问题或建议,欢迎通过电子邮件与我联系。祝您编码愉快!