使用不同的語言,redis支持不同的編程語言,但是調用了不同的redis包,例如:
java對應jedis;
php對應phpredis;
C++對應的則是hredis。
安裝Redis
上篇博客已經寫過,為了清楚的演示,再寫一遍。
打開Redis官網,進入下載頁面,選擇一個適合自己電腦的版本下載即可,下載飛機票http://redis.io/download,下載完成后解壓、編譯、安裝,依次在終端下執行如下命令。
tar -zxvf redis-2.8.7.tar.gzcd redis-2.8.7sudo apt-get install tcl(redis測試程序需要tcl版本至少為8.5)make 32bit(64位系統直接使用make即可)sudo make PREFIX=/usr/local/redis install(默認sudo make install將編譯生成的可執行文件拷貝到/usr/local/redis/bin目錄下;PREFIX更改一下目錄)
把redis-2.8.7目錄中的redis.conf復制到/usr/local/redis/bin目錄,有的道友喜歡放在/bin目錄下,只要自己額能找到就可以了。make test(用於確認安裝正確與否)
編譯生成的可執行文件有:
1. redis-server redis服務器
2. redis-cli redis客戶端
3. redis-benchmark redis性能測試工具
4. redis-check-aof aof文件修復工具
5. redis-check-dump rdb文件檢查工具
6. redis-sentinel redis集群管理工具
編譯、安裝完成后,在終端中輸入redis-server以最簡單的方式啟動redis服務端,然后在另一個終端中輸入redis-cli來連接redis服務端,接下來可以嘗試各種命令了,可以在http://try.redis.io預習下redis的各種命令,還可以在redis官網查看redis支持的命令。
安裝hiredis
需要使用C/C++操作Redis,就需要安裝C/C++ Redis Client Library,這里我使用的是hiredis,這是官方使用的庫,而且用得人比較多,在終端下依次執行下列命令進行下載、安裝:
git clone https://github.com/redis/hirediscd hiredismakesudo make install(復制生成的庫到/usr/local/lib目錄下)sudo ldconfig /usr/local/lib
C/C++操作Redis
hiredis是redis數據庫的C接口,目前只能在linux下使用,幾個基本的函數就可以操作redis數據庫了。
函數原型:redisContext *redisConnect(const char *ip, int port);
說明:該函數用來連接Redis數據庫,參數為數據庫的ip地址和端口,一般redis數據庫的端口為6379;
函數返回值:該函數返回一個結構體redisContext;
類似的提供了一個函數redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv),以帶有超時的方式連接redis服務器,同時獲取與redis連接的上下文對象。
函數原型: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;
}
- http://redis.io/:Redis官網
- http://redis.cn/:Redis中文官網
- http://try.redis.io/:在線體驗Redis
- https://github.com/antirez/redis:Redis開發版本源碼
- http://www.redisdoc.com/en/latest/:Redis命令參考
- http://blog.nosqlfan.com/topics/redis:Redis系類文章
- http://redisbook.readthedocs.org/en/latest/:Redis設計與實現
- https://github.com/huangz1990/annotated_redis_source:注釋版Redis源碼
