NPM包安装失败的终极解决方案

相信很多人使用npm安装node包时会出现卡顿, 这是因为NPM服务器在国外的原因, 常规的解决方法是把官方npm仓库换成淘宝npm仓库.

这种方法能解决大部分NPM包卡顿的现象, 但是不能根除, 这里存在着两个原因.

一个原因是淘宝源被大量人使用, 有时候会不太好用, 这个原因倒是很容易解决, 多试试就行.

另一个原因才是最麻烦的, 那就是NPM包自身可能引用外网的其他包, 这样就算更换再多的仓库也没用.

基于以上原因, 我参考了网上许多资料, 给出了一个终极解决方案. 这个方案分为两部分, 一个是解决淘宝源不稳定的问题, 另一个是解决引用
外网包的问题.

不过解决以上问题的前提是需要一个能连外网的服务器.

解决淘宝NPM仓库不稳定的问题

其实解决这个问题很简单, 既然淘宝NPM仓库不稳定, 那么就自己搭建一个NPM仓库.

其实已经有了现成的NPM仓库, 我们只需要拿来用就行, 这里使用docker和docker-compose搭建.

下面是docker-compose.yml的配置文件, 大家直接用docker-compose -f up -d --build启动就行, 开放的端口是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作为替代品.

安装squid

yum install squid

配置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, 才不会出纰漏.

启动squid

systemctl start squid
# 允许开机启动
systemctl enable squid

检查squid的状态

systemctl status squid

如下图就启动成功可以使用了

NPM包安装失败的终极解决方案_第1张图片

NPM如何使用verdaccio和squid

  1. 设置NPM仓库
npm config set registry http://<你的IP>:4873

  1. 设置NPM代理
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库

你可能感兴趣的:(npm,nginx,前端)