++kquote>推荐使用redis-plus-plus库连接Redis,基于hiredis提供同步/异步操作支持。1. 安装libhiredis-dev及redis-plus-plus源码编译;2. 用Redis("tcp://127.0.0.1:6379")创建连接,调用set/get/lpush等方法操作数据;3. 支持String、List、Hash、Set、ZSet等结构,语法类似STL;4. 编译时链接-lredis++ -lhiredis -pthread,确保Redis服务运行并检查防火墙。
在C++中连接和操作Redis数据库,推荐使用 redis-plus-plus 这个现代、易用且功能完整的客户端库。它基于 hiredis(Redis官方C客户端)构建,提供了更友好的C++接口,支持同步、异步操作以及STL容器的自然集成。
在使用之前,需要先安装底层的 hiredis 和 redis-plus-plus 库。
Ubuntu/Debian 系统:打开终端,执行以下命令:
下面是一个简单的同步连接和操作示例:
#include iostream>
#include
using namespace sw::redis;
int main() {
try {
// 创建 Redis 连接对象
auto redis = Redis("tcp://127.0.0.1:6379");
// 设置一个字符串值
redis.set("name", "Tom");
// 获取值
auto val = redis.get("name");
if (val) {
std::cout
} else {
std::cout
}
// 操作 list
redis.lpush("tasks", {"task1", "task2"});
auto tasks = redis.lrange("tasks", 0, -1);
for (const auto &task : tasks) {
std::cout
}
} catch (const RedisError &e) {
std::cerr
}
return 0;
}
redis-plus-plus 支持 Redis 大多数数据结构,可以直接使用类似 STL 的语法:
例如操作 Hash:
redis.hset("user:1001", "name", "Alice");
redis.hset("user:1001", "age", "25");
auto name = redis.hget("user:1001", "name");
if (name) std::cout
编译时需要链接 redis++ 和 hiredis 库:
g++ -std=c++17 main.cpp -lredis++ -lhiredis -pthread -o redis_demo
注意:必须加上 -pthread,因为 redis-plus-plus 内部使用了线程。基本上就这些。只要 Redis 服务正常运行(默认端口 6379),你的 C++ 程序就能成功连接并操作数据。遇到连接失败时,检查 Redis 是否启动(redis-server)以及防火墙设置。