QPS(Query Per Second):每秒請求數,就是說服務器在一秒的時間內處理了多少個請求QPS = req/sec = 請求數/秒【QPS計算PV和機器的方式】
QPS統計方式 [一般使用 http_load 進行統計] QPS = 總請求數 / ( 進程總數 * 請求時間 ) QPS: 單個進程每秒請求服務器的成功次數
單台服務器每天PV計算 公式1:每天總PV = QPS * 3600 * 6 公式2:每天總PV = QPS * 3600 * 8
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
服務器計算 服務器數量 = ceil( 每天總PV / 單台服務器每天總PV )
【峰值QPS和機器計算公式】 原理:每天80%的訪問集中在20%的時間里,這20%時間叫做峰值時間 公式:( 總PV數 * 80% ) / ( 每天秒數 * 20% ) = 峰值時間每秒請求數(QPS) 機器:峰值時間每秒QPS / 單台機器的QPS = 需要的機器
問:每天300w PV 的在單台機器上,這台機器需要多少QPS? 答:( 3000000 * 0.8 ) / (86400 * 0.2 ) = 139 (QPS) 問:如果一台機器的QPS是58,需要幾台機器來支持? 答:139 / 58 = 3
進程間通信 IPC (IPC InterProcess Communication
)
多進程模型是啟動多個服務進程。原來由一個進程做的事,當一個進程忙不過來,創建幾個功能一樣的進程來幫它一起干活,人多力量大。
由於多進程地址空間不同,數據不能共享,一個進程內創建的變量在另一個進程是無法訪問。操作系統看不下去了,憑什么同在一台機器,彼此相愛的兩個進程不能說說話呢?
於是操作系統提供了各種系統調用,搭建起各個進程間通信的橋梁,這些方法統稱為進程間通信 IPC (IPC InterProcess Communication
)