Linux下C++操作Redis

Redis的全称是Remote Dictonary Server(远程字典服务器),一个高性能key-value存储系统,Redis有如下优点:
1. 高性能 - Redis能支持超过100K+每秒的读写频率
2. 丰富的数据类型 - Redis支持Strings、Lists、Hashes、Sets及Ordered Sets等数据类型
3. 原子性 - Redis的所有操作都是原子性的,同时Redis还支持对几个操作合并后的原子操作
4. 丰富的特性 - Redis还支持发布/订阅、事务、key过期等特性

  1. tar -zxvf redis-2.8.7.tar.gz
  2. cd redis-2.8.7
  3. sudo apt-get install tcl(redis测试程序需要tcl版本至少为8.5)
  4. make 32bit(64位系统直接使用make即可)
  5. sudo make install(将编译生成的可执行文件拷贝到/usr/local/bin目录下)
  6. make test(用于确认安装正确与否)

编译生成的可执行文件有:
1. redis-server redis服务器
2. redis-cli redis客户端
3. redis-benchmark redis性能测试工具
4. redis-check-aof aof文件修复工具
5. redis-check-dump rdb文件检查工具
6. redis-sentinel redis集群管理工具

编译、安装完成后,在终端中输入redis-server以最简单的方式启动redis服务端,然后在另一个终端中输入redis-cli来连接redis服务端,接下来可以尝试各种命令了,可以在http://try.redis.io预习下redis的各种命令,还可以在redis官网查看redis支持的命令。

需要使用C/C++操作Redis,就需要安装C/C++ Redis Client Library,这里我使用的是hiredis,这是官方使用的库,而且用得人比较多。下载、安装:

  1. git clone https://github.com/redis/hiredis
  2. cd hiredis
  3. make
  4. sudo make install(复制生成的库到/usr/local/lib目录下)
  5. sudo ldconfig /usr/local/lib

代码如下:

#include<hiredis/hiredis.h>
#include<iostream>
#include<string>

int main()
{
    struct timeval timeout={2,0};//2s的超时时间
    //redisContext是Redis操作对象
    redisContext *pRedisContext = static_cast<redisContext*>(redisConnectWithTimeout("192.168.0.105", 6379, timeout));
    if ( (nullptr == pRedisContext) || (pRedisContext->err) )
    {
        if (pRedisContext)
        {
            std::cout << "connect error:" << pRedisContext->errstr << std::endl;
        }
        else
        {
            std::cout << "connect error: can't allocate redis context." << std::endl;
        }
        return -1;
    }

    //redisReply是Redis命令回复对象 redis返回的信息保存在redisReply对象中
    //hiredis可以连接设置了密码的redis服务器,但是不是在连接时指定,而是在连接成功后,通过发送`AUTH`命令来指定密码
    redisReply *pRedisReply = static_cast<redisReply*>(redisCommand(pRedisContext, "auth 123456"));
    freeReplyObject(pRedisReply);

    pRedisReply = static_cast<redisReply*>(redisCommand(pRedisContext, "INFO"));//执行INFO命令
    std::cout << pRedisReply->str << std::endl;
    //当多条Redis命令使用同一个redisReply对象时
    //每一次执行完Redis命令后需要清空redisReply 以免对下一次的Redis操作造成影响
    freeReplyObject(pRedisReply);

    redisFree(pRedisContext);

    return 0;
}

执行g++ OperatorRedis.cpp -o OperatorRedis -lhiredis进行编译,编译完成后执行./OperatorRedis运行程序(在运行程序前需要启动redis服务端,否则会得到connect error:Connection refused这样的错误),不出意外的话会看到输出的redis服务器信息~

  1. http://redis.io/:Redis官网
  2. http://redis.cn/:Redis中文官网
  3. http://try.redis.io/:在线体验Redis
  4. https://github.com/antirez/redis:Redis开发版本源码
  5. http://www.redisdoc.com/en/latest/:Redis命令参考
  6. http://blog.nosqlfan.com/topics/redis:Redis系类文章
  7. http://redisbook.readthedocs.org/en/latest/:Redis设计与实现
  8. https://github.com/huangz1990/annotated_redis_source:注释版Redis源码

猜你喜欢

转载自blog.csdn.net/f110300641/article/details/84111184