1. 程式人生 > >Linux下C++操作Redis

Linux下C++操作Redis

Redis的全稱是Remote Dictonary Server(遠端字典伺服器),redis是由Salvatore Sanfilippo寫的一個高效能key-value儲存系統,Redis有如下優點:
1. 高效能 - Redis能支援超過100K+每秒的讀寫頻率
2. 豐富的資料型別 - Redis支援Strings、Lists、Hashes、Sets及Ordered Sets等資料型別
3. 原子性 - Redis的所有操作都是原子性的,同時Redis還支援對幾個操作合併後的原子操作
4. 豐富的特性 - Redis還支援釋出/訂閱、事務、key過期等特性

開啟Redis官網,進入下載頁面,選擇一個適合自己電腦的版本下載即可,下載飛機票

http://redis.io/download,下載完成後解壓、編譯、安裝,依次在終端下執行如下命令:

  1. tar -zxvf redis-2.8.7.tar.gz
  2. cd redis-2.8.7
  3. sudo apt-get install tcl(redis測試程式需要tcl版本至少為8.5)
  4. make 32bit(64位系統直接使用make即可)
  5. sudo make install(將編譯生成的可執行檔案拷貝到/usr/local/bin目錄下)
  6. 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支援的命令。

需要使用C/C++操作Redis,就需要安裝C/C++ Redis Client Library,這裡我使用的是hiredis,這是官方使用的庫,而且用得人比較多,在終端下依次執行下列命令進行下載、安裝:

  1. git clone https://github.com/redis/hiredis
  2. cd hiredis
  3. make
  4. sudo make install(複製生成的庫到/usr/local/lib目錄下)
  5. sudo ldconfig /usr/local/lib

所有的準備工作已經做完了,接下來測試下如何使用C/C++操作Redis,程式碼如下:

  1. #include <hiredis/hiredis.h>
  2. #include <iostream>
  3. #include <string>
  4. int main(int argc, char **argv)
  5. {
  6. struct timeval timeout = {2, 0}; //2s的超時時間
  7. //redisContext是Redis操作物件
  8. redisContext *pRedisContext = (redisContext*)redisConnectWithTimeout("127.0.0.1", 6379,timeout);
  9. if ( (NULL == pRedisContext) || (pRedisContext->err) )
  10. {
  11. if (pRedisContext)
  12. {
  13. std::cout << "connect error:" << pRedisContext->errstr << std::endl;
  14. }
  15. else
  16. {
  17. std::cout << "connect error: can't allocate redis context." << std::endl;
  18. }
  19. return -1;
  20. }
  21. //redisReply是Redis命令回覆物件 redis返回的資訊儲存在redisReply物件中
  22. redisReply *pRedisReply = (redisReply*)redisCommand(pRedisContext, "INFO"); //執行INFO命令
  23. std::cout << pRedisReply->str << std::endl;
  24. //當多條Redis命令使用同一個redisReply物件時
  25. //每一次執行完Redis命令後需要清空redisReply 以免對下一次的Redis操作造成影響
  26. freeReplyObject(pRedisReply);
  27. return 0;
  28. }

儲存退出,執行g++ OperatorRedis.cpp -o OperatorRedis -lhiredis進行編譯,編譯完成後執行./OperatorRedis執行程式(在執行程式前需要啟動redis服務端,否則會得到connect error:Connection refused這樣的錯誤),不出意外的話會看到輸出的redis伺服器資訊~
好了,C++操作Redis先進行到這裡了,我這邊封裝了一個C++操作Redis的類,等完善後會放出來...