Redis C客戶端API
一、Redis安裝步驟:
1.redis server安裝
wget http://redis.googlecode.com/files/redis-2.4.6.tar.gz #下載檔案tar xzf redis-2.4.6.tar.gz
cd redis-2.4.6
make
cp src/redis-server src/redis-cli /usr/bin/ #方便在終端在任何地方直接執行
cp redis.conf /etc/
ufw allow 6379 #ubuntu下開啟埠
修改/etc/redis.conf,讓server以守護程式在後臺執行。
daemonize yes
2.啟動redis服務
redis-server /etc/redis.conf
3.檢測redis服務是否正常啟動
ps -ef | grep redis
二、Hiredis安裝步驟:
tar zxvf antirez-hiredis-v0.10.1-0-g3cc6a7f.zip
cd antirez-hiredis-3cc6a7f
make
mkdir /usr/lib/hiredis
cp libhiredis.so /usr/lib/hiredis #將動態連線庫libhiredis.so至/usr/lib/hiredis
mkdir /usr/include/hiredis
cp hiredis.h /usr/include/hiredis
1.連線hiredis伺服器
#include <stdio.h>
#include <hiredis/hiredis.h>
redisContext *conn = redisConnect("127.0.0.1", 6379); //redis server預設埠
if(conn->err){
printf("connection error: %s", conn->str);
}
2.傳送命令至伺服器
redisReply *reply = redisCommand(conn, "set key value");
3.關閉Reply物件
freeReplyObject(reply);
4.關閉連線
redisFree(conn);
hiredis是redis資料庫的C介面,目前只能在linux下使用,幾個基本的函式就可以操作redis資料庫了。
函式原型: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型別的進行進一步的處理。
函式原型void freeReplyObject(void *reply);
說明:釋放redisCommand執行後返回的redisReply所佔用的記憶體
函式原型: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 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;
- }
執行結果為:
相關文章
- c#實現redis客戶端(一)C#Redis客戶端
- Redis-客戶端Redis客戶端
- redis客戶端管理Redis客戶端
- Zookeeper 客戶端 API客戶端API
- redis客戶端的使用Redis客戶端
- Redis客戶端連線Redis客戶端
- Redis介紹 && Java客戶端操作RedisRedisJava客戶端
- redis:常用客戶端命令(redis-cli)Redis客戶端
- 初探 Redis 客戶端 Lettuce:真香!Redis客戶端
- zookeeper的Java客戶端APIJava客戶端API
- 【2】Windows C++ Redis服務端搭建與客戶端開發WindowsC++Redis服務端客戶端
- C# MQTT客戶端C#MQQT客戶端
- Redis客戶端選型再分析Redis客戶端
- Windows下安裝redis客戶端WindowsRedis客戶端
- mysql、redis 客戶端連線池MySqlRedis客戶端
- day03-Redis的客戶端Redis客戶端
- C#客戶端Redis伺服器的分散式快取C#客戶端Redis伺服器分散式快取
- C++客戶端程式(socket)C++客戶端
- Redis學習筆記(十) 客戶端Redis筆記客戶端
- Redis客戶端連線數DevOpsRedis客戶端dev
- Redis的Pub/Sub客戶端實現Redis客戶端
- Swift編寫自己的API客戶端SwiftAPI客戶端
- Redis 入門 - C#|.NET Core客戶端庫六種選擇RedisC#客戶端
- Zookeeper C客戶端庫編譯客戶端編譯
- c# 獲取客戶端IPC#客戶端
- [轉載] 使用Redis的Java客戶端JedisRedisJava客戶端
- Go 實現簡易的 Redis 客戶端GoRedis客戶端
- Redis 客戶端 Jedis、lettuce 和 Redisson 對比Redis客戶端
- Redis從客戶端登入伺服器Redis客戶端伺服器
- 使用Java客戶端對Redis進行操作Java客戶端Redis
- Redis 是如何處理命令的(客戶端)Redis客戶端
- [轉]reids客戶端 redis-cli用法客戶端Redis
- zookeeper Java客戶端API的使用方法Java客戶端API
- Java中OpenAI API客戶端原始碼教程JavaOpenAIAPI客戶端原始碼
- 百度翻譯API的C#客戶端實現過程APIC#客戶端
- CouchBase C 客戶端介面呼叫例項客戶端
- C#版Nebula客戶端編譯C#客戶端編譯
- Redis原始碼剖析——客戶端和伺服器Redis原始碼客戶端伺服器