使用hiredis库连接Redis,首先安装并链接库,通过redisConnect建立连接,用redisCommand执行命令并检查reply类型获取结果,每次操作后调用freeReplyObject释放内存,程序结束前调用redisFree关闭连接,注意定期检查context->err状态以实现重连,确保稳定通信。

在C++中连接和操作Redis,最常用的方式是使用hiredis库。hiredis是Redis官方推荐的C语言客户端库,C++项目可以通过它与Redis进行高效通信。下面介绍如何使用hiredis实现基本的连接、数据操作和断开流程。
安装hiredis库
在开始前,需要先安装hiredis。大多数Linux系统可通过包管理器安装:
# Ubuntu/Debian sudo apt-get install libhiredis-devCentOS/RHEL
sudo yum install hiredis-devel
或从源码编译
git clone https://www.php.cn/link/a854d36a4afe77df29f4c42eb35af078 cd hiredis make && sudo make install
编译C++程序时需链接hiredis库:
立即学习“C++免费学习笔记(深入)”;
g++ your_program.cpp -lhiredis连接Redis服务器
使用hiredis连接Redis非常直接。主要通过redisConnect函数建立TCP连接:
示例代码:
#include#include int main() { redisContext *context = redisConnect("127.0.0.1", 6379); if (context == nullptr || context->err) { if (context) { std::cerr << "连接错误: " << context->errstr << std::endl; } else { std::cerr << "无法分配redis上下文" << std::endl; } return 1; }
std::cout zuojiankuohaophpcnzuojiankuohaophpcn "成功连接到Redis!" zuojiankuohaophpcnzuojiankuohaophpcn std::endl; // 后续操作... redisFree(context); // 释放连接 return 0;}
说明:context是核心结构体,代表与Redis的连接。连接失败时,err字段非零,errstr包含错误信息。
执行Redis命令并获取结果
使用redisCommand发送命令并接收回复。返回值为redisReply*类型,需根据type判断结果类型。
常见操作示例:
redisReply *reply = (redisReply*)redisCommand(context, "SET name 'Alice'");
if (reply->type == REDIS_REPLY_STATUS) {
std::cout << "SET状态: " << reply->str << std::endl;
}
freeReplyObject(reply);
reply = (redisReply*)redisCommand(context, "GET name");
if (reply->type == REDIS_REPLY_STRING) {
std::cout << "GET name = " << reply->str << std::endl;
}
freeReplyObject(reply);
reply = (redisReply*)redisCommand(context, "INCR counter");
if (reply->type == REDIS_REPLY_INTEGER) {
std::cout << "counter新值: " << reply->integer << std::endl;
}
freeReplyObject(reply);
注意:每次调用redisCommand后必须调用freeReplyObject释放回复对象,避免内存泄漏。
处理异常与关闭连接
网络中断或Redis宕机可能导致连接失效。建议在关键操作前后检查context状态:
- 定期检查
context->err是否非零 - 若出错,释放旧context并尝试重连
- 程序结束前调用
redisFree(context)
简单重连逻辑:
if (context->err) {
redisFree(context);
context = redisConnect("127.0.0.1", 6379);
}
基本上就这些。hiredis轻量且稳定,适合大多数C++项目的Redis接入需求。只要注意连接管理和内存释放,就能安全高效地操作Redis。对于更复杂的场景(如异步通信),可考虑hiredis的异步API或封装更好的C++库如redox。










