用过npm的都知道node
npm install 默认安装到本地 npm install -g 安装到全局。
但npm install -g是否能够把package.json中的依赖安装到全局呢?linux
赶忙去试一下。npm
。。。。。。。。。。。json
不行。服务器
这里交代下为何会考虑到把全部依赖都安装到全局,由于咱们在项目构建时,jekins拉下代码后,默认都要先npm install安装依赖到当前目录,而后npm run build作构建,构建完的dist压缩打包拷贝到发布目录,而后把jekins目录下的代码删除,也就意味着会把对应的node_modules删除。这样每次构建都要执行一次install,npm官方仓库确定是不行了,ui
npm config set registry http://registry.npm.taobao.org/url
设置到淘宝镜像。code
有人就说了既然能够全局安装,为何不全局安装,这样就不用每次下载了。好注意!ci
回到上文,npm install -g 并不能把依赖直接安装到全局,所以本身写了一个prebuild.js,get
遍历package.json中的依赖,并用npm i -g XXX逐个安装。
安装成功了,可是去buid时,依然报找到不到...........xxx npm包,
看到网上有人说设置下NODE_PATH ,找到npm包安装的全局路径:
export NODE_PATH=/usr/local/node-v6.11.2-linux-x64/lib/node_modules
设置完后,ok了。能够啊。那之后就用每次删除再下载了。
这里NPM的全局路径能够npm root -g 查看,并经过npm config set prefix '目标目录' 修改。(查看npm config get prefix 或者用npm root -g命令也可 )
成功了吗?
一个项目是ok的,若是多个项目呢? 若是不一样项目引用到同一个包的不一样版本,此时依赖版本的管理就没法依赖npm了,就须要本身写代码来管理了。
固然这里面也有一个以前使用过的方法:
就是在构建服务器上,建一个公共目录,再在下面按照各项目目录,预先安装好各项目的依赖包。
在jekinks构建脚本中,在执行npm install前,看公共目录是否存在该项目命令的目录,存在直接拷贝过来就能够。若是没有,那就切换到那个目录下,去安装,而后在切换回来,再拷贝,再构建。
这样依赖包的本地管理,也能解决必定的问题。
附npm包管理一些命令
npm update moduleName:更新node模块
npm rebuild moduleName
npm view moudleName dependencies:查看包的依赖关系
npm view moduleName repository.url:查看包的源文件地址
npm view moduleName engines:查看包所依赖的Node的版本
npm outdated:检查包是否已通过时,此命令会列出全部已通过时的包,能够及时进行包的更新
不管你在哪一个文件夹 执行 npm link xxx , 若是没有xxx模块, 那么xxx就会先安装在全局, 而后再从全局link过来