關于并發測試的一點總結

發表于:2009-07-03來源:作者:點擊數: 標簽:
通過和 開發 了解,目前加鎖方式去控制并發一般會在程序塊里和在數據庫級別去做。 1、程序塊里的鎖一般是針對某個變量(全局變量)的操作的并發。 舉例說明,比如很多地方會用到地名(假設有上海、杭州、金華三個地名)的一個下拉列表,而并不是說每次去查詢
通過和開發了解,目前加鎖方式去控制并發一般會在程序塊里和在數據庫級別去做。

  1、程序塊里的鎖一般是針對某個變量(全局變量)的操作的并發。

  舉例說明,比如很多地方會用到地名(假設有上海、杭州、金華三個地名)的一個下拉列表,而并不是說每次去查詢數據庫表的方式來取到這個值的,處于性能考慮,程序實現的時候通常會考慮用緩存的方式來做。將數據庫表的這些數據先取出來放于一個變量list中(A)作為緩存,然后再做一個更新緩存的功能專門用來更新這個變量的取值,而此時更新緩存的這個動作就會可能出現并發,因為這個更新緩存的類是又一個變量和一個賦值的方法組成的,并且程序加載的時候就做了實例化;當多個用戶同時點擊更新緩存的時候,就有可能說出現這種情況,前一個更新緩存的請求處理了一半(僅僅將上海賦值給A),后一個更新緩存的請求又起來了,最后更新完之后,變量A中就會分別出現2個上海,2個杭州,2個金華。

  對于這種情況要控制并發的話,通常是加synchronize方法來給這個程序塊加鎖,每次去觸發更新緩存的請求的時候就先上這個鎖,等第一個線程處理完畢之后再解鎖,這個時候第二個線程才可以進入。

  2、數據庫級別的鎖一般是同時去操作同一條數據的時候會用到的,這種情況一般用for update去控制并發。而這個鎖肯定是在一個事務里面的(事務起來之后第一件事情就是上鎖,然后再后續的動作),因為是做為這個事務的一部分的,當事務提交或者回滾之后,這個鎖會自動失效。(這個你可以聯想在pl sql里去for update之后,要進行提交或者回滾那么就不會再鎖住記錄了)。這種情況一般都會有update記錄狀態的動作。

  事務控制并不一定是多表操作的時候用到的。

原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97