成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

php + nginx 網(wǎng)站并發(fā)壓力測(cè)試及優(yōu)化

yeyan1996 / 2426人閱讀

摘要:一測(cè)試工具壓力測(cè)試工具是針對(duì)的性能測(cè)試工具,可以只安裝工具。顯示版本號(hào)并退出。用戶(hù)名和密碼由一個(gè)隔開(kāi),并以編碼形式發(fā)送。參考并發(fā)數(shù)問(wèn)題思考與工作原理和優(yōu)化漏洞調(diào)大的并發(fā)連接數(shù)調(diào)的等。

一、測(cè)試工具: Apache 壓力測(cè)試工具ab

ab是針對(duì)apache的性能測(cè)試工具,可以只安裝ab工具。

ubuntu安裝ab

apt-get install apache2-utils

centos安裝ab

yum install httpd-tools

ab的參數(shù)詳細(xì)解釋

格式: ./ab [options] [http://]hostname[:port]/path

參數(shù):

-n在測(cè)試會(huì)話(huà)中所執(zhí)行的請(qǐng)求個(gè)數(shù)。默認(rèn)時(shí),僅執(zhí)行一個(gè)請(qǐng)求。

-c一次產(chǎn)生的請(qǐng)求個(gè)數(shù)。默認(rèn)是一次一個(gè)。

-t測(cè)試所進(jìn)行的最大秒數(shù)。其內(nèi)部隱含值是-n 50000,它可以使對(duì)服務(wù)器的測(cè)試限制在一個(gè)固定的總時(shí)間以?xún)?nèi)。默認(rèn)時(shí),沒(méi)有時(shí)間限制。

-p包含了需要POST的數(shù)據(jù)的文件。

-P對(duì)一個(gè)中轉(zhuǎn)代理提供BASIC認(rèn)證信任。用戶(hù)名和密碼由一個(gè):隔開(kāi),并以base64編碼形式發(fā)送。無(wú)論服務(wù)器是否需要(即, 是否發(fā)送了401認(rèn)證需求代碼),此字符串都會(huì)被發(fā)送。

-T POST數(shù)據(jù)所使用的Content-type頭信息。

-v設(shè)置顯示信息的詳細(xì)程度-4或更大值會(huì)顯示頭信息,3或更大值可以顯示響應(yīng)代碼(404,200等),2或更大值可以顯示警告和其他信息。

-V顯示版本號(hào)并退出。

-w以HTML表的格式輸出結(jié)果。默認(rèn)時(shí),它是白色背景的兩列寬度的一張表。

-i執(zhí)行HEAD請(qǐng)求,而不是GET。

-x設(shè)置

屬性的字符串。

-X對(duì)請(qǐng)求使用代理服務(wù)器。

-y設(shè)置

屬性的字符串。

-z設(shè)置

<
屬性的字符串。

-C對(duì)請(qǐng)求附加一個(gè)Cookie:行。其典型形式是name=value的一個(gè)參數(shù)對(duì),此參數(shù)可以重復(fù)。

-H對(duì)請(qǐng)求附加額外的頭信息。此參數(shù)的典型形式是一個(gè)有效的頭信息行,其中包含了以冒號(hào)分隔的字段和值的對(duì)(如,"Accept-Encoding:zip/zop;8bit")。

-A對(duì)服務(wù)器提供BASIC認(rèn)證信任。用戶(hù)名和密碼由一個(gè):隔開(kāi),并以base64編碼形式發(fā)送。無(wú)論服務(wù)器是否需要(即,是否發(fā)送了401認(rèn)證需求代碼),此字符串都會(huì)被發(fā)送。

-h顯示使用方法。

-d不顯示"percentage served within XX [ms] table"的消息(為以前的版本提供支持)。

-e產(chǎn)生一個(gè)以逗號(hào)分隔的(CSV)文件,其中包含了處理每個(gè)相應(yīng)百分比的請(qǐng)求所需要(從1%到100%)的相應(yīng)百分比的(以微妙為單位)時(shí)間。由于這種格式已經(jīng)“二進(jìn)制化”,所以比"gnuplot"格式更有用。

