使用不同的語言,redis支持不同的編程語言,但是調用了不同的redis包,例如:
java對應jedis;
php對應phpredis;
C++對應的則是hredis。
安裝Redis
上篇博客已經寫過,為了清楚的演示,再寫一遍。
打開Redis官網,進入下載頁面,選擇一個適合自己電腦的版本下載即可,下載飛機票http://redis.io/download,下載完成后解壓、編譯、安裝,依次在終端下執行如下命令。
tar -zxvf redis-2.8.7.tar.gz
cd redis-2.8.7
sudo 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/hiredis
cd hiredis
make
sudo 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源碼