首頁 php框架 Workerman workerman怎麼實現高並發

workerman怎麼實現高並發

Dec 05, 2019 am 10:21 AM
workerman

workerman怎麼實現高並發

並發概念太模糊,這裡以兩個可以量化的指標並發連接數和並發請求數來說明。

並發連接數是指伺服器當下時刻總共維持了多少TCP連接,而這些連接上是否有資料通訊並不關注。 (建議學習: workerman教學

例如一台訊息推播伺服器上可能維持了百萬的設備連接,由於連接上很少有資料通訊,所以這台伺服器上負載可能幾乎為0,只要記憶體夠,還可以繼續接受連線。

影片課程推薦→:《千萬資料並發解決方案(理論實戰)》

並發請求數字一般用QPS(伺服器每秒處理多少請求)來衡量,而當前時刻伺服器上有多少tcp連線並不十分關注。例如一台伺服器只有10個客戶端連接,每個客戶端連接上每秒有1W個請求,那麼要求服務端需要至少能支撐10*1W=10W每秒的吞吐量(QPS)。

假設10W吞吐量每秒是這台伺服器的極限,如果每個客戶端每秒發送1個請求給服務端,那麼這台伺服器能夠支撐10W個客戶端。

並發連線數受限於伺服器內存,一般24G內存workerman伺服器可以支援大概120W並發連線。

並發請求數受限於伺服器cpu處理能力,一台24核心workerman伺服器可以達到45W每秒的吞吐量(QPS),實際值根據業務複雜度以及程式碼品質有所變化。

注意

高並發場景必須安裝event或libevent擴充功能。另外需要優化linux內核,尤其是進程開啟檔數限制。

壓測資料

這裡僅提供workerman壓測的QPS資料參考。

測試環境:

系統:debian 6.0 64位元

記憶體:64G

cpu:Intel(R ) Xeon(R) CPU E5-2420 0 @ 1.90GHz (2顆物理cpu,6核心,2線程)

Workerman:開啟200個Benchark進程

壓測腳本:benchmark

業務:發送並傳回hello字串

普通PHP(版本5.3.10)壓測

短連接(每次請求完成後關閉連接,下次請求建立新的連接):

條件: 壓測腳本開500個並發線程模擬500個並髮用戶,每個線程連接Workerman 10W次,每次連接發送1個請求

結果: 吞吐量:2.3W/S , cpu利用率:36%

長連接(每次請求後不關閉連接,下次請求繼續復用這個連線):

    條件: 壓測腳本開啟2000個同時執行緒模擬2000個並髮用戶,每個執行緒連接Workerman 1次,每個連線發送10W請求

    結果:吞吐量:36.7W/S , cpu利用率:69%

內存:每個進程內存穩定在6444K,無內存洩漏

以上是php5.3版本壓測數據,如果用php7,效能會再提升40%左右。

HHVM環境壓力測試

短連接(每次請求完成後關閉連接,下次請求建立新的連接):

條件: 壓測腳本開1000個並發線程模擬1000個並髮用戶,每個線程連接Workerman 10W次,每次連接發送1個請求

結果: 吞吐量:3.5 W/S , cpu利用率:35%

長連接(每次請求後不關閉連接,下次請求繼續復用這個連接):

    條件: 壓測腳本開6000個同時執行緒模擬6000個同時用戶,每個執行緒連接Workerman 1次,每個連線發送10W請求

    結果: 吞吐量:45W/S , cpu利用率:67%#######記憶體:HHVM環境每個進程記憶體穩定在46M,無記憶體洩漏###

以上是workerman怎麼實現高並發的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

實作Workerman文件中的文件上傳與下載 實作Workerman文件中的文件上傳與下載 Nov 08, 2023 pm 06:02 PM

實現Workerman文件中的文件上傳與下載,需要具體程式碼範例引言:Workerman是一款高效能的PHP非同步網路通訊框架,具備簡潔、高效、易用等特點。在實際開發中,文件上傳和下載是常見的功能需求,本文將介紹如何使用Workerman框架實現文件的上傳和下載,並給出具體的程式碼範例。一、檔案上傳:檔案上傳是指將本機上的檔案傳輸至伺服器端的操作。下面是使用

如何實作Workerman文件的基本使用方法 如何實作Workerman文件的基本使用方法 Nov 08, 2023 am 11:46 AM

如何實現Workerman文件的基本使用方法簡介:Workerman是一個高效能的PHP開發框架,它可以幫助開發者輕鬆建立高並發的網路應用程式。本文將介紹Workerman的基本使用方法,包括安裝和設定、建立服務和監聽連接埠、處理客戶端請求等。並給出相應的程式碼範例。一、安裝並設定Workerman在命令列中輸入以下命令來安裝Workerman:c

swoole和workerman哪個好 swoole和workerman哪個好 Apr 09, 2024 pm 07:00 PM

Swoole 和 Workerman 都是高效能 PHP 伺服器框架。 Swoole 以其非同步處理、出色的效能和可擴展性而聞名,適用於需要處理大量並發請求和高吞吐量的專案。 Workerman 提供了非同步和同步模式的靈活性,具有直覺的 API,更適合易用性和處理較低並發量的專案。

Workerman開發:如何實現基於UDP協定的即時視訊通話 Workerman開發:如何實現基於UDP協定的即時視訊通話 Nov 08, 2023 am 08:03 AM

Workerman開發:基於UDP協議的即時視訊通話摘要:本文將介紹如何使用Workerman框架實現基於UDP協議的即時視訊通話功能。我們將深入了解UDP協議的特點,並透過程式碼範例展示如何建立一個簡單但完整的即時視訊通話應用程式。引言:在網路通訊中,即時視訊通話是一項非常重要的功能。傳統的TCP協定在實現即時性較高的視訊通話時,可能會有傳輸延遲等問題。而UDP

如何實作Workerman文件中的定時器功能 如何實作Workerman文件中的定時器功能 Nov 08, 2023 pm 05:06 PM

如何實現Workerman文件中的定時器功能Workerman是一款強大的PHP非同步網路通訊框架,它提供了豐富的功能,其中就包括定時器功能。使用定時器可以在指定的時間間隔內執行程式碼,非常適合定時任務、輪詢等應用程式場景。接下來,我將詳細介紹如何在Workerman中實現定時器功能,並提供具體的程式碼範例。第一步:安裝Workerman首先,我們需要安裝Worker

如何使用Workerman建構高可用性負載平衡系統 如何使用Workerman建構高可用性負載平衡系統 Nov 07, 2023 pm 01:16 PM

如何使用Workerman建立高可用性負載平衡系統,需要具體程式碼範例在現代技術領域中,隨著網路的快速發展,越來越多的網站和應用程式需要處理大量的並發請求。為了實現高可用性和高效能,負載平衡系統成為了必不可少的組件之一。本文將介紹如何使用PHP開源框架Workerman建構一個高可用性的負載平衡系統,並提供具體的程式碼範例。一、Workerman簡介Worke

如何實現Workerman文件中的反向代理功能 如何實現Workerman文件中的反向代理功能 Nov 08, 2023 pm 03:46 PM

如何實現Workerman文件中的反向代理功能,需要具體程式碼範例簡介:Workerman是一款高效能的PHP多進程網路通訊框架,提供了豐富的功能和強大的效能,廣泛應用於Web即時通訊、長連接服務等場景。其中,Workerman也支援反向代理功能,可實現伺服器對外提供服務時的負載平衡和靜態資源快取等功能。本篇文章將介紹如何使用Workerman實現反向代理功

如何實現Workerman文件中的TCP/UDP通信 如何實現Workerman文件中的TCP/UDP通信 Nov 08, 2023 am 09:17 AM

如何實現Workerman文件中的TCP/UDP通信,需要具體程式碼範例Workerman是一款高效能的PHP非同步事件驅動框架,廣泛用於實現TCP和UDP通訊。本文將介紹如何使用Workerman實現基於TCP和UDP的通信,並提供相應的程式碼範例。一、TCP通訊創建TCP伺服器使用Workerman建立TCP伺服器十分簡單,只需寫如下程式碼:<?ph

See all articles