解决在 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

相关推荐
fishmemory7sec几秒前
Electron 主进程与渲染进程、预加载preload.js
前端·javascript·electron
fishmemory7sec3 分钟前
Electron 使⽤ electron-builder 打包应用
前端·javascript·electron
豆豆1 小时前
为什么用PageAdmin CMS建设网站?
服务器·开发语言·前端·php·软件构建
twins35202 小时前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky2 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~2 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
安冬的码畜日常2 小时前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
l1x1n03 小时前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
昨天;明天。今天。3 小时前
案例-任务清单
前端·javascript·css
zqx_74 小时前
随记 前端框架React的初步认识
前端·react.js·前端框架