相关文章推荐
腼腆的炒粉  ·  代理服务器之 ...·  5 天前    · 
从未表白的毛衣  ·  Python ...·  1 月前    · 
另类的麦片  ·  一种 float 和 int ...·  11 月前    · 

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

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

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

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

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

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

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

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

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

下面是docker-compose.yml的配置文件, 大家直接用 docker-compose -f <docker-compose.yml文件路径> 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如何使用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安装node包时会出现卡顿, 这是因为NPM服务器在国外的原因, 常规的解决方法是把官方npm仓库换成淘宝npm仓库.这种方法能解决大部分NPM包卡顿的现象, 但是不能根除, 这里存在着两个原因.一个原因是淘宝源被大量人使用, 有时候会不太好用, 这个原因倒是很容易解决, 多试试就行.另一个原因才是最麻烦的, 那就是NPM包自身可能引用外网的其他包, 这样就算更换再多的仓库也没用.基于以上原因, 我参考了网上许多资料, 给出了一个终极解决方案. 这个方案分为两部分, 一个是解决淘 npm install --unsafe-perm npm 出于安全考虑不支持以 root 用户运行,即使你用 root 用户身份运行了,npm 会自动转成一个叫 nobody 的用户来运行,而这个用户几乎没有任何权限。这样的话如果你脚本里有一些需要权限的操作,比如写文件(尤其是写 /root/.node-gyp),就会崩掉了。 为了避免这种情况,要么按照 npm 的规矩来,专门建一个用于运行 npm 的高 npm ERR! code ETIMEDOUT npm ERR! errno ETIMEDOUT npm ERR! network request to https://registry.npm.taobao.org/clipboard failed, reason: connect ETIMEDOUT 112.54.108.89: npm ERR! network This is a problem related to network connecti 解压安装后一直点next安装,一直等到安装结束就是安装完成。 三、配置nvm 安装完成后再开始配置,安装nvm的过程中会自动配置环境变量,如没用配置,请参考下图: 1.方法一:有可能会出错的安装方式