Docker环境中Redis连接三种场景的配置指南

 更新时间:2026年06月02日 08:46:58   作者:取经蜗牛  
本指南详细说明如何将docker项目原本redis服务连接到 三种不同位置的 Redis 服务,并屏蔽项目自带的 Redis 容器,需要的朋友可以参考下

所有操作前请备份 docker-compose.yml 和 .env 文件。

场景一:连接到 Ubuntu 物理机上的 Redis

适用情况:Redis 直接安装在宿主机(独立的 Ubuntu 物理机或虚拟机)上,Docker 运行在该宿主机上。

1. 检查宿主机 Redis 配置

确保宿主机 Redis 允许 Docker 容器访问(默认只监听 127.0.0.1):

# 查看监听地址
sudo netstat -tlnp | grep 6379

如果只显示 127.0.0.1:6379,请修改 /etc/redis/redis.conf

bind 0.0.0.0          # 允许所有连接
# 或 bind 127.0.0.1 172.17.0.1   # 仅允许 Docker 网桥

重启 Redis:

sudo systemctl restart redis-server

2. 修改docker-compose.yml

2.1 删除内部 Redis 服务

找到文件中的 redis: 块(约第 158 行),删除或注释。

2.2 删除app服务中的 Redis 依赖

app 服务的 depends_on: 中删除 redis: 条目。

2.3 修改app的环境变量

app:
  environment:
    # 将 REDIS_ADDR 改为宿主机 IP(Docker 网桥网关)
    - REDIS_ADDR=172.17.0.1:6379
    # 如果宿主机 Redis 有密码,确保 .env 中 REDIS_PASSWORD 正确
    - REDIS_PASSWORD=${REDIS_PASSWORD}
    - REDIS_DB=0

说明172.17.0.1 是 Docker 默认网桥的网关地址,始终指向宿主机。也可以使用宿主机的物理 IP(如 192.168.1.100),但可能因 DHCP 变化而不稳定。

2.4 确保.env中的密码匹配

REDIS_PASSWORD=your_redis_password

3. 重新部署

docker compose down
docker compose up -d

4. 验证

# 进入 app 容器测试(容器内可能没有 nc/redis-cli,可用 Python)
docker exec WeKnora-app python3 -c "import socket; s=socket.socket(); s.connect(('172.17.0.1',6379)); print('OK')"

场景二:连接到 WSL 环境中的 Redis 服务

适用情况:Docker 运行在 WSL2 的 Linux 发行版中,Redis 安装在同一个 WSL 实例内(作为宿主机)。

说明:在 WSL 环境中,Docker 容器与 WSL 宿主机共享内核,但网络栈是隔离的。容器访问 WSL 宿主机的服务需要使用 WSL 实例的 IP 或 Docker 网关 IP。

1. 检查 WSL 中 Redis 的监听配置

WSL 中的 Redis 默认只监听 127.0.0.1,需要修改为监听 0.0.0.0 或至少 Docker 网桥 IP:

sudo vi /etc/redis/redis.conf

修改:

bind 0.0.0.0

重启 Redis:

sudo systemctl restart redis-server

2. 修改docker-compose.yml

2.1 删除内部 Redis 服务及依赖(同场景一)

2.2 修改app环境变量

WSL 中有两种可靠的地址:

地址说明
172.17.0.1Docker 网桥网关,始终可达
host.docker.internal需要 extra_hosts 支持(你的配置已添加)

推荐使用 172.17.0.1

app:
  environment:
    - REDIS_ADDR=172.17.0.1:6379
    - REDIS_PASSWORD=${REDIS_PASSWORD}
    - REDIS_DB=0

如果希望使用 host.docker.internal(你的 extra_hosts 已配置),也可:

- REDIS_ADDR=host.docker.internal:6379

3. 重新部署并验证

docker compose down
docker compose up -d

# 测试连通性
docker exec WeKnora-app sh -c "echo 'PING' | timeout 2 nc 172.17.0.1 6379"

场景三:连接到指定 Docker 容器中的 Redis 服务

适用情况:已有一个独立的 Redis 容器(如 xiaozhi-esp32-server-redis),希望 WeKnora 共用。

1. 确认外部 Redis 容器信息

docker ps | grep redis

记下容器名(例如 xiaozhi-esp32-server-redis)及其密码(通过查看启动命令或进入容器获取)。

2. 将外部 Redis 容器加入 WeKnora 的项目网络

WeKnora 项目使用自定义网络 WeKnora-network(实际名称可能带项目前缀)。先查看实际网络名:

docker network ls | grep WeKnora
# 假设输出:weknora-main_WeKnora-network

连接外部容器到该网络:

docker network connect weknora-main_WeKnora-network xiaozhi-esp32-server-redis

3. 修改docker-compose.yml

3.1 删除内部 Redis 服务及依赖(同前)

3.2 修改app环境变量

app:
  environment:
    - REDIS_ADDR=xiaozhi-esp32-server-redis:6379   # 使用容器名
    - REDIS_PASSWORD=${REDIS_PASSWORD}             # 必须与外部 Redis 密码一致
    - REDIS_DB=0

3.3 如果外部 Redis 有密码,更新.env

