登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
业界区
›
安全
›
强制 pnpm 使用 IPv4 而不是 IPv6 的终极解决方案指南 ...
强制 pnpm 使用 IPv4 而不是 IPv6 的终极解决方案指南
[ 复制链接 ]
扈季雅
2025-8-14 09:06:36
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
强制 pnpm 使用 IPv4 而不是 IPv6 的终极解决方案指南
一、问题背景与影响
1.1 为什么会出现 IPv6 问题?
随着 IPv6 的普及,许多域名(如 mirrors.cloud.tencent.com)会同时返回
IPv4(如 101.89.19.12)
和
IPv6(如 240e:95e:4001:1:38::11)
地址。当你的网络环境
不支持 IPv6
或
IPv6 连接不稳定
时,pnpm 默认优先尝试 IPv6 连接会导致以下问题:
安装超时
:pnpm install 卡在 Fetch Metadata 或 Downloading 阶段。
错误提示
:如 connect ETIMEDOUT、getaddrinfo ENOTFOUND 等。
日志分析
:通过 pnpm install --loglevel debug 可看到连接尝试的是 IPv6 地址。
1.2 如何验证 IPv6 问题?
运行以下命令测试:
# 测试 IPv6 连接(可能超时)
ping mirrors.cloud.tencent.com
# 强制使用 IPv4(应正常响应)
ping -4 mirrors.cloud.tencent.com
# 查询域名的 DNS 解析结果
nslookup mirrors.cloud.tencent.com
复制代码
输出示例
:
非权威应答:
名称: mirrors.cloud.tencent.com
Addresses: 240e:95e:4001:1:38::11 # IPv6(可能不可用)
101.89.19.12 # IPv4(可用)
复制代码
二、解决方案详解
方法 1:通过 NODE_OPTIONS 强制 Node.js 优先 IPv4(推荐)
原理
:pnpm 基于 Node.js,可通过环境变量调整 DNS 解析顺序。
适用场景
:临时测试或快速修复,无需修改系统配置。
操作步骤
:
# Linux/macOS(终端临时生效)
export NODE_OPTIONS="--dns-result-order=ipv4first"
pnpm install
# Windows PowerShell
$env:NODE_OPTIONS="--dns-result-order=ipv4first"
pnpm install
# Windows CMD
set NODE_OPTIONS=--dns-result-order=ipv4first
pnpm install
复制代码
永久生效配置
:
Linux/macOS
:将 export NODE_OPTIONS="--dns-result-order=ipv4first" 添加到 ~/.bashrc 或 ~/.zshrc。
Windows
:通过系统属性 → 环境变量添加 NODE_OPTIONS。
方法 2:修改 Hosts 文件固定 IPv4 地址
原理
:绕过 DNS 解析,直接绑定域名到 IPv4。
适用场景
:长期稳定使用,避免 DNS 返回 IPv6。
操作步骤
:
查询镜像的 IPv4 地址
:
nslookup mirrors.cloud.tencent.com
复制代码
记录输出的 IPv4 地址(如 101.89.19.12)。
编辑 Hosts 文件
:
Windows
:
以管理员身份打开记事本,编辑 C:\Windows\System32\drivers\etc\hosts。
添加一行:
101.89.19.12 mirrors.cloud.tencent.com
复制代码
Linux/macOS
:
sudo nano /etc/hosts
复制代码
添加相同内容后保存。
刷新 DNS 缓存
:
Windows
:
ipconfig /flushdns
复制代码
macOS
:
sudo dscacheutil -flushcache
复制代码
Linux
:
sudo systemd-resolve --flush-caches
复制代码
方法 3:切换到纯 IPv4 的镜像源
原理
:使用国内镜像源(如淘宝、华为云),默认优先 IPv4。
适用场景
:国内开发者,兼顾速度和稳定性。
常用镜像源列表
:
镜像源地址特点
淘宝 npm 镜像
https://registry.npmmirror.com国内最快,默认 IPv4
阿里云镜像
https://registry.npm.aliyun.com企业级稳定
华为云镜像
https://mirrors.huaweicloud.com/repository/npm/适合华为生态用户
切换命令
:
pnpm config set registry https://registry.npmmirror.com
复制代码
验证是否生效
:
pnpm config get registry
复制代码
方法 4:调整系统 DNS 解析优先级
Windows 系统
禁用 IPv6 DNS 解析
:
打开
控制面板 > 网络和 Internet > 网络和共享中心
。
点击当前网络 →
属性
→ 取消勾选
Internet 协议版本 6 (TCP/IPv6)
。
或保留 IPv6 但调整 DNS 顺序:
双击
IPv4
→
高级
→
DNS
选项卡 → 将 IPv4 DNS 服务器移到顶部。
使用 IPv4 专用 DNS
:
推荐 DNS:
8.8.4.4(Google Public DNS IPv4)
114.114.114.114(国内 114 DNS)
Linux/macOS 系统
编辑 /etc/gai.conf,取消注释以下行(强制 IPv4 优先):
precedence ::ffff:0:0/96 100
复制代码
然后重启网络:
# Linux(Systemd)
sudo systemctl restart NetworkManager
# macOS
sudo killall -HUP mDNSResponder
复制代码
方法 5:彻底禁用 IPv6(终极方案)
适用场景
:网络环境完全不支持 IPv6,且其他方法无效。
Windows
以管理员身份运行 CMD:
netsh interface ipv6 set global state=disabled
复制代码
重启电脑生效。
Linux
编辑 /etc/sysctl.conf,添加:
net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
复制代码
执行生效:
sudo sysctl -p
复制代码
macOS
networksetup -setv6off Wi-Fi # 替换 Wi-Fi 为你的网络接口名
复制代码
三、验证解决方案是否生效
3.1 检查连接日志
pnpm install --loglevel debug | grep -i "connect"
复制代码
正常输出应显示 IPv4 地址(如 101.89.19.12:443)。
3.2 测试网络连通性
# 测试 IPv4 连接
curl -v https://registry.npmmirror.com/node-opcua
# 测试端口是否开放
telnet 101.89.19.12 443
复制代码
3.3 使用 tcpdump 抓包分析(高级)
# Linux/macOS
sudo tcpdump -i any host 101.89.19.12 and port 443 -nn
复制代码
观察是否有 IPv6 流量(以 :: 开头的地址)。
四、常见问题解答
Q1:为什么修改 Hosts 后仍然无效?
可能原因
:
Hosts 文件权限不足(需管理员权限编辑)。
系统 DNS 缓存未刷新(执行 ipconfig /flushdns 或重启网络)。
镜像源更换了 IPv4 地址(需重新查询 nslookup)。
Q2:禁用 IPv6 会影响其他服务吗?
影响范围
:
仅影响依赖 IPv6 的服务(如某些企业内部系统)。
现代网站(如 Google、GitHub)均支持 IPv4,可正常访问。
Q3:如何恢复 IPv6?
Windows
:
netsh interface ipv6 set global state=enabled
复制代码
Linux
:
sed -i 's/net.ipv6.conf.all.disable_ipv6 = 1/#net.ipv6.conf.all.disable_ipv6 = 1/' /etc/sysctl.conf
sudo sysctl -p
复制代码
五、总结与推荐
方法复杂度持久性适用场景
NODE_OPTIONS
★☆☆临时快速测试
修改 Hosts
★★☆持久长期稳定
切换镜像源
★☆☆持久国内用户首选
调整 DNS 优先级
★★★系统级全局修改
禁用 IPv6
★★★永久终极方案
推荐流程
:
尝试 NODE_OPTIONS="--dns-result-order=ipv4first" pnpm install。
若无效,切换到淘宝镜像 pnpm config set registry https://registry.npmmirror.com。
仍有问题时,修改 Hosts 文件或禁用 IPv6。
通过以上方法,你可以彻底解决 pnpm 因 IPv6 导致的安装失败问题!
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
强制
pnpm
使用
IPv4
不是
相关帖子
使用 OpenSpec + 提示词工程 + Harness 思维,构建一站式多 Agent 研发流程
使用fetchEventSource构建高效AI智能助手:文件搜索场景的完整实现与深度解析
【ESP32】ESP32 使用 MQTT 连接华为云 IoT (MQTT.fx 篇) —— 1
如何使用 UEFI Shell 执行 Hello World 程序
使用vue3+ts构建企业级文件传输管理系统:状态管理、性能优化与用户体验的深度实践
gitee使用教程
使用PHP对接韩国股票市场API 实时数据、IPO和K线(Kline)的PHP对接方案
使用Java对接印度股票市场API 实时数据、IPO和K线(Kline)的PHP对接方案
【ESP32】使用 MQTT(S) 连接华为云 IoT
从分形到森林——使用 Three.js 创建逼真的 3D 树木
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
使用 OpenSpec + 提示词工程 + Harness 思维,构建一站式多 Agent 研发流程
1
515
啦迩
2026-03-31
业界
使用fetchEventSource构建高效AI智能助手:文件搜索场景的完整实现与深度解析
0
129
胁冉右
2026-04-01
安全
【ESP32】ESP32 使用 MQTT 连接华为云 IoT (MQTT.fx 篇) —— 1
1
663
玲液
2026-04-01
业界
如何使用 UEFI Shell 执行 Hello World 程序
2
700
剽达崖
2026-04-01
业界
使用vue3+ts构建企业级文件传输管理系统:状态管理、性能优化与用户体验的深度实践
0
361
万俟谷雪
2026-04-02
安全
gitee使用教程
1
31
醋辛
2026-04-02
安全
使用PHP对接韩国股票市场API 实时数据、IPO和K线(Kline)的PHP对接方案
0
790
锟及
2026-04-02
安全
使用Java对接印度股票市场API 实时数据、IPO和K线(Kline)的PHP对接方案
1
65
湄圳啸
2026-04-04
安全
【ESP32】使用 MQTT(S) 连接华为云 IoT
1
121
缀访
2026-04-05
业界
从分形到森林——使用 Three.js 创建逼真的 3D 树木
0
259
豹筒生
2026-04-06
回复
(31)
伏滢
2025-10-19 01:09:38
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢分享,学习下。
撷监芝
2025-11-6 11:09:25
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
这个好,看起来很实用
窝酴
2025-11-14 23:34:11
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
不错,里面软件多更新就更好了
缀访
2025-11-27 20:04:45
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢,下载保存了
丘娅楠
2026-1-2 08:40:37
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,辛苦了
伯斌
2026-1-2 21:21:08
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
分享、互助 让互联网精神温暖你我
司空娅玲
2026-1-9 18:27:30
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
yyds。多谢分享
冷晓晴
2026-1-17 09:46:49
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
前排留名,哈哈哈
尹疋
2026-1-18 19:59:22
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢楼主提供!
愤血冒
2026-1-18 20:48:17
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
用心讨论,共获提升!
巩芷琪
2026-1-21 23:31:04
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢分享
梦霉
2026-1-23 09:31:04
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢楼主提供!
焦听云
2026-1-24 19:06:52
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢分享
揉幽递
2026-1-24 23:11:54
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢分享,辛苦了
襁壮鸢
2026-1-25 23:16:44
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢楼主提供!
烯八
2026-1-28 05:09:18
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
东西不错很实用谢谢分享
粒浊
2026-1-30 04:32:49
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
收藏一下 不知道什么时候能用到
讥慰捷
2026-2-2 03:53:42
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
分享、互助 让互联网精神温暖你我
诸婉丽
2026-2-4 05:16:30
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
过来提前占个楼
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
业界
科技
程序
代码
软件
签约作者
程序园优秀签约作者
发帖
扈季雅
2026-2-4 05:16:30
关注
0
粉丝关注
28
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991126
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
神泱
9517
6
韶又彤
9909
7
荪俗
8991
8
宋子
9875
9
蓬森莉
9868
10
俞瑛瑶
10000
查看更多
今日好文热榜
294
程序员AI编程之提示词【学习笔记】
802
Tcache attack
850
AgileAI - 一个新的 .NET AI 库
301
OpenClaw AI助手本地部署完整教程
24
AI 编程助手 + 基于 CLI 的 Manus 实现(Ja
716
React 技术深度探讨
259
从分形到森林——使用 Three.js 创建逼真的
563
React 技术深度探讨
1002
React 技术深度探讨
470
【读书笔记】【CUDA编程指南】CUDA简介
870
React 技术深度探讨
6
hal库总结学习
931
"Natural-Language Agent Harnesses" 论文
846
自我即自感:一种极简存在论
79
Microsoft Agent Framework + Kimi API 实
354
【节点】[Posterize节点]原理解析与实际应
6
【小记】解决校园网中单播互通的不同子网间
760
GitHub 热门项目 Top 10 | 2026 年 04 月 0
196
Spring Cloud Gateway实战:微服务API网关
791
罗兰艺境GEO内容工程实战复盘:CSDN 92分技