解决在 macOS 上终端找不到全局命令的问题

解决在 macOS 上终端找不到全局命令的问题

在 macOS 上,有时候我们会遇到全局安装的命令在终端中找不到的问题,例如 flutteryarn 等。通常这是因为这些工具的安装路径没有正确添加到 PATH 环境变量中。以下是解决这个问题的方法。

检查 Shell 配置文件

首先,确保你正在使用正确的 Shell(如 Zsh 或 Bash),并且 Shell 配置文件中包含必要的环境变量配置。

确认使用 Zsh

你可以运行以下命令检查当前使用的 Shell:

bash 复制代码
sh
复制代码
echo $SHELL

输出应该类似于 /bin/zsh/usr/bin/zsh。如果不是 Zsh,可以将其设置为默认 Shell:

bash 复制代码
sh
复制代码
chsh -s $(which zsh)

更新 ~/.zshrc 文件

确保 ~/.zshrc 文件中包含正确的配置。你可以使用以下命令打开并编辑 ~/.zshrc 文件:

bash 复制代码
sh
复制代码
nano ~/.zshrc

配置 nvm 和 Flutter

确保 nvm 和 Flutter 的路径已经添加到 ~/.zshrc 文件中:

bash 复制代码
sh
复制代码
# 设置 nvm
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"  # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && . "$NVM_DIR/bash_completion"  # This loads nvm bash_completion

# 设置 Flutter
export PATH="$PATH:$HOME/flutter/bin"

配置 yarn

如果你已经全局安装了 yarn,但找不到命令,可能是 yarn 的安装路径没有正确添加到 PATH 环境变量中。

首先,确认 yarn 的安装路径:

bash 复制代码
sh
复制代码
which yarn

如果 which yarn 返回路径,比如 /usr/local/bin/yarn,说明 yarn 已经安装但可能没有在 PATH 中正确配置。

检查 npm 的全局安装路径:

arduino 复制代码
sh
复制代码
npm config get prefix

通常,yarn 会安装在这个路径的 bin 目录下,例如 /usr/local/bin/yarn

确保 ~/.zshrc 文件中包含以下内容:

bash 复制代码
sh
复制代码
# 设置 npm 全局安装路径
export PATH="$PATH:/usr/local/bin"

重新加载 ~/.zshrc 文件

保存对 ~/.zshrc 文件的更改并退出编辑器,然后在终端中运行以下命令以重新加载配置文件:

bash 复制代码
sh
复制代码
source ~/.zshrc

验证命令

通过以下命令检查和验证配置:

bash 复制代码
sh
复制代码
which flutter
flutter doctor

which yarn
yarn --version

示例 ~/.zshrc 文件

以下是一个示例 ~/.zshrc 文件,展示了如何配置 nvm、Flutter 和 yarn

bash 复制代码
sh
复制代码
# 设置 nvm
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"  # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && . "$NVM_DIR/bash_completion"  # This loads nvm bash_completion

# 设置 Flutter
export PATH="$PATH:$HOME/flutter/bin"

# 设置 npm 全局安装路径
export PATH="$PATH:/usr/local/bin"

通过这些步骤,你可以确保全局安装的命令行工具在终端中可以正确使用。如果你有任何其他工具需要配置,只需确保将它们的路径添加到 PATH 环境变量中即可。

补充:mac 上安装命令

brew install yarn

相关推荐
架构师老Y39 分钟前
003、Python Web框架深度对比:Django vs Flask vs FastAPI
前端·python·django
小陈工3 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1318 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉8 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro8 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常9 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆9 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶9 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐9 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅9 小时前
Vue如何集成封装Axios
前端·javascript·vue.js