博客
关于我
在wsl中使用node和wsl与window环境冲突问题 使用 Ubuntu 系列(6️⃣)
阅读量:538 次
发布时间:2019-03-08

本文共 1291 字,大约阅读时间需要 4 分钟。

在WSL中配置全局Node.js环境

安装Node.js在Windows Subsystem for Linux (WSL)中操作,虽然有一些挑战,但完全可行。以下是详细的操作步骤。

grind……

现状

在安装Node.js之前,我们发现Node和NPM版本查询时会出现错误,提示不存在相关文件。这可能是由于WSL与本地计算机的环境变量配置不一致导致的。

直接在WSL安装Node.js

网上很多教程建议通过一些繁琐的方法(如SSH代理或桥接)来安装Node.js,这对我来说没有成功。于是,我决定采取更直接的方式。

Current situation

安装之前,通过query命令发现节点和npm的版本都无法正确识别。这可能是因为WSL和本地环境的变量配置存在不一致的问题。

Install Node.js in WSL

我直接下载Node.js v10.16.0的Linux版本(注意:链接已被修复)并进行了以下步骤:

cd /usr/local/softwarewget https://nodejs.org/download/release/v10.16.0/node-v10.16.0-linux-x64.tar.xz# 解压tar xvf node-v10.16.0-linux-x64.tar.xz# 重命名并删除压缩包mv node-v10.16.0-linux-x64 node-v10.16.0rm -rf node-v10.16.0-linux-x64.tar.xz

配置全局环境变量

在WSL上安装Node.js后,我需要配置全局环境变量。建议在WSL系统文件( /etc/profile/bashrc)中进行配置。

echo "export PATH=/usr/local/software/node-v10.16.0/bin:$PATH" >> /etc/profilesource /etc/profile

细节注意事项

在配置环境变量时,确保PATH的顺序正确。我之前曾误将bin放在后面,导致npm无法识别环境变量。建议正确顺序是:

export PATH=$PATH:/usr/local/software/node-v10.16.0/bin

这样可以确保npm能正确识别全局安装的依赖工具。

验证配置

安装完成后,使用以下命令验证:

node -vnpm -v

如果版本号正常显示,说明配置成功。

其他注意事项

对于使用Oh-My-Zsh的用户,建议在~/.zshrc中添加环境变量配置:

echo "export PATH=/usr/local/software/node-v10.16.0/bin:$PATH" >> ~/.zshrcsource ~/.zshrc

总结

通过以上步骤,我成功在WSL中配置了全局Node.js环境。现在,可以像在本地一样,轻松使用全局依赖工具,此外,也不再需要为WSL中的Node.js环境进行额外配置。

安装完成后,可以直接运行已安装的全局Node包,无需又在WSL中重新安装所需的全局npm包。

转载地址:http://aouiz.baihongyu.com/

你可能感兴趣的文章
PHP数据访问的多重查询(租房子查询)
查看>>
RabbitMQ - 如保证消息的可靠性?(消息确认、消息持久化、失败重试机制)
查看>>
RabbitMQ - 基于 SpringAMQP 带你实现五种消息队列模型
查看>>
php数组函数分析--array_column
查看>>
php数组去重复数据的小例子
查看>>
php数组实现:哈希 +双向链表
查看>>
PHP数组排序函数array_multisort()函数详解(二)
查看>>
php数组的几个函数和超全局变量
查看>>
PHP文件上传详解
查看>>
PHP文件锁
查看>>
php文本框输入制定文本,php – 当用户没有向文本框输入任何内容时...
查看>>
PHP时间戳和日期相互转换操作总结
查看>>
php时间戳知识点,php 时间戳函数总结与示例
查看>>
php更新数据库失败,php – 无法更新MySQL数据库
查看>>
php机器人聊天对话框,基于AIML的PHP聊天机器人
查看>>
PHP查找数组中最大值与最小值
查看>>
php查最大值,在PHP数组中查找最大值
查看>>
php标签筛选,关于PHP CodeIgniter框架中通过<a>标签和url做多条件分类筛选
查看>>
php根据年月日计算年龄
查看>>
RabbitMQ - 单机部署(超详细)
查看>>