hiredis使用简介
来源:互联网 发布:ccs软件 编辑:程序博客网 时间:2024/05/21 17:36
hiredis是Redis数据库的C接口,目前只能在Linux下使用,几个基本的函数就可以操作redis数据库了。
一、API简介
1、redisContext* redisConnect(const char *ip, int port);
说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379。 类似的提供了一个函数redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv)
redisConnect函数用来创建一个叫redisContext的东西,它包含了连接相关的信息。它里面有个err字段,0表示正常,其他表示出错了!通过errstr字段可以知晓错误信息。
// 建立连接redisContext *c = redisConnect("127.0.0.1", 6379);if (c != NULL && c->err) { printf("Error: %s\n", c->errstr); // handle error}
2、void *redisCommand(redisContext *c, const char *format, …);
说明:该函数执行redis数据库中的操作命令,第一个参数为连接数据库时返回的redisContext,剩下的参数为变参,就如C标准函数printf函数一样的变参。 返回值为void*,一般强制转换成为redisReply类型,以便做进行进一步的处理。
redisCommand的调用格式类似printf函数,上面的第二条调用语句的作用在于输入二进制格式的value内容,其后必须表明二进制的字节长度!
// 执行命令reply = redisCommand(context, "SET key value");reply = redisCommand(context, "SET key %s", value);reply = redisCommand(context, "SET key %b", value, (size_t) valuelen);reply = redisCommand(context, "SET key:%s %s", myid, value);
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对象的指针
3、void *redisCommandArgv(redisContext *c, int argc, const char **argv, const size_t *argvlen);
说明:一个类似redisCommand的函数,批量执行命令
4、void freeReplyObject(void *reply);
说明:释放redisCommand执行后返回的redisReply所占用的内存
5、void redisFree(redisContext *c);
说明:断开redisConnect()所产生的连接,并释放redisContext的内容
二、使用步骤
1、redisCommand的函数执行流程说明:
a. 格式化redis command
b. 格式化后的命令内容放入redisContext的输出缓冲区
c. 调用redisGetReply函数执行命令,得到结果
2、管道的使用方式:
a.填入需要执行的命令
void redisAppendCommand(redisContext *c, const char *format, …);
void redisAppendCommandArgv(redisContext *c, int argc,const char **argv, const size_t *argvlen);
b. 获取命令的输出结果
int redisGetReply(redisContext *c, void **reply);
c. 释放输出结果
void freeReplyObject(void *reply);
// 例子redisReply *reply = NULL;redisAppendCommand(context,"set key1 value");redisAppendCommand(context,"get key2");redisGetReply(context,&reply); // reply for setfreeReplyObject(reply);redisGetReply(context,&reply); // reply for getfreeReplyObject(reply);// 订阅模式reply = redisCommand(context,"SUBSCRIBE test");freeReplyObject(reply);while(redisGetReply(context,&reply) == REDIS_OK) { // consume message freeReplyObject(reply);}
3、redisReply返回结果处理:
REDIS_OK 正常
REDIS_ERR_IO IO读/写出现异常,通过errno查看原因
REDIS_ERR_EOF 服务器关闭了链接,读结束
REDIS_ERR_PROTOCOL 分析redis协议内容出错
EDIS_ERR_OTHER 其他未知的错误
上述错误类型都可以通过redisReply的errstr字段查看简短的描述
三、异步API
(异步API的使用方式和同步API差不多,在这儿列出不同的函数吧)
1、连接redis服务器
redisAsyncContext *c = redisAsyncConnect(“127.0.0.1”, 6379);
if (c->err) {
printf(“Error: %s\n”, c->errstr);
// handle error
}
2、设置连接、断开的钩子函数
int redisAsyncSetConnectCallback(redisAsyncContext *ac, redisConnectCallback *fn);
int redisAsyncSetDisconnectCallback(redisAsyncContext *ac, redisDisconnectCallback *fn);
3、插入命令信息
int redisAsyncCommand(
redisAsyncContext *ac, redisCallbackFn *fn, void *privdata,
const char *format, …);
int redisAsyncCommandArgv(
redisAsyncContext *ac, redisCallbackFn *fn, void *privdata,
int argc, const char **argv, const size_t *argvlen);
获取命令输出和同步API相同
4、关闭连接
void redisAsyncDisconnect(redisAsyncContext *ac);
四、辅助API
下面的API主要用于其他编程语言绑定的术后,可以读取分析数据
redisReader *redisReaderCreate(void);
void redisReaderFree(redisReader *reader);
int redisReaderFeed(redisReader *reader, const char *buf, size_t len);
int redisReaderGetReply(redisReader *reader, void **reply);
// 例子 #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* redis = redisConnect("127.0.0.1", 6379); if ( NULL == redis || redis->err) { // redis为NULL与redis->err是两种不同的错误,若redis->err为true,可使用redis->errstr查看错误信息 redisFree(c); printf("Connect to redisServer faile\n"); return ; } printf("Connect to redisServer Success\n"); const char* command1 = "set stest1 value1"; redisReply* reply = (redisReply*)redisCommand(c, command1); // 执行命令,结果强转成redisReply*类型 if( NULL == reply) { printf("Execut command1 failure\n"); redisFree(redis); // 命令执行失败,释放内存 return; } if( !(reply->type == REDIS_REPLY_STATUS && strcasecmp(reply->str,"OK")==0)) { // 判断命令执行的返回值 printf("Failed to execute command[%s]\n",command1); freeReplyObject(reply); redisFree(redis); return; } freeReplyObject(reply); printf("Succeed to execute command[%s]\n", command1); // 一切正常,则对返回值进行处理 } int main() { doTest(); return 0; }
- hiredis使用简介
- hiredis简介
- c++中使用 hiredis/hiredis.h
- hiredis使用注意事项
- C++中使用hiredis
- windows下hiredis使用
- Hiredis 基本使用
- Hiredis 基本使用
- windows下hiredis使用
- Hiredis
- hiredis的一些使用心得
- hiredis安装和使用介绍
- redis C接口hiredis初次使用
- redis C接口hiredis初次使用
- 坑爹的hiredis API使用
- redis C接口hiredis初次使用
- 坑爹的hiredis API使用
- redis和hiredis-master使用心得
- java API中常用方法
- HTML---网页编程(二)HTML基本属性、图像、框架和浏览器与服务器交互方式
- [Unity3D]AssetServer服务器迁移数据备份还原
- CS231N-1
- Python cv2 图像自适应灰度直方图均衡化处理
- hiredis使用简介
- 大牛总结的前端技术
- JVM参数配置总结
- Java防止表单重复提交的方式
- LearnOpenGL学习笔记8:光照基础
- 前端小白训练营DAY7-DAY10
- ps抠图
- Mac版MySQL修改默认编码格式
- 重复定义错误与“stdfx”放在位置