Redis Cluster + Docker + --net=host在 WSL2 下是一个“看起来能跑,实际上必失败”的组合

一、结论

Windows + WSL2 + Docker(Linux 容器)的场景,

因此:

--net=host 绑定的是 WSL2 的 Linux 网络栈,而不是 Windows 主机的 172.18.53.x

这就是为什么:

  • Redis 日志显示:Ready to accept connections

  • 但:ss -lntp | grep 7000

    没有任何输出

  • Windows 上:telnet 172.18.53.x 7000 → 失败

👉 这是 WSL2 网络模型导致的"必然结果",不是 Redis 配置错误。


二、关键证据(你已经无意中暴露了)

这一行信息非常关键:

复制代码

root@DESKTOP-6OOV0C7:/data/redis/cluster#

DESKTOP-xxxx = Windows 主机名

这说明:

  • Redis 实际运行在 WSL2 Linux 虚拟机

  • Docker 的 --net=host

    • 只对 WSL2 内部的 Linux 网络生效

    • 不会绑定 Windows 的物理网卡 IP


三、WSL2 网络模型(这是问题根源)

WSL2 是什么?

一个轻量级虚拟机

网络关系是:

Windows (172.18.53.x)

↑ NAT

WSL2 Linux (172.30.x.x)

Docker container (--net=host)

所以:

以为的 实际发生的
Redis 监听 172.18.53.x Redis 监听 WSL2 的 IP
host 网络 = Windows host host 网络 = WSL2 VM
Windows 可直连 Windows 不能直连

四、为什么 ss -lntp | grep 7000 没输出?

Redis 日志里这行:

* Running mode=cluster, port=7000. * Ready to accept connections

说明:

  • Redis 确实启动了

  • 但它监听的是 WSL2 的某个 IP

  • 而你执行 ss 的环境 不是 Redis 实际监听的网络命名空间

在 WSL2 中,Redis 很可能监听的是:

127.0.0.1:7000 或 172.30.x.x:7000

但你尝试连接的是:

172.18.53.x (Windows IP)

两个世界


五、为什么这件事在 WSL2 下"无解"

❌ 在 WSL2 中,你无法做到:

  • Docker --net=host

  • Redis Cluster

  • Windows 直接通过物理 IP 访问

  • 并且地址还能正确 announce

这四个条件不能同时成立。

Redis Cluster 的前提是:

客户端和节点在同一套地址体系中

WSL2 + Windows 天生违背这个前提。


六、可行的解决方案(按现实可用性排序)

✅ 方案一(强烈推荐,生产级):不用 WSL2

如果你是认真要跑 Redis Cluster(尤其给 Spring Boot 用):

  • 纯 Linux 物理机 / 云服务器

  • Linux 虚拟机

  • Docker + --net=host

👉 这是 唯一与 Redis Cluster 设计完全一致的方式


七、为什么"配置全对但还是不通"

因为:

Redis Cluster 的"网络假设" vs WSL2 的"虚拟化网络"冲突

这不是配置细节问题,是架构层面的不兼容

相关推荐
忆~遂愿1 小时前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊2 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙2 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器
forestsea2 小时前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
佛祖让我来巡山3 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
Zfox_3 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
春日见4 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡4 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
啦啦啦_99994 小时前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学5 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存