PHP程序加速探索之服務(wù)器負(fù)載測試
發(fā)表時間:2024-06-06 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]服務(wù)器負(fù)載太大而影響程序效率也是很常見的,我們需要對此進行測試。這里我以目前最常用的Apache服務(wù)器為例。 Apache服務(wù)器自帶有一個叫AB(ApacheBench)的工具,在bin目錄下。使用這個輕巧的工具我們可以對服務(wù)器進行負(fù)載測試,看看在重負(fù)荷之下服務(wù)器的表現(xiàn)如何。ApacheBe...
服務(wù)器負(fù)載太大而影響程序效率也是很常見的,我們需要對此進行測試。這里我以目前最常用的Apache服務(wù)器為例。
Apache服務(wù)器自帶有一個叫AB(ApacheBench)的工具,在bin目錄下。使用這個輕巧的工具我們可以對服務(wù)器進行負(fù)載測試,看看在重負(fù)荷之下服務(wù)器的表現(xiàn)如何。ApacheBench 可以針對某個特定的 URL 仿真出連續(xù)的聯(lián)機請求,同時還可以仿真出同時間點數(shù)個相同的聯(lián)機請求,因此利用 ApacheBench 可幫助我們在網(wǎng)站開發(fā)期間仿真實際上線可能的情況,利用仿真出來的數(shù)據(jù)作為調(diào)整服務(wù)器設(shè)定或程序的依據(jù)。
在命令行下輸出:
./ab -n number_of_total_requests \
-c number_of_simultaneous_requests \
http://your_web_server/your_php_app.php
例如:
./ab -n 1000 -c 50 http://www.domain.com/myapp.php
AB將同時向http://www.domain.com/myapp.php發(fā)出50個并發(fā)請求,共發(fā)出1000次。
測試結(jié)果將可能是這樣的:
Server Software: Apache/2.0.16
Server Hostname: localhost
Server Port: 80
Document Path: /myapp.php
Document Length: 1311 bytes
Concurrency Level: 50
Time taken for tests: 8.794 seconds
Complete requests: 1000
Failed requests: 0
Total transferred: 1754000 bytes
HTML transferred: 1311000 bytes
Requests per second: 113.71
Transfer rate: 199.45 kb/s received
Connection Times (ms)
min avg max
Connect: 0 0 5
Processing: 111 427 550
Total: 111 427 555
myapp.php每秒鐘可以處理的請求數(shù)為113.71個。將請求數(shù)增加,看看服務(wù)器能否處理更大的壓力。你也需要調(diào)節(jié)Apache的MaxClients,ThreadsPerChild,MaxThreadsPerChild等參數(shù),基于你的httpd.conf中的MPM模塊選擇。
如果你想得到更詳細(xì)的信息,請到www.apache.org上查閱一些更深入的文檔,包括模塊和第三方的提高效率的工具。修改httpd.conf后,要重啟Apache服務(wù)器,然后再用AB測試。你會看到每秒請求數(shù)增加或減少。
記下每次的參數(shù),最后選擇最佳效率的那種配置。
要指出的是,除了AB,還有許多優(yōu)秀的服務(wù)器性能測試軟件。另外,如果你的服務(wù)器不是Apache,請自行尋找測試方法。