Redis 客户端C++使用

安装 redis-plus-plus

在C++中使用Redis,通常需要借助第三方库来实现与Redis服务器的交互。目前比较流行的库有 redis-plus-plushiredisredis-plus-plus 是基于 hiredis 实现的,hiredis 是⼀个 C 语⾔实现的 redis 客⼾端,因此需要先安装 **hiredis,**直接使⽤包管理器安装即可。
Ubuntu

bash 复制代码
apt install libhiredis-dev

Centos

复制代码
​​​​​​​yum install hiredis-devel.x86_64

之后通过源码编译安装 redis-plus-plus

bash 复制代码
#下载 redis-plus-plus 源码
git clone https://github.com/sewenew/redis-plus-plus.git
#使⽤ cmake 构建
cd redis-plus-plus
mkdir build #创建build目录,放入编译生成的文件,避免污染源代码
cd build 
cmake .. #生成mafile文件
make #编译
make install #把库拷贝到系统目录

构建成功后, 会在 /usr/local/include/ 中多出 sw ⽬录, 并且内部包含 redis++ 的⼀系列头⽂件,由于我们已经把该目录拷贝到系统目录下,所以当我们使用 redis++ 中的接口函数时就需要包含头文件<sw/redis++/redis++.h>。

在 /usr/local/lib/ 中则是多出⼀系列 libredis 库⽂件。

详细 API

参考:
Github 地址: https://github.com/sewenew/redis-plus-plus/blob/master/src/sw/redis++/redis.h
同步到 gitee 后的地址: https://gitee.com/peixinchen2/redis-plus-plus/blob/master/src/sw/redis++/redis.h

使用案例

redis++.cc

cpp 复制代码
#include <iostream>
#include "sw/redis++/redis++.h"
using namespace std;

int main()
{
    // 创建redis连接,基于tcp的应用层协议+ip+端口
    sw::redis::Redis redis("tcp://127.0.0.1:6379");
    // 检查连接是否成功
    string ret = redis.ping();
    cout << ret << endl;

    redis.flushall();
    redis.set("key1", "111");
    redis.set("key2", "222");
    sw::redis::OptionalString value1 = redis.get("key1");
    auto value2 = redis.get("key2");
    cout << value1.value() << endl;
    cout << value2.value() << endl;

    vector<string> v;                  // 用来存储 keys 返回结果的容器
    auto it = back_insert_iterator(v); // 尾插迭代器
    redis.keys("*", it);
    for (auto &e : v)
        cout << e << endl;
    return 0;
}

makefile

使用 makefile 编译程序时需要引入库文件,如 redis++ 的库,hiredis 的库,线程库。首先需要使用 find 命令找到相关库文件的路径,例如:

需要连接动态库或者静态库看自己选择,为了方便,此处我们选择直接连接动态库

bash 复制代码
test:redis++.cc
	g++ -o $@ $^ -std=c++20 -lpthread /usr/local/lib/libredis++.a  /usr/lib/x86_64-linux-gnu/libhiredis.a
.PHONY:clean
clean:
	rm -f test
相关推荐
Leo.yuan18 分钟前
不同数据仓库模型有什么不同?企业如何选择适合的数据仓库模型?
大数据·数据库·数据仓库·信息可视化·spark
麦兜*35 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow38 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
稻草人想看远方41 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑41 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood1 小时前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
TDengine (老段)1 小时前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
驾驭人生1 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
xhbh6662 小时前
不止是DELETE:MySQL多表关联删除的JOIN语法实战详解
数据库·mysql·程序员·mysql删除语句