REDIS_PASSWORD=external_redis_password

4. 重新部署并验证

docker compose down
docker compose up -d

# 验证 DNS 解析和连接
docker exec WeKnora-app ping -c 1 xiaozhi-esp32-server-redis
docker exec WeKnora-app python3 -c "import socket; s=socket.socket(); s.connect(('xiaozhi-esp32-server-redis',6379)); print('OK')"

通用注意事项

  1. 删除内部 Redis 后docker-compose.ymlredis: 整个块必须删除或注释,否则 Compose 仍会创建容器。
  2. 依赖关系:务必删除 app 服务的 depends_on 中的 redis: 条目,否则启动时会等待不存在的服务。
  3. 密码一致性:外部 Redis 如有密码,.env 中的 REDIS_PASSWORD 必须完全一致(包括大小写、特殊字符)。无密码则留空:REDIS_PASSWORD=
  4. 数据库编号:通过 REDIS_DB 选择数据库,默认为 0。如果外部 Redis 的 DB0 已被其他应用占用,可改为 1,但需确保 WeKnora 支持。
  5. Langfuse 等可选服务:如果启用了 --profile langfuse--profile fulllangfuse-workerlangfuse-web 也依赖 Redis,它们通过 REDIS_CONNECTION_STRING 连接,需要同步修改。如果未启用,可忽略。
  6. 网络稳定性
    • 场景一、二中,宿主机 IP(172.17.0.1)在 Docker 重启后可能改变(极少见),建议使用 host.docker.internal(需 extra_hosts 支持,你的配置已提供)。
    • 场景三中,容器名解析依赖 Docker 内置 DNS,只要容器在同一网络即可。
  7. 安全建议
    • 避免将 Redis 暴露到公网。
    • 生产环境务必设置强密码,并考虑使用 Docker 网络隔离。

附录:快速比对表

场景REDIS_ADDR需要额外操作验证命令
物理机 Redis172.17.0.1:6379宿主机IP修改 Redis 监听 0.0.0.0docker exec WeKnora-app python3 -c "import socket; socket.create_connection(('172.17.0.1',6379),2)"
WSL 中 Redis172.17.0.1:6379host.docker.internal:6379修改 Redis 监听 0.0.0.0同上
外部 Redis 容器<容器名>:6379将容器加入 WeKnora-networkdocker exec WeKnora-app sh -c "echo PING | nc <容器名> 6379"

以上就是Docker环境中Redis连接三种场景的配置指南的详细内容,更多关于Docker Redis连接的三种场景的资料请关注脚本之家其它相关文章!

相关文章

  • docker的具名挂载与匿名挂载实现

    docker的具名挂载与匿名挂载实现

    本文主要介绍了docker的具名挂载与匿名挂载实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Dockerfile的使用及docker部署java项目实践

    Dockerfile的使用及docker部署java项目实践

    Docker通过Dockerfile构建自定义镜像,简化部署流程,主要指令包括FROM、RUN、CMD、ENTRYPOINT、ENV、ADD、COPY、VOLUME、WORKDIR和USER,构建Java环境需准备目录、Dockerfile、JDK和jar文件,执行构建命令并验证部署
    2026-03-03
  • docker如何查看容器/删除(所有)容器/删除镜像

    docker如何查看容器/删除(所有)容器/删除镜像

    这篇文章主要介绍了docker如何查看容器/删除(所有)容器/删除镜像问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Docker 部署net5程序实现跨平台功能

    Docker 部署net5程序实现跨平台功能

    本文讲述使用docker容器部署.net5项目、实现跨平台,本文通过图文的形式给大家介绍了创建.net5项目的过程及安装成功后如何使用docker部署项目,感兴趣的朋友跟随小编一起学习吧
    2021-05-05
  • docker配置skywalking 监控springcloud应用的详细步骤

    docker配置skywalking 监控springcloud应用的详细步骤

    本文分步骤给大家讲解docker配置skywalking 监控springcloud应用的方法,感兴趣的朋友一起看看吧
    2025-04-04
  • Docker删除某个镜像的实现方法

    Docker删除某个镜像的实现方法

    在使用 Docker 时,经常需要删除不再需要的镜像、容器和卷,以释放存储空间,本文主要介绍了Docker删除某个镜像的实现方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • jenkins如何进行自动化部署

    jenkins如何进行自动化部署

    这篇文章主要介绍了jenkins如何进行自动化部署问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • Linux下Docker CE使用从包中安装的方式详解

    Linux下Docker CE使用从包中安装的方式详解

    这篇文章主要为大家详细介绍了Linux下Docker CE使用从包中安装的方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • Docker desktop中文设置方法步骤

    Docker desktop中文设置方法步骤

    这篇文章主要给大家介绍了关于Docker desktop中文设置的方法步骤,Docker Desktop默认使用英文界面,要设置为中文界面,请按照以下步骤操作,需要的朋友可以参考下
    2024-03-03
  • docker客户端访问harbor及安装配置更新

    docker客户端访问harbor及安装配置更新

    这篇文章主要介绍了docker客户端访问harbor以及harbor的安装配置更新步骤详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12

最新评论