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;
- }
執行結果為:
相關文章
- [Redis 客戶端整合] Java 中常用Redis客戶端比較Redis客戶端Java
- Zookeeper 客戶端 API客戶端API
- redis客戶端管理Redis客戶端
- Redis-客戶端Redis客戶端
- zookeeper的Java客戶端APIJava客戶端API
- redis:常用客戶端命令(redis-cli)Redis客戶端
- 初探 Redis 客戶端 Lettuce:真香!Redis客戶端
- C# MQTT客戶端C#MQQT客戶端
- Redis客戶端連線數DevOpsRedis客戶端dev
- Redis客戶端選型再分析Redis客戶端
- Windows下安裝redis客戶端WindowsRedis客戶端
- [Redis 客戶端整合] SpringBoot 整合 LettuceRedis客戶端Spring Boot
- [Redis 客戶端整合] SpringBoot 整合 JedisRedis客戶端Spring Boot
- day03-Redis的客戶端Redis客戶端
- mysql、redis 客戶端連線池MySqlRedis客戶端
- kubernetes 客戶端KubeClient使用及常用api客戶端clientAPI
- Redis 入門 - C#|.NET Core客戶端庫六種選擇RedisC#客戶端
- Redis的Pub/Sub客戶端實現Redis客戶端
- Redis學習筆記(十) 客戶端Redis筆記客戶端
- Redis客戶端管理神器RedisInsight 推薦Redis客戶端
- Zookeeper C客戶端庫編譯客戶端編譯
- c# 獲取客戶端IPC#客戶端
- Jenkins 常用 REST API介紹(Java 客戶端)JenkinsRESTAPIJava客戶端
- Java中OpenAI API客戶端原始碼教程JavaOpenAIAPI客戶端原始碼
- Go 實現簡易的 Redis 客戶端GoRedis客戶端
- Redis 客戶端 Jedis、lettuce 和 Redisson 對比Redis客戶端
- [轉載] 使用Redis的Java客戶端JedisRedisJava客戶端
- C#之使用CefSharp建立客戶端C#客戶端
- CouchBase C 客戶端介面呼叫例項客戶端
- C#版Nebula客戶端編譯C#客戶端編譯
- Golang 實現 Redis(6): 實現 pipeline 模式的 redis 客戶端GolangRedis模式客戶端
- Redis原始碼剖析——客戶端和伺服器Redis原始碼客戶端伺服器
- 深入剖析Redis客戶端Jedis的特性和原理Redis客戶端
- Redis 6.0 客戶端快取的伺服器端實現Redis客戶端快取伺服器
- FTP客戶端c程式碼功能實現FTP客戶端C程式
- Redis客戶端管理軟體:Redis Desktop Client mac中文免費版Redis客戶端clientMac
- 前端入門6-JavaScript客戶端api&jQuery前端JavaScript客戶端APIjQuery
- 走近原始碼:Redis命令執行過程(客戶端)原始碼Redis客戶端
- Redis客戶端基本操作以及檢視慢查詢Redis客戶端