LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

C#.NET高級(jí)編程高并發(fā)必備技巧 - 多線程搶庫(kù)存時(shí)加鎖

admin
2023年9月20日 12:17 本文熱度 1140

前言

鎖最為常見(jiàn)的應(yīng)用就是高并發(fā)的情況下,庫(kù)存的控制。本次只做簡(jiǎn)單的單機(jī)鎖介紹。

正文

直接看代碼

每請(qǐng)求一次庫(kù)存-1. 假如庫(kù)存1000,在1000個(gè)人請(qǐng)求之后,庫(kù)存將變?yōu)?

public int Reduce0()
{
        int r = 0;
        string key = "stock";
        string stock = Rds.cli.Get(key);
        int.TryParse(stock, out r);
        if (r > 0)
        {
            r--;
            Rds.cli.Set(key, r);
        }
        else
        {
            throw new Exception("庫(kù)存用盡!");
        }
        return r;
}

本次測(cè)試使用Jmeter進(jìn)行測(cè)試。先初始化庫(kù)存為1000。

Jmeter 設(shè)置如下,一個(gè)線程請(qǐng)求1000次,再去查看庫(kù)存剛好為0,沒(méi)有任何問(wèn)題:

調(diào)整一下測(cè)試參數(shù),5個(gè)人同時(shí)請(qǐng)求,各請(qǐng)求200次。再去查看庫(kù)存

發(fā)現(xiàn)請(qǐng)求后,還有279的庫(kù)存。明明請(qǐng)求了1000次。但是還有279的庫(kù)存,明顯不對(duì)。

造成次問(wèn)題的原因很簡(jiǎn)單,就是在庫(kù)存還沒(méi)完全減的情況下,有另外一個(gè)、或多個(gè)線程同時(shí)發(fā)出了請(qǐng)求,而庫(kù)存只減少了1

只要還有庫(kù)存,就可以繼續(xù)請(qǐng)求,到了庫(kù)存完全為0的時(shí)候,已經(jīng)超過(guò)1000個(gè)人進(jìn)行了請(qǐng)求。與實(shí)際庫(kù)存不符合。

為了解決這個(gè)問(wèn)題。我們簡(jiǎn)單調(diào)整一下代碼:

private static object lck = new object();
[HttpGet]
public  int Reduce1()
{
    lock(lck)
    {
        int r = 0;
        string key = "stock";
        string stock = Rds.cli.Get(key);
        r = int.Parse(stock);
        if (r > 0)
        {
            r--;
            Rds.cli.Set(key, r);
        }
        else
        {
            throw new Exception("庫(kù)存用盡!");
        }
        return r;
    }
}

聲明一個(gè)靜態(tài)變量,然后再方法體內(nèi) 使用lock。調(diào)整代碼后,再次進(jìn)行測(cè)試:

發(fā)現(xiàn) 請(qǐng)求1000次后,庫(kù)存為0。調(diào)整測(cè)試參數(shù) 100人*10次。測(cè)試結(jié)果依然為0。

到此為止,問(wèn)題解決。

但是,實(shí)際應(yīng)用場(chǎng)景中,高并發(fā)的應(yīng)用,都會(huì)多機(jī)分布式部署。分布式部署要怎么解決?大家思考一下。

轉(zhuǎn)自:CHN_CODER

鏈接:cnblogs.com/pzscit/p/17644157.html

- EOF -


該文章在 2023/9/20 12:17:52 編輯過(guò)
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶(hù)的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
日产日韩亚洲欧美综合在线 | 日本在线免费AⅤ视频 | 亚洲精品A区在线 | 亚洲日韩mⅴ在线 | 亚洲国内自拍愉拍中文字幕 | 好吊妞人成视频在线观看强行 |