# 3.8 redis-C-API
* 网址:
https://github.com/redis/hiredis
* 下载:
```bash
git clone https://github.com/redis/hiredis.git
```
* 安装
```bash
cd hiredis
make
sudo make install
```
安装输出
```bash
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/",设置加载库路径
```bash
vim ~/.bashrc
```
最后一行写入
```
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib/
```
重启终端
---
###API
```cpp
redisContext *redisConnect(const char *ip, int port);
```
说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379 该函数返回一个结构体 redisContext。
---
```cpp
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对象的指针。 |
---
```cpp
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字段查看简短的描述
---
```cpp
void redisFree(redisContext *c);
```
说明:释放redisConnect()所产生的连接。
###测试用例
```cpp
#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;
}
```
编译:
```bash
gcc testredis.c -lhiredis -o testredis
```
运行:
```bash
./testredis
```
- 概要
- 1 分布式存储fastDFS
- 1.1 fastDFS 通用介绍
- 1.2 fastDFS安装和使用
- 1.3 基于fastDFS实现分布式
- 2 缓存数据库redis快速搭建
- 2.1 环境安装
- 2.2 redis数据类型
- 2.3 redis订阅发布模式
- 2.4 redis事务
- 2.5 redis备份
- 3 redis详细攻略
- 3.1 redis简介
- 3.2 redis使用场景
- 3.3 redis基本操作
- 3.4 redis数据类型
- 3.4.1 字符串
- 3.4.2 HASH-字典
- 3.4.3 List-列表
- 3.4.4 Set-集合
- 3.4.5 Sorted Set-有序集合
- 3.4.6 订阅-发布
- 3.4.7 事务
- 3.5 redis配置文件
- 3.6 持久化
- 3.7 redis性能测试
- 3.8 redis-C-API
- 3.9 redis-C++-API
- 3.10 总结与建议
- 4 memcache缓存数据库
- 4.1 什么是memcached
- 4.2 memcached的特征
- 4.3 memcached的内存管理
- 4.4 如何使用memcached
- 4.5 memcached参数详解
- 4.6 memcached安装
- 4.7 memcached-C客户端
- 4.8 memcached-C++客户端
- 5 Nginx
- 6 FastCGI
- 6.1 CGI
- 6.2 FastCGI
- 6.3 Nginx与FastCGI
- 7 Nginx上部署fastDFS
- 8 项目概要
- 8.1 上传文件功能
- 8.2 主界面显示与下载文件功能
- 8.3 注册功能
- 8.4 登陆功能
- 8.5 文件分类功能
- 8.6 个人网盘功能
- 8.8 秒传功能