新聞中心
Redis集群在現(xiàn)在的系統(tǒng)開發(fā)架構(gòu)中是不可或缺的,在門檻低的同時具備強大的存儲性能和穩(wěn)定性,人們最主要的用途就是以其key-value內(nèi)存數(shù)據(jù)庫的特性來解決更靈活的業(yè)務需求,其中流水號生成也是比較常見的應用場景,而實現(xiàn)高可用,并發(fā)生成流水號就需要系統(tǒng)體系中有剛性的組件可以確保高可用,和高準確率。

成都創(chuàng)新互聯(lián)公司主營覃塘網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,app開發(fā)定制,覃塘h5微信小程序開發(fā)搭建,覃塘網(wǎng)站營銷推廣歡迎覃塘等地區(qū)企業(yè)咨詢
下面我們就介紹下,如何基于Redis的集群特性,來搭建一個實現(xiàn)高可用,準確性的流水號系統(tǒng),及其實現(xiàn)的代碼實例。
我們需要建立Redis的集群節(jié)點,一般集群節(jié)點包括主節(jié)點和新加入的從節(jié)點。在新加入的從節(jié)點上面運行以下命令:
redis-cli slaveof IP地址of Master端口
這條命令會將從節(jié)點建立主從關系,從節(jié)點會同步獲取主節(jié)點的數(shù)據(jù)來保持數(shù)據(jù)的一致性,當主節(jié)點發(fā)生故障時,從節(jié)點會馬上被提升為新的主節(jié)點,從而實現(xiàn)高可用。
我們在主節(jié)點上面建立流水號的生成函數(shù)。函數(shù)的大致代碼如下:
long buildNumber() {
long lastNumber = incr();
if (lastNumber == 0) { //用來判斷是否第一次請求,并設置流水號初始值
lastNumber = getNextInitValue();
}
return lastNumber;
}
這段代碼主要使用Redis操作中的 ”Incr“ 函數(shù)進行遞增,根據(jù)Redis自身攜帶的Atomic(原子性)特性,保證每次遞增之后的Redis緩存key中都會增加一位,返回新增之后的值。對于第一次的請求,我們需要額外寫一個獲取流水號的初始值的函數(shù)– getNextInitValue,讓流水號能夠每次重新從一個不重復的值開始遞增。
我們需要考慮高并發(fā)時,不重復增加流水號的場景,這時候我們可以利用Redis的鎖機制,即”setnx+expire“,在setnx執(zhí)行之前根據(jù)當前時間設置一定的過期時間,假如當前線程獲取鎖成功,那么他就可以進行緩存key的操作,緩存key操作完成之后就釋放當前鎖,完成一次安全的遞增流水號的操作。
Redis的集群架構(gòu)可以為我們的流水號系統(tǒng)提供高可用,準確性的解決方案,同時能夠給我們處理高并發(fā)下的數(shù)據(jù)安全保障。
成都網(wǎng)站建設選創(chuàng)新互聯(lián)(?:028-86922220),專業(yè)從事成都網(wǎng)站制作設計,高端小程序APP定制開發(fā),成都網(wǎng)絡營銷推廣等一站式服務。
標題名稱:Redis集群實現(xiàn)高效流水號生成(redis集群生成id)
網(wǎng)頁鏈接:http://m.fisionsoft.com.cn/article/cohohgg.html


咨詢
建站咨詢