-g把所有測(cè)試結(jié)果寫(xiě)入一個(gè)"gnuplot"或者TSV(以Tab分隔的)文件。此文件可以方便地導(dǎo)入到Gnuplot,IDL,Mathematica,Igor甚至Excel中。其中的第一行為標(biāo)題。

-i執(zhí)行HEAD請(qǐng)求,而不是GET。

-k啟用HTTP KeepAlive功能,即在一個(gè)HTTP會(huì)話(huà)中執(zhí)行多個(gè)請(qǐng)求。默認(rèn)時(shí),不啟用KeepAlive功能。

-q如果處理的請(qǐng)求數(shù)大于150,ab每處理大約10%或者100個(gè)請(qǐng)求時(shí),會(huì)在stderr輸出一個(gè)進(jìn)度計(jì)數(shù)。此-q標(biāo)記可以抑制這些信息。

eg:

### POST /user/login

ab -n 100 -kc 10 -p user_login -T "application/json" -H "Accept-Encoding:gzip, deflate" -H "accept-language:zh-Hans-CN;q=1, en-CN;q=0.9"  http://XXX/user/login


##### request data
文件 user_login 內(nèi)容:
{"email":"[email protected]","password":"ws65536"}
### GET /default/index

ab -n 1000 -c 100 http://XXX/default/index

測(cè)試的同時(shí)可以在被測(cè)試的服務(wù)器上使用htop命令查看CPU和內(nèi)存的實(shí)時(shí)使用情況:

關(guān)于ab詳情可參考:apache性能測(cè)試工具ab使用詳解

二、配置優(yōu)化

nginx處理PHP請(qǐng)求有三個(gè)步驟。

第一步:接受請(qǐng)求,發(fā)現(xiàn)是PHP請(qǐng)求,轉(zhuǎn)向第二步。

第二步:通過(guò)socket的方式,連接PHP-FPM的fast-cgi,讓PHP-FPM處理請(qǐng)求。

第三步:獲得PHP-FPM處理結(jié)果,加上http報(bào)頭,返回給客戶(hù)端。

所以,我們要提高nginx的PHP并發(fā)性能,我們需要做這三步。

1.調(diào)大nginx的并發(fā)連接數(shù)( 調(diào)nginx.conf 的worker_connections 和 worker_processes)。

worker_connections : 每一個(gè)worker進(jìn)程能并發(fā)處理(發(fā)起)的最大連接數(shù)(包含所有連接數(shù))

worker_processes :指明了nginx要開(kāi)啟的進(jìn)程數(shù),據(jù)官方說(shuō)法,一般開(kāi)一個(gè)就夠了,多開(kāi)幾個(gè),可以減少機(jī)器io帶來(lái)的影響。 一般為當(dāng)前機(jī)器總cpu核心數(shù)的1到2倍。

參考:

nginx 并發(fā)數(shù)問(wèn)題思考:worker_connections,worker_processes與 max clients

Nginx工作原理和優(yōu)化、漏洞

2.調(diào)大php-fpm的并發(fā)連接數(shù)(調(diào)php-fpm.conf 的pm.max_children等)。

本人用的是Ubuntu 14.04.4,PHP 5.5.9,以下目錄結(jié)構(gòu)對(duì)其他服務(wù)器環(huán)境可能不適用。

由于在 /etc/php5/fpm/php-fpm.conf 中并沒(méi)有找到 max_children ,于是使用以下命令進(jìn)行查找:

# 在/etc/php5/fpm 目錄下查找所有文件,并依次在每個(gè)文件中查找"max_children"
sudo find /etc/php5/fpm -name * | xargs grep "max_children"

終于在 /etc/php5/fpm/pool.d/www.conf 中找到了 max_children 等相關(guān)配置。

關(guān)于具體配置,請(qǐng)參考以下內(nèi)容:

(PHP手冊(cè))FastCGI 進(jìn)程管理器(FPM)

php-fpm的配置和優(yōu)化

PHP-FPM性能優(yōu)化參考

PHP FPM php-fpm.conf設(shè)置詳解

3.增加系統(tǒng)的最大文件數(shù)量限制(ulimit -n 65535)。

