❏ 站外平台:

解决 Linux 中的 “Bash: Command Not Found” 报错

作者: Abhishek Prakash 译者: LCTT chai001125

| 2022-10-22 11:59   评论: 4    

本新手教程展示了在 Debian、Ubuntu 和其他的 Linux 发行版上如何解决 “Bash: command not found” 这一报错。

当你在 Linux 中使用命令时,你希望得到终端输出的结果。但有时候,你会遇到终端显示“命令未找到command not found”这一报错。

对于这个问题,并没有直截了当且单一的解决方案。你必须自己做一些故障排除来解决这个报错。

老实说,要解决它并不难。该报错信息已经给出了一些提示:“命令未找到”,这说明你的 shell(或者 Linux 系统)找不到你输入的那条命令。

shell(或 Linux 系统)找不到命令,有三个可能的原因:

  • 你将命令的名称拼错了
  • 该命令还没有安装
  • 该命令是一个可执行脚本,但其位置未知

接下来,我们会详细介绍“命令未找到”这一报错的每一个原因。

解决“命令未找到”报错

方法 1:再次检查命令名称有没有写错

每个人都会犯错误,尤其是在打字的时候。你输入的命令可能存在错别字(也就是你写错啦)。

你应该特别注意:

  • 是否拼对了正确的命令名称
  • 是否在命令与其选项之间加上了空格
  • 是否在拼写中混淆了 1(数字 1)、I(大写的 i)和 l(小写的 L)
  • 是否正确使用了大写字母或者小写字母

看看下面的示例,因为我写错了 ls 命令,所以会导致“command not found”报错。

所以,请再次仔细确认你输入得对不对。

方法 2:确保命令已安装在你的系统上

这是“命令未找到”错误的另一个常见原因。如果命令尚未安装,则无法运行该命令。

虽然在默认情况下,你的 Linux 发行版自带安装了大量命令,但是不会在系统中预装 所有的 命令行工具。如果你尝试运行的命令不是一个流行的常用命令,那么你需要先安装它。

你可以使用发行版的软件包管理器来安装命令。

You may have to install the missing command

有时候,某一常用命令可能也不再能使用了,甚至你也不能够安装这个命令了。这种情况下,你需要找到一个替代的命令,来得到结果。

以现已弃用的 ifconfig 命令为例。网络上的旧教程依旧会让你使用 ifconfig 命令,来 获取本机的 IP 地址 和网络接口信息,但是,在较新的 Linux 版本中,你已经无法使用 ifconfig 了。ifconfig 命令已被 ip 命令所取代。

Some popular commands get discontinued over the time

有时候,你的系统可能甚至找不到一些非常常见的命令。当你在 Docker 容器中运行 Linux 发行版时,就通常如此。Docker 容器为了缩小操作系统镜像的大小,容器中通常不包含那些常见的 Linux 命令。

这就是为什么使用 Docker 的用户会碰到 ping 命令未找到 等报错的原因。

Docker containers often have only a few commands installed

因此,这种情况下的解决方案是安装缺失的命令,或者是找到一个与缺失命令有同等功能的工具。

方法 3:确保命令是真实的,而不是一个别名

我希望你知道 Linux 中的别名概念。你可以配置你自己的较短的命令来代替一个较长命令的输入。

一些发行版,如 Ubuntu,会自动提供 llls -l 的别名)、lals -a 的别名)等命令。

想象一下,你习惯于在你的个人系统上输入 ll 和 la,而你登录到另一个 Linux 系统,发现 ll 命令并不存在。你甚至不能安装 ll 命令,因为它不是一个真正的命令。

所以,如果你找不到一个命令,甚至不能安装,你应该尝试在互联网上搜索该命令是否存在。如果不存在,可能是其他系统上的一个别名。

方法 4:检查命令是否是一个路径正确的可执行脚本

这是 Linux 新手在 运行 shell 脚本 时常犯的错误。

