您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解怎樣增加redis自定義命令,文章內容質量較高,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Redis因高性能、輕量的優秀特性成了互聯網公司緩存的標配,有的時候我們想增加一些自定義的命令,主要是重度使用Redis的場景,像搶購的場景,要保證多個Redis命令的事務性,如果沒有很好的原子性保證,很容易出現數據不一致的問題。
雖然官方給出事務的方案,但如果中間需要根據某個命令的返回值做判斷才做下一步處理,則事務的方案就無法應對了。
今天我們以一個實際的案例講述如何增加一個Redis命令,這個命令主要用于防刷的場景:
經常要將某個IP或某個用戶封禁一段時間,如果不用這個命令的方案如下:
先incr下,然后判斷是否為1,是1則設置過期時間。可以看到這樣處理在高并發時如果第1個發起incr請求的客戶端掛掉,則這個key不會過期。
今天要編寫的這個命令用來保證這個事務性,在服務端保證如果key的值為1的時候設置過期時間。
命令用法如下:
incexpire key expireTime maxNum
key:要處理的key
expireTime:過期時間,單位為秒,如果寫10,表示這個key到10秒之后過期;
maxNum:表示增加到多少為止不增加了,如果設為10,則返回的最大值就是11,返回11表示已經超出了;
二、編寫命令
1、下載redis代碼
本文所用Redis版本為3.2.11;
下載代碼并切到3.2.11分支
git clone https://github.com/antirez/redis
2、編寫增加命令代碼
1)在src/server.c中redisCommandTable結構體中增加新命令
struct redisCommand redisCommandTable[] = {
redisCommandTable為一個數組,每個項表示一個redis命令,其中第一個表示命令的名字,第二個為實際處理的函數,第3個為參數的個數,其它的先不詳細討論。
2)在src/server.h增加函數聲明:
void incrExpireCommand(client *c);
3)然后新增一個文件為ljh.c(名字自己定),加入以下代碼:
#include "server.h"
4)在src/Makefile中增加新文件 ljh.o
REDIS_SERVER_OBJ=adlist.o quicklist.o ae.o anet.o dict.o server.o sds.o zmalloc.o lzf_c.o lzf_d.o pqsort.o zipmap.o sha1.o ziplist.o release.o networking
執行效果如下
可以看到,key1增加到11之后不再增加,并且過了10秒之后,又變成1了。
最后我們還是要問自己我們的場景中是否有增加Redis命令的必要,如果需要則要把握好各層之間的職責,不要讓Redis最后變成處理業務去了;一般來說中間件層一般處理比較通用的功能,越到下面的層應該越穩定,越少改動才是正常的情況。
以上就是增加redis自定義命令的方法,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注億速云行業資訊,感謝各位的閱讀。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。