由于NGINX處理PHP請(qǐng)求的第二步需要通過(guò)socket的方式和PHP-FPM通信,它能新建的最大socket數(shù)受到系統(tǒng)最大打開(kāi)文件數(shù)的限制。新裝的Linux默認(rèn)只有1024,所以必須增加系統(tǒng)最大打開(kāi)文件數(shù)目。

ulimit -n 命令可以查看當(dāng)前系統(tǒng)最大打開(kāi)文件數(shù)。

ulimit -n 65535 可以將系統(tǒng)最大打開(kāi)文件數(shù)臨時(shí)修改為65535,然而退出登錄后就會(huì)失效。

想要修改系統(tǒng)最大打開(kāi)文件數(shù),并永久生效:

vi /etc/security/limits.conf
        
# 添加如下的行
* soft noproc 11000
* hard noproc 11000
* soft nofile 65535
* hard nofile 65535

說(shuō)明:

* 代表針對(duì)所有用戶(hù)

noproc 是代表最大進(jìn)程數(shù)

nofile 是代表最大文件打開(kāi)數(shù)

具體配置參考一下內(nèi)容:

ulimit -n 修改

linux有效修改max open files/ulimit -n

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/21973.html

相關(guān)文章

  • php + nginx 網(wǎng)站并發(fā)壓力測(cè)試優(yōu)化

    摘要:一測(cè)試工具壓力測(cè)試工具是針對(duì)的性能測(cè)試工具,可以只安裝工具。顯示版本號(hào)并退出。用戶(hù)名和密碼由一個(gè)隔開(kāi),并以編碼形式發(fā)送。參考并發(fā)數(shù)問(wèn)題思考與工作原理和優(yōu)化漏洞調(diào)大的并發(fā)連接數(shù)調(diào)的等。 一、測(cè)試工具: Apache 壓力測(cè)試工具ab ab是針對(duì)apache的性能測(cè)試工具,可以只安裝ab工具。 ubuntu安裝ab apt-get install apache2-utils centos安...

    Soarkey 評(píng)論0 收藏0
  • Node.js運(yùn)行原理、高并發(fā)性能測(cè)試對(duì)比生態(tài)圈匯總

    摘要:模式,單實(shí)例多進(jìn)程,常用于多語(yǔ)言混編,比如等,不支持端口復(fù)用,需要自己做應(yīng)用的端口分配和負(fù)載均衡的子進(jìn)程業(yè)務(wù)代碼。就是我們需要一個(gè)調(diào)度者,保證所有后端服務(wù)器都將性能充分發(fā)揮,從而保持服務(wù)器集群的整體性能最優(yōu),這就是負(fù)載均衡。 showImg(https://segmentfault.com/img/remote/1460000019425391?w=1440&h=1080); Nod...

    BDEEFE 評(píng)論0 收藏0
  • Node.js運(yùn)行原理、高并發(fā)性能測(cè)試對(duì)比生態(tài)圈匯總

    摘要:模式,單實(shí)例多進(jìn)程,常用于多語(yǔ)言混編,比如等,不支持端口復(fù)用,需要自己做應(yīng)用的端口分配和負(fù)載均衡的子進(jìn)程業(yè)務(wù)代碼。就是我們需要一個(gè)調(diào)度者,保證所有后端服務(wù)器都將性能充分發(fā)揮,從而保持服務(wù)器集群的整體性能最優(yōu),這就是負(fù)載均衡。 showImg(https://segmentfault.com/img/remote/1460000019425391?w=1440&h=1080); Nod...

    TesterHome 評(píng)論0 收藏0
  • Node.js運(yùn)行原理、高并發(fā)性能測(cè)試對(duì)比生態(tài)圈匯總

    摘要:模式,單實(shí)例多進(jìn)程,常用于多語(yǔ)言混編,比如等,不支持端口復(fù)用,需要自己做應(yīng)用的端口分配和負(fù)載均衡的子進(jìn)程業(yè)務(wù)代碼。就是我們需要一個(gè)調(diào)度者,保證所有后端服務(wù)器都將性能充分發(fā)揮,從而保持服務(wù)器集群的整體性能最優(yōu),這就是負(fù)載均衡。 showImg(https://segmentfault.com/img/remote/1460000019425391?w=1440&h=1080); Nod...

    kamushin233 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看