# 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 秒傳功能