測(cè)試那些事兒(四)- 并發(fā)

什么是并發(fā)?

并發(fā),在操作系統(tǒng)中,是指一個(gè)時(shí)間段中有幾個(gè)程序都處于已啟動(dòng)運(yùn)行到運(yùn)行完畢之間,且這幾個(gè)程序都是在同一個(gè)處理機(jī)運(yùn)行,但任一個(gè)時(shí)刻點(diǎn)上只有一個(gè)程序在處理機(jī)上運(yùn)行。

嗯,不是很明白。。。拋去晦澀的定義,換種方式,我們先看看什么是并發(fā)用戶(hù)數(shù)量。

并發(fā)用戶(hù)數(shù)量:在同一時(shí)刻與服務(wù)器進(jìn)行了交互的在線(xiàn)用戶(hù)數(shù)量。

這個(gè)定義就非常好理解了,同一時(shí)刻與服務(wù)器進(jìn)行了交互的在線(xiàn)用戶(hù)數(shù)量只要大于1,其實(shí)就構(gòu)成了并發(fā)行為。而本次要討論的內(nèi)容其實(shí)還可以再加一個(gè)定義,就是同一時(shí)刻與服務(wù)器進(jìn)行了交互的、且對(duì)資源產(chǎn)生了影響的在線(xiàn)用戶(hù)數(shù)量

并發(fā)是開(kāi)發(fā)測(cè)試過(guò)程中很容易忽視的點(diǎn),不處理它而產(chǎn)生的問(wèn)題有的時(shí)候是致命的,比如在做跟錢(qián)相關(guān)的業(yè)務(wù)時(shí)。

舉個(gè)栗子:

假設(shè)我們有個(gè)數(shù)據(jù)是代表金庫(kù)總額的,現(xiàn)在它的數(shù)值現(xiàn)在為0元。如果要想完成存錢(qián)的操作,系統(tǒng)需要先取金庫(kù)總額的值到內(nèi)存,對(duì)這個(gè)值進(jìn)行+1,最后再回存到金庫(kù)總額中。如果這時(shí)A和B兩個(gè)人同時(shí)往里面存錢(qián),每個(gè)人存1元錢(qián),有可能出現(xiàn)什么問(wèn)題呢?假設(shè)就是這么巧,A和B在同一時(shí)間拿到了金庫(kù)總額數(shù)據(jù),都是0,然后各自進(jìn)行了+1操作,再回存。。。是不是最終的結(jié)果不對(duì)了?預(yù)期是2,實(shí)際是1。

對(duì)于并發(fā)工作,你需要某種方式來(lái)防止兩個(gè)任務(wù)在同一時(shí)刻訪問(wèn)相同的資源(其實(shí)就是共享資源競(jìng)爭(zhēng))。 防止這種沖突的方法就是當(dāng)資源被一個(gè)任務(wù)使用時(shí),在其上加鎖。第一個(gè)訪問(wèn)某項(xiàng)資源的任務(wù)必須鎖定這項(xiàng)資源,使其他任務(wù)在其被解鎖之前,就無(wú)法訪問(wèn)它了,而在其被解鎖之時(shí),另一個(gè)任務(wù)就可以鎖定并使用它了。具體關(guān)于鎖的內(nèi)容可以參考我之前的分享:java中的實(shí)例鎖(Synchronized)和類(lèi)鎖(Static Synchronized)

其實(shí),鎖的實(shí)現(xiàn)方式有很多的,大家感興趣都可以去了解。比如樂(lè)觀鎖、悲觀鎖、分布式鎖等等等等,各自有各自的特點(diǎn),也有各自的特點(diǎn)(性能、準(zhǔn)確性等),根據(jù)大家不同的業(yè)務(wù)去進(jìn)行選擇就好。

我們能夠發(fā)現(xiàn)并發(fā)問(wèn)題的方式有以下這些:

  1. 代碼走查:通過(guò)分析業(yè)務(wù),我們可以發(fā)現(xiàn)有哪些資源是有可能存在并發(fā)問(wèn)題的,也就是同時(shí)會(huì)進(jìn)行多次操作的,比如交易系統(tǒng)中的余額。所以,在進(jìn)行代碼走查的時(shí)候,就要重點(diǎn)看下這塊數(shù)據(jù)的處理邏輯,有沒(méi)有加鎖的功能。
  2. 并發(fā)測(cè)試:通過(guò)設(shè)置并發(fā)用戶(hù)數(shù),編寫(xiě)接口測(cè)試用例,實(shí)現(xiàn)并發(fā)測(cè)試(比如Jmeter),來(lái)發(fā)現(xiàn)最終的實(shí)際數(shù)值是否和預(yù)期數(shù)值相同。這種測(cè)試可以多做幾次,逐步提高并發(fā)用戶(hù)數(shù),就可以發(fā)現(xiàn)問(wèn)題。在提高并發(fā)用戶(hù)數(shù)的情況下,還可以對(duì)服務(wù)的性能達(dá)到檢驗(yàn)的目的,得到在合理的超時(shí)時(shí)間的設(shè)定下我們可以承受住多大的并發(fā)量。
測(cè)試人需關(guān)注

對(duì)于測(cè)試來(lái)說(shuō),資源在并發(fā)條件下產(chǎn)生變更是不是準(zhǔn)確的、性能是不是符合要求的,都是我們需要關(guān)注的,通過(guò)并發(fā)測(cè)試和合理的超時(shí)時(shí)間設(shè)定,能夠幫助我們發(fā)現(xiàn)并發(fā)問(wèn)題,保證系統(tǒng)穩(wěn)定且準(zhǔn)確。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容