引言
在微服务架构中,redis 是一种常见的高效缓存解决方案,通常用于存储临时数据、会话信息或 token。如何在服务容器中高效、稳定地连接 redis 是架构设计中的一个重要环节。
这篇博客将以实际项目为例,详细介绍如何配置 flask 应用中的服务容器连接宿主机上的 redis 服务.
一、服务架构概述
通常,我们的应用程序运行在容器中,而 redis 可以运行在宿主主机上或者单独的容器内。为了避免不必要的端口映射和复杂的网络配置,以下介绍的是如何通过容器中的 flask 应用连接宿主机上的 redis 服务。
架构图可以简单地表示为:
+-----------------+ +-----------------+
| | | |
| flask 容器 | ---> | redis 服务 (宿主机)|
| | | |
+-----------------+ +-----------------+
二、redis 容器与 flask 服务容器的网络配置
宿主机上 redis 服务的配置
首先,我们需要在宿主机上运行 redis 并确保其对外开放接口,允许来自容器的连接。
安装 redis (如果尚未安装):
sudo apt-get install redis-server
配置 redis 监听所有接口: 打开 redis 的配置文件 /etc/redis/redis.conf,确保 bind 选项设置为 0.0.0.0,允许来自外部的连接:
bind 0.0.0.0
并确保将 redis 配置为带有密码保护:
requirepass 123...
重启 redis 服务:
sudo systemctl restart redis-server
允许防火墙端口: 开放 redis 的端口 6379,确保 flask 容器可以连接:
sudo ufw allow 6379
三、flask 服务容器如何连接 redis
当 redis 在宿主主机上运行时,flask 容器需要通过宿主机的 ip 地址来连接到 redis 服务。假设宿主机的 ip 地址为 172.29.11.11,以下是如何在 flask 应用中配置 redis 连接。
1. redis 连接配置
在 flask 应用的代码中,我们通过 redis.strictredis 来连接 redis。
import redis
# 配置 redis 连接
redis_client = redis.strictredis(
host='172.29.11.11', # 宿主机的 ip 地址
port=6379, # redis 端口
password='123...', # redis 的密码
db=0, # 默认数据库
decode_responses=true, # 自动解码 redis 响应
socket_timeout=5 # 设置超时时间
)2. flask 容器的运行
假设你已经有了一个 flask 服务的 docker 容器,运行该容器时的命令如下:
docker run -d --name myapp -p 5000:5000 \
-e redis_host=172.29.11.11 \
${{ secrets.docker_hub_username }}/myapp:${{ github.sha }}这个命令使用环境变量 redis_host 将 redis 的宿主机 ip 地址注入到容器中。在 flask 应用中,你也可以通过读取这个环境变量来动态配置 redis 连接。
import os
redis_client = redis.strictredis(
host=os.getenv('redis_host', 'localhost'), # 通过环境变量读取 redis 地址
port=6379,
password='123...',
db=0,
decode_responses=true,
socket_timeout=5
)总结:从容器中连接宿主主机的最佳实践
- 网络配置:确保宿主机的 redis 监听所有接口 (
0.0.0.0) 并开放了防火墙端口。 - 连接方式:使用宿主机的 ip 地址来连接 redis,而不是
localhost。 - 安全性:通过密码 (
requirepass) 来确保 redis 连接的安全性。
以上就是docker容器高效连接redis的方法步骤的详细内容,更多关于docker容器连接redis的资料请关注代码网其它相关文章!
发表评论