即使在我安装brew node和NVM安装v0.6.19之后,我的节点版本始终是v0.6.1-pre。
我的节点版本是:
node -v
v0.6.1-pre
NVM这样说(在我第一次在一个bash终端中安装一个版本的节点之后):
nvm ls
v0.6.19
current: v0.6.19
但当我重启bash时,我看到的是:
nvm ls
v0.6.19
current: v0.6.1-pre
default -> 0.6.19 (-> v0.6.19)
那么,这个幻影节点0.6.1预版本在哪里?我该如何摆脱它?我正在尝试通过NPM安装库,以便我可以在项目中工作。
我尝试在NVM之前使用BREW进行更新,使用BREW更新和BREW安装节点。我已尝试删除/usr/local/include中的“node”目录和/usr/local/lib中的“节点”和“node_modules”。我已尝试卸载npm并按照以下说明重新安装。
所有这些都是因为我试图更新节点的旧版本以安装“zipstream”库。现在我的用户目录中有文件夹,节点版本STILL不是最新的,尽管NVM说它使用的是0.6.19。
理想情况下,我希望卸载nodejs、npm和nvm,然后在我的系统上从头安装整个程序。
对于brew用户,OSX:
要删除:
brew uninstall node;
# or `brew uninstall --force node` which removes all versions
brew cleanup;
rm -f /usr/local/bin/npm /usr/local/lib/dtrace/node.d;
rm -rf ~/.npm;
要安装:
brew install node;
which node # => /usr/local/bin/node
export NODE_PATH='/usr/local/lib/node_modules' # <--- add this ~/.bashrc
您可以运行brew info node以获取有关节点安装的更多详细信息。
考虑使用NVM而不是brew
NVM(节点版本管理器)是用于管理多个版本的节点的便携式解决方案
https://github.com/nvm-sh/nvm
> nvm uninstall v4.1.0
> nvm install v8.1.2
> nvm use v8.1.2
> nvm list
v4.2.0
v5.8.0
v6.11.0
-> v8.1.2
system
当您在具有不同节点依赖关系的不同项目之间切换时,可以使用AVN自动切换版本。
Docker-替代方法
Docker是一种超级快速的虚拟机,可以用来运行node等工具(而不是直接安装在macos上)。这样做的优点如下
所有内容(“millions”节点文件)都安装在docker映像/容器中(它们封装在几个内部docker文件中)您可以将带有项目的mac目录映射到docker容器,并可以访问节点,但在docker之外,macos系统甚至不知道节点已安装。因此,您可以获得某种带有可用节点命令的“虚拟”控制台,这些命令可以在真实文件上运行您可以通过docker ps查找节点并通过docker rm-f nameornum查找节点,从而轻松地杀死节点您可以通过一个命令dockerrmi轻松卸载dockerimage/容器。。。并获得可用空间-然后通过运行脚本再次安装(如下)您的节点封装在docker中,不能访问整个系统-只能访问映射到它的文件夹您可以运行节点服务,轻松地将其端口映射到mac端口,并可以从web浏览器访问它可以同时运行多个节点版本以类似的方式,您可以在docker内部安装其他工具,如php、数据库、redis等,而无需与macos进行任何交互(它们根本没有注意到此类软件)。例如,您可以同时运行3个不同版本的mysqldb和3个不同php版本的php应用程序…-所以你可以有很多工具,但系统干净团队工作:这样的环境可以很容易地克隆到其他机器上(甚至可以克隆到windows/linux系统上-经过一些修改),并提供相同的docker级环境-因此您可以轻松地设置和重用脚本/dockerfile,并以非常快速的方式为新的团队成员设置环境(他只需要安装docker并创建类似的文件夹结构并获取脚本副本即可)。我以这种方式工作了2年,和我的团队一起工作,我们非常高兴
指示
使用以下说明安装docker为工作准备“特殊”目录,例如我的目录是/Users/kamil/work(我将进一步使用这个目录,但它可以是任意的)-这个目录将是docker容器和mac文件ststem之间的“接口”。在此目录中创建以下目录结构:/Users/kamil/work/code-在这里,您可以将项目与代码放在一起/用户/卡米尔/工作/工具/Users/kamil/work/tools/docker数据-这里我们映射容器输出数据,如日志(或数据库文件,如果有人使用db等)/用户/卡米尔/工作/工具/码头工人/Users/kamil/work/tools/docker/node cmd-这里我们放置docker-node脚本工具内部创建文件.env,该文件将在一个位置包含其他脚本中使用的全局路径toolspath=“/Users/kamil/work/tools”codepath=“/Users/kamil/work/code”工作路径=/Users/kamil/work内侧方向/node cmd创建包含以下内容的文件dockerfile#默认/var/www/html(映射到带有项目的…/code文件夹)FROM节点WORKDIR/工作#其他任意工具(ng、gulf、bower)RUN npm install-g n@angular/cli bower gulf grutCMD为真;睡眠10000;完成#以下端口是任意的暴露3002 3003 3004 4200内侧方向/nodecmd创建包含以下内容的文件运行容器(该文件应可执行,例如通过chmod+x运行容器)-(注意我们如何将port-s和目录从外部“world”映射到内部docker文件系统)集合-ecd--“$(dirname”$0“)”#此脚本目录(双击时未设置)源../../。环境toolsdir=$toolspath/docker数据workdir=$workpath如果[!“$(docker ps|grep node cmd)”]然后docker build-t node cmd。docker rm-f节点cmd|:docker run-d--name node cmd-p 4200:4200-p 4201:4201-p 3002:3002-p 3003:3003-p 3004:3004-v$toolsdir/node cmd/logs:/root/.npm/logs-v$workdir:/work node cmd传真好了,现在您可以添加一些项目,例如work/code/myProject,并添加以下文件“run-cmd”(必须是可执行的)cd--“$(目录名“$0”)”../../tools/docker/node cmd/run containerdocker exec-it node cmd bash-c“cd/work/code/myProject;bash”然后,如果您运行上面的脚本(双击),您将在项目目录中看到带有可用节点命令的控制台,例如npm install要在后台运行项目(例如一些serwice),例如运行web服务器angular cli应用程序,可以使用以下脚本(名为run front-必须是可执行的)-(还必须编辑/etc/hosts文件以添加适当的域)cd--“$(目录名“$0”)”打开“http://my-angular.local:3002"../../tools/docker/node cmd/run containerdocker exec-it node cmd/bin/sh-c“cd/work/code/my angular project;npm start”cat#用于块脚本并等待用户ctrl+C
这为我修复了Homebrew用户在Mac OS X上修复npm。而且它不需要太多步骤。
如果你不在乎原因,就去解决问题。
为方便起见,以下是相关部分:
解决方案
此解决方案修复了尝试运行npm更新npm-g所导致的错误。完成后,您也不需要使用sudo在全球安装npm模块。
开始之前,请记下所有全球安装的npm包。这些说明将帮助您删除所有这些包。完成后,您需要重新安装它们。
运行以下命令以删除所有现有的全局npm模块,卸载node和npm,使用正确的默认值重新安装node,配置要安装的全局npm模块的位置,然后将npm作为自己的软件包安装。
rm -rf /usr/local/lib/node_modules
brew uninstall node
brew install node --without-npm
echo prefix=~/.npm-packages >> ~/.npmrc
curl -L https://www.npmjs.com/install.sh | sh
此时应正确安装节点和npm。最后一步是将~/.npm包/bin添加到PATH中,以便npm和全局npm包可用。为此,请在~/.bash_profile中添加以下行:
export PATH="$HOME/.npm-packages/bin:$PATH"
现在,您可以毫无问题地重新安装所需的任何全局npm包。