相信很多人使用npm安装node包时会出现卡顿, 这是因为NPM服务器在国外的原因, 常规的解决方法是把官方npm仓库换成淘宝npm仓库.
这种方法能解决大部分NPM包卡顿的现象, 但是不能根除, 这里存在着两个原因.
一个原因是淘宝源被大量人使用, 有时候会不太好用, 这个原因倒是很容易解决, 多试试就行.
另一个原因才是最麻烦的, 那就是NPM包自身可能引用外网的其他包, 这样就算更换再多的仓库也没用.
基于以上原因, 我参考了网上许多资料, 给出了一个终极解决方案. 这个方案分为两部分, 一个是解决淘宝源不稳定的问题, 另一个是解决引用
外网包的问题.
不过解决以上问题的前提是需要一个能连外网的服务器.
其实解决这个问题很简单, 既然淘宝NPM仓库不稳定, 那么就自己搭建一个NPM仓库.
其实已经有了现成的NPM仓库, 我们只需要拿来用就行, 这里使用docker和docker-compose搭建.
下面是docker-compose.yml的配置文件, 大家直接用docker-compose -f
启动就行, 开放的端口是4873
version: '3'
networks:
verdaccio_network:
services:
verdaccio:
image: verdaccio/verdaccio
ports:
- "4873:4873"
networks:
- verdaccio_network
restart: always
container_name: npm
这里有个坑我帮大家踩了, 就是千万不要用nginx反代, 必须直接暴露端口, 否则会导致部分包不能被安装.
解决引用外网包就是使用正向代理, 让我们本地可以通过外网服务器去访问外网的包.
构建正向代理本来用NGINX就可以了, 但是需要安装额外的模块, 否则会导致SSL请求不能被转发.
其中的原理在于nginx服务器在转发请求时, 会拆开请求的包装, 解析里面的内容, 然后再转发, 但SSL加密后NGINX不能解析出请求内容, 所以就会导致转发失败. 但可以安装一个NGINX模块, 该模块的作用就是告诉NGINX直接转发, 不需要拆开包装, 这样就能实现SSL请求可以被转发.
但我使用docker版nginx, 如果要加入该模块比较麻烦, 要重新编译nginx, 所以就放弃了.
于是使用squid作为替代品.
yum install squid
我直接把配置给出, 大家替换掉/etc/squid/squid.conf
路径下的配置就能使用, 暴露的端口是3128
# 允许所有http请求
http_access allow all
# 指定监听IPV4的3128端口
http_port 0.0.0.0:3128
#IPV4优先
dns_v4_first on
#缓存文件夹
coredump_dir /var/spool/squid
这里也有一个坑, 就是squid优先监听的是IPV6, 这个新协议虽然快, 但是兼容性还不是很好, 所以必须强制指定http_port 0.0.0.0:3128
, 才不会出纰漏.
systemctl start squid
# 允许开机启动
systemctl enable squid
systemctl status squid
如下图就启动成功可以使用了
npm config set registry http://<你的IP>:4873
npm config set proxy http://<你的IP>:3128
npm config set https-proxy http://<你的IP>:3128
这里要注意开放firewalld的端口和云服务器自带防火墙的端口
经过以上步骤就能完全解决NPM包安装失败的问题, 让你不再漫长焦急的等待之后, 留下懊恼的泪光.
文章首发于: https://w2fenx.com/284.html
Npm的配置管理及设置代理
CentOS7解决squid只监听ipv6地址问题
搭建自己的私有npm库