linux下Redis以及c++操作

使用不同的语言,redis支持不同的编程语言,但是调用了不同的redis包,例如:

java对应jedis;

php对应phpredis;

C++对应的则是hredis。

 

上篇博客已经写过,为了清楚的演示,再写一遍。

打开Redis官网,进入下载页面,选择一个适合自己电脑的版本下载即可,下载飞机票http://redis.io/download,下载完成后解压、编译、安装,依次在终端下执行如下命令。

  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 PREFIX=/usr/local/redis install(默认sudo make install将编译生成的可执行文件拷贝到/usr/local/redis/bin目录下;PREFIX更改一下目录)
    把redis-2.8.7目录中的redis.conf复制到/usr/local/redis/bin目录,有的道友喜欢放在/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

hiredis是redis数据库的C接口,目前只能在linux下使用,几个基本的函数就可以操作redis数据库了。

 

函数原型:redisContext *redisConnect(const char *ip, int port);

说明:该函数用来连接Redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379;

函数返回值:该函数返回一个结构体redisContext;

类似的提供了一个函数redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv),以带有超时的方式连接redis服务器,同时获取与redis连接的上下文对象。

 

函数原型:void *redisCommand(redisContext *c, const char *format, ...);

说明:该函数执行命令,就如sql数据库中的SQL语句一样,只是执行的是redis数据库中的操作命令,第一个参数为连接数据库时返回的redisContext,剩下的参数为变参,就如C标准函数printf函数一样的变参。

函数返回值:返回值为void*,一般强制转换成为redisReply类型,以便做进一步处理。

 

函数原型void freeReplyObject(void *reply);

说明:释放redisCommand执行后返回的redisReply所占用的内存;

 函数返回值:无。

 

函数原型:void redisFree(redisContext *c);

说明:释放redisConnect()所产生的连接。

函数返回值:无。

 

下面用一个简单的例子说明:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#include <stdio.h> 
#include <stdlib.h> 
#include <stddef.h> 
#include <stdarg.h> 
#include <string.h> 
#include <assert.h> 
#include <hiredis/hiredis.h> 
   
void doTest() 
    //redis默认监听端口为6387 可以再配置文件中修改 
    redisContext* c = redisConnect("127.0.0.1", 6379); 
    if ( c->err) 
    
        redisFree(c); 
        printf("Connect to redisServer faile\n"); 
        return
    
    printf("Connect to redisServer Success\n"); 
       
    const char* command1 = "set stest1 value1"
    redisReply* r = (redisReply*)redisCommand(c, command1); 
       
    if( NULL == r) 
    
        printf("Execut command1 failure\n"); 
        redisFree(c); 
        return
    
    if( !(r->type == REDIS_REPLY_STATUS && strcasecmp(r->str,"OK")==0)) 
    
        printf("Failed to execute command[%s]\n",command1); 
        freeReplyObject(r); 
        redisFree(c); 
        return
    }    
    freeReplyObject(r); 
    printf("Succeed to execute command[%s]\n", command1); 
       
    const char* command2 = "strlen stest1"
    r = (redisReply*)redisCommand(c, command2); 
    if ( r->type != REDIS_REPLY_INTEGER) 
    
        printf("Failed to execute command[%s]\n",command2); 
        freeReplyObject(r); 
        redisFree(c); 
        return
    
    int length =  r->integer; 
    freeReplyObject(r); 
    printf("The length of 'stest1' is %d.\n", length); 
    printf("Succeed to execute command[%s]\n", command2); 
       
       
    const char* command3 = "get stest1"
    r = (redisReply*)redisCommand(c, command3); 
    if ( r->type != REDIS_REPLY_STRING) 
    
        printf("Failed to execute command[%s]\n",command3); 
        freeReplyObject(r); 
        redisFree(c); 
        return
    
    printf("The value of 'stest1' is %s\n", r->str); 
    freeReplyObject(r); 
    printf("Succeed to execute command[%s]\n", command3); 
       
    const char* command4 = "get stest2"
    r = (redisReply*)redisCommand(c, command4); 
    if ( r->type != REDIS_REPLY_NIL) 
    
        printf("Failed to execute command[%s]\n",command4); 
        freeReplyObject(r); 
        redisFree(c); 
        return
    
    freeReplyObject(r); 
    printf("Succeed to execute command[%s]\n", command4);    
       
       
    redisFree(c); 
       
   
int main() 
    doTest(); 
    return 0; 

  

  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源码
posted @   CTHON  阅读(13453)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示