【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 服务器的连接
相关推荐
这个DBA有点耶4 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶6 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技6 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend7 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence10 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
orion571 天前
Missing Semester Class1:course overview and introduction of shell
linux
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
用户120487221611 天前
Linux驱动编译与加载
linux·嵌入式