Redis缓存核心是解决重复查库和响应慢问题,需设置带过期时间的键、先查缓存后回填、更新时主动删缓存;pub/sub适用于轻量通知;需防范穿透、击穿、雪崩,并通过连接池和序列化优化实战。
缓存不是加个redis.set()就完事。核心是解决「重复查数据库」和「响应慢」问题。比如用户详情页每次打开都查 MySQL,QPS 上去后数据库容易扛不住;而用户资料变化不频繁,完全可以用 Redis 缓存 5 分钟——既减轻数据库压力,又让接口快上几倍。
关键操作有三点:
redis.setex("user:1001", 300, json.dumps(data)),避免缓存永久堆积redis.delete("user:1001"),防止脏数据Redis 的 pub/sub 不是 Kafka,也不保证消息不丢,但它足够简单、低延迟,适合内部通知类需求:比如后台改了配置,通知所有 Web 实例重新加载;或者管理员踢人,实时推下线指令给对应连接。
实际写法很直接:
redis.publish("channel:config_update", "reload")
PubSub 对象,调用 ps.subscribe("channel:config_update"),再循环 ps.get_message() 或用 listen() 阻塞收消息PubSub 和重订阅频道线上出问题,往往不是不会用 Redis,而是没防住这三种典型场景:
redis.setex("user:-1", 60, "null")),或用布隆过滤器前置拦截set nx ex 实现),只让一个请求回源加载,其余等待后读缓存300 + random.randint(0, 60)),错峰失效别在每次操作都新建 Redis 连接——开销大还容易触发连接数上限。用 redis.ConnectionPool 复用连接:
pool = redis.ConnectionPool(host='localhost', port=6379, db=0, max_connections=20)
redis_client = redis.Redis(connection_pool=pool)
存 Python 对象别直接塞字典进去,Redis 只认字节串。推荐用 js(简单结构)或
onpickle(含方法/自定义类,但注意安全):
redis.set("user:1001", json.dumps(data, ensure_ascii=False).encode("utf-8"))
json.loads(redis.get("user:1001"))