成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

LimitLatch 在 Tomcat 中的應用

開發(fā) 開發(fā)工具
Tomcat的LimitLatch類用于控制網(wǎng)絡通信的socket接收上限,在Tomcat7時引入,實現(xiàn)簡單,借此可以學習一下線程同步的相關知識。

Tomcat的LimitLatch類用于控制網(wǎng)絡通信的socket接收上限,在Tomcat7時引入,實現(xiàn)簡單,借此可以學習一下線程同步的相關知識。

Tomcat

LimitLatch依賴內部類Sync進行線程同步,而Sync繼承自大家熟悉的AbstractQueuedSynchronizer。AQS是java.util.concurrent的核心組件,諸多常用的線程同步工具類都能夠找到他的影子,讀者可以翻閱ReentrantLock、CountDownLatch、Semaphore等類的源碼。

  1. //if we have reached max connections, wait 
  2. countUpOrAwaitConnection(); 
  3. SocketChannel socket = null
  4. try { 
  5.       // Accept the next incoming connection from the server socket 
  6.      socket = serverSock.accept(); 
  7.      …… 

不管是NIO還是BIO,Tomcat在接收socket前,都要通過countUpOrAwaitConnection方法獲取資源,如果已經(jīng)達到***連接數(shù),則需要當前線程等待資源釋放。該方法最終會調用到LimitLatch的內部類Sync的acquireSharedInterruptibly方法,即AQS的acquireSharedInterruptibly方法。

從內部類Sync的重載方法我們能看到Sync是一個共享模式的同步器,重載了tryAcquireShared和tryReleaseShared兩個方法,而兩個方法之所以能夠如此簡單,就是因為父類AQS在背后默默完成了其他所有的排隊、等待、激活等一系列邏輯。

  1. protected int tryAcquireShared(int ignored) {            
  2.  long newCount = count.incrementAndGet();         
  3.     if (!released && newCount > limit) {//自增后沒有超過資源上限則獲取成功                // Limit exceeded                
  4.        count.decrementAndGet();//資源獲取失敗,回退                
  5.        return -1;         
  6.     } else { 
  7.                 return 1;       
  8.       }  
  9.  } 

在獲取共享資源時,LimitLatch.Sync使用了原子變量AtomicLong,利用其自增的CAS原子操作結果與設定的共享資源數(shù)量上限進行比較,如果超出上限則目前無法獲取資源,由AQS放入等待隊列等待下次觸發(fā)。LimitLatch中定義了released屬性,該屬性為true時,無論如何都會獲取到共享資源。

  1. public boolean releaseAll() {      
  2.    released = true;//標志位置為ture后,后續(xù)均可獲取資源     
  3.     return sync.releaseShared(0);//通知等待線程重新獲取資源   
  4.   } 

這里就有一個問題了,既然無論如何都會獲取到資源,LimitLatch就沒有存在的必要,那為何還要這樣一個看似多余的released 屬性呢?這里其實考慮到一個狀態(tài)變更的問題,當由一個LimitLatch控制資源獲取量變更為無需LimitLatch時,僅僅將LimitLatch置為null從而跳過資源競爭是不夠的。

如果之前存在在等待隊列中等待資源的線程,而此時沒有資源釋放,那么在狀態(tài)變更后線程仍然會處于等待狀態(tài),這與“***制”的狀態(tài)是不符的,此時需要將released屬性置為true,然后通過一次資源釋放由AQS觸發(fā)所有等待線程重新獲取資源,這個時候所有線程均會獲取資源立即返回。

  1. protected boolean tryReleaseShared(int arg) {    
  2.          count.decrementAndGet();//自減釋放資源      
  3.        return true;     
  4.     } 

資源釋放時的代碼就更簡單了,直接將代表資源的原子變量AtomicLong自減從而釋放資源就完成了。而后續(xù)的喚醒等待資源的線程等工作已經(jīng)由AQS代勞了。

寫到這里,問題又來了,這個功能完全可以由JDK自帶的Semaphore類來完成啊。如果非要再寫一個那一定是因為性能的原因了,畢竟該類要使用在接收Socket的前面,對性能有直接影響。下面代碼為Semaphore類(JDK1.8)的FairSync重寫的tryAcquireShared方法,本質上與LimitLatch并無什么不同,都是CAS自旋:

  1. protected int tryAcquireShared(int acquires) {             
  2. for (;;) {               
  3.  if (hasQueuedPredecessors())             
  4.        return -1;               
  5.  int available = getState();     
  6.            int remaining = available - acquires;     
  7.            if (remaining < 0 ||                    compareAndSetState(available, remaining))     
  8.                return remaining;          
  9.       } 
  10.    } 

話不多說,開始性能測試,測試場景分為64線程競爭64個資源以及64線程競爭32個資源,循環(huán)300w次。測試結果竟然是LimitLatch性能要比Semaphore性能低近10%左右,這個。。。一定是我打開的方式不對。

我們回顧一下,當前使用的環(huán)境為Windows,JDK版本為1.8,而tomcat7引入LimitLatch的時候正是JDK1.6橫行的時代。筆者將JDK切換到1.6進行測試,果然結果變?yōu)閮烧卟幌嗌舷?而后將測試代碼上傳到了服務器,在Linux、JDK1.6環(huán)境下重新測試,結果LimitLatch扭轉乾坤,反超Semaphore性能20%左右,切換到JDK1.8性能領先Semaphore約40%!很明顯Tomcat更注重的是Linux服務器下的性能,至于兩者性能對比結果在不同環(huán)境下不同的原因,歡迎各位大牛一起討論。

