由于項目需要,需要多線程去獲取和修改數(shù)據(jù)庫的庫存,考慮到給數(shù)據(jù)庫加鎖效率低,所以采用redis+lua來進行實現(xiàn) 。
成都創(chuàng)新互聯(lián)公司專注于柯橋企業(yè)網(wǎng)站建設,成都響應式網(wǎng)站建設公司,商城開發(fā)。柯橋網(wǎng)站建設公司,為柯橋等地區(qū)提供建站服務。全流程定制網(wǎng)站,專業(yè)設計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務
redis的單線程操作特性來執(zhí)行l(wèi)ua腳本,通過lua腳本來保證原子性。如果通過單純的redis指令來進行更改,在讀和寫之間會存在多線程并發(fā)更新的問題。
1.首先定義redis數(shù)據(jù)結構
goodId:
{
"total":100,
"released":0;
}
local n = tonumber(ARGV[1])
if not n or n == 0 then
return 0
end
local vals = redis.call("HMGET", KEYS[1], "total", "released");
local total = tonumber(vals[1])
local blocked = tonumber(vals[2])
if not total or not blocked then
return 0
end
if blocked + n <= total then
redis.call("HINCRBY", KEYS[1], "released", n)
return n;
end
return 0
- 執(zhí)行腳本命令`EVAL script_string 1 goodId apply_count`
- 若庫存足夠則返回申請的數(shù)量,否則返回0,不返回可滿足的剩余數(shù)
3.spring boot 調用
- pom dependency
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.0.1.RELEASE</version>
- java code
```java
long count = redisHelper.getStrCache().execute(new RedisCallback<Long>() {
@Nullable
@Override
public Long doInRedis(RedisConnection redisConnection) throws DataAccessException {
long ret = redisConnection.eval(script.getScriptAsString().getBytes(), ReturnType.INTEGER, 1, key.getBytes(), String.valueOf(count).getBytes());
return ret;
}
});
4.redis->database
針對redis到databases的更新,思考了很久,沒有找到較好的解決辦法,先采用定時任務異步更新。至于數(shù)據(jù)是否丟失的問題,如果redis掛了,重啟后redis會恢復數(shù)據(jù),等下次定時任務就可以將數(shù)據(jù)庫中的數(shù)據(jù)保持一致,缺點是redis掛了秒殺活動會失敗。
至于redis到database更新的如何驅動,列出兩種愚見:
歡迎各位提出問題,謝謝您的閱讀
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
名稱欄目:Redis+lua進行類似秒殺的實現(xiàn)-創(chuàng)新互聯(lián)
瀏覽地址:http://www.chinadenli.net/article46/dheehg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、App設計、靜態(tài)網(wǎng)站、營銷型網(wǎng)站建設、商城網(wǎng)站、ChatGPT
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容