即使你在同一目录下,仅用可执行脚本的名称,来运行可执行脚本,也会显示错误。

[email protected]:~/scripts# sample
-bash: sample: command not found

因为你需要显式指定 shell 解释器或可执行脚本的路径!

如果你在其他目录下,在未提供文件正确路径的情况下,运行 shell 脚本,则会有“找不到文件no such file or directory”的报错。

把可执行文件的路径加到 PATH 变量中

有时候,你下载了一个软件的压缩文件(tar 格式),解压这个 tar 文件,然后找到一个可执行文件和其他程序文件。你需要运行可执行文件,来运行那个软件。

但是,你需要在可执行文件的同一目录下或指定可执行文件的整个路径,才能运行那个可执行文件。这很令人烦扰。

你可以使用 PATH 变量来解决这个问题。PATH 变量包含了有各种 Linux 命令的二进制(可执行)文件的目录集合。当你运行一个命令时,你的 Linux 系统会检查 PATH 变量中的上述目录,以查找该命令的可执行文件。

你可以使用 which 命令,来检查某一命令的二进制文件的位置:

如果你想从系统上的任何地方都能运行可执行文件或脚本,你需要将可执行文件的位置添加到 PATH 变量中。

然后,PATH 变量需要添加到 shell 的 rc 文件中,如此对 PATH 变量的更改就是永久性的。

这里的要点是:你的 Linux 系统必须了解可执行脚本的位置。要么在运行时给出可执行文件的整个路径,要么将其位置添加到 PATH 变量中。

以上的内容有帮到你吗?

我懂得,当你是 Linux 新手时,很多事情可能会让你不知所措。但是,当你了解问题的根本原因时,你的知识会逐渐增加。

对于“未找到命令”报错来说,没有简单的解决方案。我提供给你了一些提示和要点,我希望这对你的故障排除有帮助。

如果你仍然有疑问或需要帮助,请在评论区告诉我吧。


via: https://itsfoss.com/bash-command-not-found/

作者:Abhishek Prakash 选题:lujun9972 译者:chai001125 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出



最新评论

暗灬先知 [Chrome 106.0|GNU/Linux] 2022-10-24 09:10 4 回复
有个网站叫做 command-not-found
来自湖北武汉的 Chrome Mobile iOS 106.0|iOS 16.0 用户 2022-10-23 23:09 5 回复
把 The fuck 文章链接贴出来了更好。我就是在linux 中国种草的thefuck ,打错了命令fuck下就好
[1]
来自四川南充的 Chrome 108.0|Windows 10 用户 发表于 2022-10-22 18:27 的评论:
没多大的帮助,旦凡用了一两天的 Linux,都知道要不是拼错了,要不是没装对应的软件包。

最重要的是得知道 "这个命令它到底在什么软件包里",以下是各系统搜索软件包文件的命令。

Arch Linux: pacman -F
Fedora: dnf provides
Debian: apt-file search
openSUSE: zypper what-provides / zypper wp / zypper search -f
Gentoo: equery belongs

比如,不知道 nokfw 这个命令是由什么软件包提供,直接执行 pacman -F nokfw 命令,然后就知道是 bluez-utils 包提供的。
来自山东的 Firefox 106.0|GNU/Linux 用户 2022-10-22 21:37 4 回复
确实,但是对于很多 Linux 新手来说还是挺有用的。比如以前啥都不会就尝试 WSL Ubuntu 的我,不知道 gcc -o 后头该写什么扩展名……有了缺省的 a.out,又不知道如何执行,甚至尝试使用 exec 来执行它。

不过 newbies,只要敢折腾,终究可以成为 dalao。
LCTT 译者
chai001125 🌟🌟🌟🌟
共计翻译: 28.0 篇 | 共计贡献: 238
贡献时间:2022-10-06 -> 2023-05-31
访问我的 LCTT 主页 | 在 GitHub 上关注我


返回顶部

分享到微信

打开微信,点击顶部的“╋”,
使用“扫一扫”将网页分享至微信。