"command not found"问题的解决办法

"zsh: command not found:"这个错误相信大家都不陌生,以前每次遇到这个问题都是Google一下,然后告诉你在xxx文件添加xxx文字,或者在Terminal运行xxx命令即可,有些work,有些不行。

万事皆有因,今天我们就来说一下这个问题发生的时最常见的原因和解决办法,让你下次再遇到这种问题时自己就可以解决不需要在去Googlexxx Gems command not found

问题通常发生在局部安装了某个Terminal程序之后,此时程序可能在某个ruby gem的bin目录下,或者Application下(如:sublime),需要我们创建一个指向这个地址软链接,可以方便的访问它。例如:

subl . or pod install

Terminal访问程序原理

Linux环境下通常我们将Terminal可访问的程序放在/bin, /usr/bin, /usr/local/bin,有时也会放在~/bin目录下。

那么在Terminal页面打开(其实是shell login)的时候,程序是如何Load进来的呢?过程大致如下:

  1. Terminal打开时当前user默认的shell会去读取自己的配置文件,一般在~目录下;
  2. 这个配置文件会去export上述几个路径,读取*/bin下的可执行文件;
  3. */bin下的可执行文件通常情况下是指向某个路径下的软链接(可以使用ln -s创建);

问题原因

基于上面的过程,我们在Terminal中访问得到command not found的具体原因可能如下:

  1. 当前调用的命令确实没有安装,如:"lorem spear";
  2. 当前命令安装了,但是没有创建软链接到*/bin
  3. 当前命令已创建软链接到*/bin,但是所在*/bin路径没有被export;

解决办法

接下来以Mac下的zsh为例给出解决办法:

Linux系统或者其他Shell(如:bash、sh等)只需要换一些shell的配置文件即可。

  • 首先zsh的配置文件在~/.zshrc,使用任何编辑器(vim、atom)打开这个文件,搜索export会看到有如下一行:

      `export PATH="/Users/yourname/.rbenv/shims:/opt/iOSOpenDev/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"`
    

    PATH=后是用:连接的多个*/bin路径[1]

    /usr/sbin
    /bin
    /usr/bin
    /usr/local/bin
    

    我的机器中安装了rbenviOSOpenDev,所以还 export 了:

    /Users/yourname/.rbenv/shims
    

    有的程序安装时会自动添加自己的*/binexport或者引导你运行一些命令去添加,原理都是一样的

  • 在上面的路径中找一个合适的路径,如/usr/bin或者/usr/local/bin,然后在这个路径下创建一个指向not found那个程序的软链接。

    当然,你也可以像rbenv那样直接将程序所在路径或者一些特定的*/bin整个加到export中。

  • 你需要找到not found的这个程序在什么位置,比如:

    • subl/Applications/Sublime\ Text\ 2.app/Contents/SharedSupport/bin/subl路径下;
    • pod的所在路径可以通过下面命令找到(所有的ruby gems程序都可以通过这种方式找到):
    $ gem which cocoapods
    /Users/eloy/.gem/ruby/2.0.0/gems/cocoapods-0.29.0/lib/cocoapods.rb
    $ /Users/eloy/.gem/ruby/2.0.0/bin/pod install
    

    如果以后有时间丰富一些常见的case。

  • 创建从程序所在位置*/bin的软链接。创建软链接的命令是ln -s $source $target-s参数表明创建的链接类型,source表示程序所在位置,target表示软链接的所在路径。

    例如:ln -s /Users/kimimaro/.rbenv/versions/2.0.0-p645/bin/pod /usr/local/bin

  • 运行source命令使软链接生效。新创建的软链接在当前的Terminal页面(即没有再次运行shell login)不会生效,需要对当前Shell(在本例中即zsh)的配置文件(在本例中即~/.zshrc)手动执行source来加载。例如:

    source ~/.zshrc

此时再次运行命令已经不会报错了。

脚注


  1. 这些系统路径用户使用权限登录和非登等情况下作用有所不同,,但由于我们绝大部分操作都在登录情况下因此本文范围内不再详述。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容