【本文為51CTO專欄作者“侯樹成”的原創(chuàng)稿件,轉載請通過作者微信公眾號『Tomcat那些事兒』獲取授權】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2019-08-15 16:30:49

TomcatSpringBootJava

2009-06-05 14:59:31

Eclipse中配置T

2019-12-09 15:08:30

JavaTomcatWeb

2020-05-22 10:40:33

ContinuatioJS前端

2009-02-27 16:22:34

AjaxProAjax.NET

2023-03-24 09:07:22

SignalsJavaScript應用

2009-06-25 15:54:18

設計模式EJB

2010-08-09 10:21:56

XMLFlex

2011-06-23 09:14:52

CRM云計算

2010-10-08 10:15:34

IFrameJS控件

2009-02-03 10:19:45

2010-08-03 11:07:34

NFSVMware快照

2009-06-29 17:09:49

JavaBeanJSP

2022-06-28 08:02:44

SPISpringJava

2022-10-26 07:47:54

2022-06-30 20:47:58

區(qū)塊鏈

2020-05-06 07:53:09

物聯(lián)網(wǎng)物流IOT

2014-08-08 16:50:21

AB 測試安卓推送

2022-06-30 08:58:09

時鐘輪RPC框架

2010-07-07 17:24:39

BGP協(xié)議
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天色天天色 | 精品91久久久 | 中文字幕 欧美 日韩 | 一级免费在线视频 | 曰韩三级 | 精品一区二区电影 | 久草免费在线视频 | 欧美一级黄视频 | 欧美黄色小视频 | 久久国产综合 | 日韩视频免费看 | 午夜影院在线观看 | 久久久久久久久99 | 日韩视频―中文字幕 | 欧美jizzhd精品欧美巨大免费 | 成人久久18免费网站图片 | 亚洲视频免费 | 成人在线视频网址 | 国产亚洲精品久久情网 | 欧美日韩一本 | 成人免费在线视频 | 久久精品免费看 | 国产乱码精品一区二区三区五月婷 | 91精品国产综合久久香蕉922 | 久久久影院 | 国产一级片精品 | 在线播放中文字幕 | 中文字幕亚洲视频 | 欧美精品久久久 | 国产不卡视频 | 成人免费影院 | 久久精品视频亚洲 | 欧美精品一区二区三区在线 | 国产超碰人人爽人人做人人爱 | 亚洲视频一区二区三区四区 | 亚洲日韩第一页 | 精品久久一区 | 久久久成人网 | 色欧美综合 | 日韩欧美在线观看视频 | 久优草 |