3.8 redis-C-API
- 网址:
https://github.com/redis/hiredis
- 下载:
git clone https://github.com/redis/hiredis.git
- 安装
cd hiredis
make
sudo make install
安装输出
mkdir -p /usr/local/include/hiredis /usr/local/lib
cp -a hiredis.h async.h read.h sds.h adapters /usr/local/include/hiredis cp -a libhiredis.so /usr/local/lib/libhiredis.so.0.13
cd /usr/local/lib && ln -sf libhiredis.so.0.13 libhiredis.so
cp -a libhiredis.a /usr/local/lib
mkdir -p /usr/local/lib/pkgconfig
cp -a hiredis.pc /usr/local/lib/pkgconfig
默认库安装在"/usr/local/lib/",设置加载库路径
vim ~/.bashrc
最后一行写入
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib/
重启终端
API
redisContext *redisConnect(const char *ip, int port);
说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379 该函数返回一个结构体 redisContext。
void *redisCommand(redisContext *c, 
const char *format, ...);
说明:该函数执行命令,就如sql数据库中的SQL语句一样,只是执行的是redis数据库中的操作命令,第一个参数为连接数据库时 返回的redisContext,剩下的参数为变参,就如C标准函数printf函数一样的变参。返回值为void*,一般强制转换成为redisReply类 型的进行进一步的处理。
redisCommand函数返回一个东西叫redisReply,我们需要通过判断它的type字段 来知道返回了具体什么样的内容:
| 状态标识 | 含义 | 
|---|---|
| REDIS_REPLY_STATUS | 表示状态,内容通过str字段查看,字符串长度是len字段 | 
| REDIS_REPLY_ERROR | 表示出错,查看出错信息,如上的str,len字段 | 
| REDIS_REPLY_INTEGER | 返回整数,从integer字段获取值 | 
| REDIS_REPLY_NIL | 没有数据返回 | 
| REDIS_REPLY_STRING | 返回字符串,查看str,len字段 | 
| REDIS_REPLY_ARRAY | 返回一个数组,查看elements的值(数组个数),通过 element[index]的方式访问数组元素,每个数组元素是一个redisReply对象的指针。 | 
void freeReplyObject(void *reply);
说明:释放redisCommand执行后返回的redisReply所占用的内存
redisReply返回结果处理:
| 标识 | 含义 | 
|---|---|
| REDIS_OK | 正常 | 
| REDIS_ERR_IO | IO读/写出现异常,通过errno查看原因 | 
| REDIS_ERR_EOF | 服务器关闭了链接,读结束 | 
| REDIS_ERR_PROTOCOL | 分析redis协议内容出错 | 
| EDIS_ERR_OTHER | 其他未知的错误 | 
上述错误类型都可以通过redisReply的errstr字段查看简短的描述
void redisFree(redisContext *c);
说明:释放redisConnect()所产生的连接。
测试用例
#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 key1 itcast_1"; 
    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 key1";
    r = (redisReply*)redisCommand(c, command2); 
    if ( r->type != REDIS_REPLY_INTEGER) {
        printf("Failed to execute command[%s]\n",command2); 
        freeReplyObject(r);
        redisFree(c);
        return;
    }
    intlength= r->integer;
    freeReplyObject(r);
    printf("The length of 'key1' is %d.\n", length); 
    printf("Succeed to execute command[%s]\n", command2);
    const char* command3 = "get key1";
    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 'key1' is %s\n", r->str); 
    freeReplyObject(r);
    printf("Succeed to execute command[%s]\n", command3);
    const char* command4 = "get key2";
    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(void)
{
    doTest();
    return 0;
}
编译:
gcc testredis.c -lhiredis -o testredis
运行:
./testredis