当前位置: 首页 > web >正文

【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、编译命令:

make
sudo make install
sudo ldconfig

3、编写一个简单的demo

#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 服务器的连接
http://www.xdnf.cn/news/8803.html

相关文章:

  • RabbitMQ 可靠性保障:消息确认与持久化机制(一)
  • day01
  • 算法打卡第六天
  • C++23 对部分特性的 constexpr 支持
  • 历年华南理工大学保研上机真题
  • 阿里千问系列:Qwen3技术报告解读(下)
  • 美团2025年校招笔试真题手撕教程(二)
  • 第一章 半导体基础知识
  • 腾讯云国际站可靠性测试
  • 13软件测试用例设计方法-场景法
  • UnLua源码分析(二)IUnLuaInterface
  • 并发编程(6)
  • Lua5.4.2常用API整理记录
  • 基于Python的分布式网络爬虫系统设计与实现
  • DAY33 简单神经网络
  • MongoDB 错误处理与调试完全指南:从入门到精通
  • 字符集和字符编码
  • 使用Arduino UNO复活电脑的风扇
  • CI/CD (持续集成/持续部署) GitHub Actions 自动构建
  • 【Linux】进程问题--僵尸进程
  • Github Actions工作流入门
  • 详解3DGS
  • MySQL---库操作
  • 深入解析MongoDB WiredTiger存储引擎:原理、优势与最佳实践
  • 如何通过API接口实现自动化上货跨平台铺货?商品采集|商品上传实现详细步骤
  • 论文阅读:PURPLE: Making a Large Language Model a Better SQL Writer
  • leetcode排序链表 java
  • k8s部署ELK补充篇:kubernetes-event-exporter收集Kubernetes集群中的事件
  • QT单例模式简单讲解与实现
  • 汇量科技前端面试题及参考答案