【redis】redis和hiredis的基本使用

总结:

介绍了一下redis和hiredis的安装步骤,用一个简单的demo演示了使用redis的基本过程。

启动redis步骤

1、下载redis:https://github.com/redis/redis

2、编译命令:make

3、编译产物:libredis.a(静态库)和可执行文件( redis-server

4、运行redis服务:./redis-server

使用hiredis(redis客户端)连接redis

1、下载hiredis:https://github.com/redis/hiredis/tree/v1.3.0

2、编译命令:

bash 复制代码
make
sudo make install
sudo ldconfig

3、编写一个简单的demo

cpp 复制代码
#include <iostream>
#include <string>
extern "C" {
    #include <hiredis/hiredis.h>
}

int main() {
    // 连接 Redis 服务器
    redisContext* context = redisConnect("127.0.0.1", 6379);
    if (context == nullptr || context->err) {
        if (context) {
            std::cerr << "连接错误: " << context->errstr << std::endl;
            redisFree(context);
        } else {
            std::cerr << "无法分配 Redis 连接上下文" << std::endl;
        }
        return 1;
    }
    std::cout << "成功连接到 Redis 服务器" << std::endl;

    // 执行 SET 命令
    redisReply* reply = static_cast<redisReply*>(redisCommand(context, "SET mykey %s", "Hello, Redis!"));
    if (reply == nullptr) {
        std::cerr << "执行 SET 命令失败" << std::endl;
        redisFree(context);
        return 1;
    }

    // 检查 SET 命令结果
    if (reply->type == REDIS_REPLY_STATUS && std::string(reply->str) == "OK") {
        std::cout << "SET 命令执行成功" << std::endl;
    } else {
        std::cerr << "SET 命令执行失败: " << reply->str << std::endl;
    }
    freeReplyObject(reply);

    // 执行 GET 命令
    reply = static_cast<redisReply*>(redisCommand(context, "GET mykey"));
    if (reply == nullptr) {
        std::cerr << "执行 GET 命令失败" << std::endl;
        redisFree(context);
        return 1;
    }

    // 检查 GET 命令结果
    if (reply->type == REDIS_REPLY_STRING) {
        std::cout << "GET 结果: " << reply->str << std::endl;
    } else {
        std::cerr << "GET 命令执行失败,非预期的回复类型" << std::endl;
    }
    freeReplyObject(reply);

    // 执行 INCR 命令(演示数值操作)
    reply = static_cast<redisReply*>(redisCommand(context, "INCR counter"));
    if (reply == nullptr) {
        std::cerr << "执行 INCR 命令失败" << std::endl;
        redisFree(context);
        return 1;
    }

    // 检查 INCR 命令结果(整数类型)
    if (reply->type == REDIS_REPLY_INTEGER) {
        std::cout << "INCR 结果: " << reply->integer << std::endl;
    }
    freeReplyObject(reply);

    // 释放连接
    redisFree(context);
    std::cout << "已断开与 Redis 服务器的连接" << std::endl;
    return 0;
}

代码说明:

  • 连接部分 :使用 redisConnect 连接到本地 Redis 服务器(默认ip地址是127.0.0.1,端口6379)
  • 错误处理:检查连接是否成功,并处理可能的错误
  • 命令执行 :使用 redisCommand 执行 Redis 命令,如 SET、GET、INCR
  • 结果解析 :根据 redisReply 的类型判断命令执行结果
  • 资源释放 :使用 freeReplyObject 释放回复对象,使用 redisFree 释放连接

4、编译:g++ -o main main.cpp -lhiredis

5、运行程序:./redis_demo

6、日志输出:

复制代码
成功连接到 Redis 服务器
SET 命令执行成功
GET 结果: Hello, Redis!
INCR 结果: 1
已断开与 Redis 服务器的连接
相关推荐
jiayou642 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
Johny_Zhao13 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
NineData14 小时前
NineData 迁移评估功能正式上线
数据库·dba
雨中飘荡的记忆18 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
NineData19 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师21 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
blasit21 小时前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
曲幽1 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库