【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 服务器的连接
相关推荐
瑾曦3 分钟前
Docker相关命令
linux
正在走向自律5 分钟前
X2Doris是SelectDB可视化数据迁移工具,安装与部署&使用手册,轻松进行大数据迁移
数据库·数据迁移·selectdb·x2doris·数据库迁移工具
发抖吧小喵喵6 分钟前
rpm包直接安装新系统缺少依赖问题处理
linux·运维·服务器
凤年徐9 分钟前
【数据结构与算法】21.合并两个有序链表(LeetCode)
c语言·数据结构·c++·笔记·算法·链表
tuokuac9 分钟前
SQL中的LEFT JOIN
数据库·sql
tuokuac13 分钟前
SQL中的GROUP BY用法
数据库·sql
爱吃小土豆豆豆豆18 分钟前
登录校验一
java·大数据·数据库
jdlxx_dongfangxing23 分钟前
2024 年 NOI 最后一题题解
c++·noi
码农101号36 分钟前
Linux中Docker Swarm介绍和使用
linux·spring cloud·docker
Nazi637 分钟前
dockerfile基础
linux·运维·docker·容器·云计算