這篇文章主要介紹“nginx+php的性能優(yōu)化設(shè)置是什么意思”,在日常操作中,相信很多人在nginx+php的性能優(yōu)化設(shè)置是什么意思問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”nginx+php的性能優(yōu)化設(shè)置是什么意思”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)建站是專業(yè)的大姚網(wǎng)站建設(shè)公司,大姚接單;提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行大姚網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
一臺(tái)ECS服務(wù)器
手動(dòng)編譯nginx+php
修改index.php ,輸出 ‘hello world’
用ab工具,ab -c 100 -n 50000 ,連續(xù)5次,記錄壓測(cè)的qps平均值。
想辦法去優(yōu)化,調(diào)整各種參數(shù)。每次調(diào)整一個(gè)參數(shù)有發(fā)現(xiàn)QPS提高,那就記錄下來,并思考qps瓶頸是在哪
user administrator administrators; #配置用戶或者組,默認(rèn)為nobody nobody。 worker_processes 2; #允許生成的進(jìn)程數(shù),默認(rèn)為1 pid /nginx/pid/nginx.pid; #指定nginx進(jìn)程運(yùn)行文件存放地址 error_log log/error.log debug; #制定日志路徑,級(jí)別。這個(gè)設(shè)置可以放入全局塊,http塊,server塊,級(jí)別以此為:debug|info|notice|warn|error|crit|alert|emerg events { accept_mutex on; #設(shè)置網(wǎng)路連接序列化,防止驚群現(xiàn)象發(fā)生,默認(rèn)為on multi_accept on; #設(shè)置一個(gè)進(jìn)程是否同時(shí)接受多個(gè)網(wǎng)絡(luò)連接,默認(rèn)為off #use epoll; #事件驅(qū)動(dòng)模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport worker_connections 1024; #最大連接數(shù),默認(rèn)為512 } http { include mime.types; #文件擴(kuò)展名與文件類型映射表 default_type application/octet-stream; #默認(rèn)文件類型,默認(rèn)為text/plain #access_log off; #取消服務(wù)日志 log_format myFormat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定義格式 access_log log/access.log myFormat; #combined為日志格式的默認(rèn)值 sendfile on; #允許sendfile方式傳輸文件,默認(rèn)為off,可以在http塊,server塊,location塊。 sendfile_max_chunk 100k; #每個(gè)進(jìn)程每次調(diào)用傳輸數(shù)量不能大于設(shè)定的值,默認(rèn)為0,即不設(shè)上限。 keepalive_timeout 65; #連接超時(shí)時(shí)間,默認(rèn)為75s,可以在http,server,location塊。 upstream mysvr { server 127.0.0.1:7878; server 192.168.10.121:3333 backup; #熱備 } error_page 404 https://www.baidu.com; #錯(cuò)誤頁(yè) server { keepalive_requests 120; #單連接請(qǐng)求上限次數(shù)。 listen 4545; #監(jiān)聽端口 server_name 127.0.0.1; #監(jiān)聽地址 location ~^.+$ { #請(qǐng)求的url過濾,正則匹配,~為區(qū)分大小寫,~為不區(qū)分大小寫。#root path; #根目錄#index vv.txt; #設(shè)置默認(rèn)頁(yè)proxy_pass http://mysvr; #請(qǐng)求轉(zhuǎn)向mysvr 定義的服務(wù)器列表deny 127.0.0.1; #拒絕的ipallow 172.18.5.54; #允許的ip } }}
ECS配置
CPU: 1核
內(nèi)存: 1 GiB
操作系統(tǒng): CentOS 7 64位
當(dāng)前使用帶寬: 1Mbps
在高并發(fā)的情況下,內(nèi)核會(huì)認(rèn)為系統(tǒng)受到了SYN flood攻擊,會(huì)發(fā)送cookies(possible SYN flooding on port 80. Sending cookies),這樣會(huì)減慢影響請(qǐng)求的速度,所以在應(yīng)用服務(wù)器上設(shè)置下這個(gè)參數(shù)為0禁用系統(tǒng)保護(hù)就可以進(jìn)行大并發(fā)測(cè)試了:
$ vim /etc/sysctl.conf $ net.ipv4.tcp_syncookies = 0 $ sysctl -p $ net.ipv4.tcp_syncookies = 0
net.ipv4.tcp_syncookies = 0 #此參數(shù)是為了防止洪水攻擊的,但對(duì)于大并發(fā)系統(tǒng),要禁用此設(shè)置
net.ipv4.tcp_max_syn_backlog#參數(shù)決定了SYN_RECV狀態(tài)隊(duì)列的數(shù)量,一般默認(rèn)值為512或者1024,即超過這個(gè)數(shù)量,系統(tǒng)將不再接受新的TCP連接請(qǐng)求,一定程度上可以防止系統(tǒng)資源耗盡??筛鶕?jù)情況增加該值以接受更多的連接請(qǐng)求。
net.ipv4.tcp_tw_recycle#參數(shù)決定是否加速TIME_WAIT的sockets的回收,默認(rèn)為0。
net.ipv4.tcp_tw_reuse#參數(shù)決定是否可將TIME_WAIT狀態(tài)的sockets用于新的TCP連接,默認(rèn)為0。
net.ipv4.tcp_max_tw_buckets#參數(shù)決定TIME_WAIT狀態(tài)的sockets總數(shù)量,可根據(jù)連接數(shù)和系統(tǒng)資源需要進(jìn)行設(shè)置
ab -c 100 -n 50000 http://127.0.0.1/index.php
1、 7111 2、7233 3、7240 4、7187 5、7197 平均:7194
worker_processes :工作進(jìn)程數(shù),調(diào)整一般為auto或者跟cpu核心一樣的數(shù)量。
一般一個(gè)進(jìn)程足夠了,你可以把連接數(shù)設(shè)得很大。(worker_processes: 1,worker_connections: 10,000)
如果有SSL、gzip這些比較消耗CPU的工作,而且是多核CPU的話,可以設(shè)為和CPU的數(shù)量一樣。(worker_processes: CPU核心數(shù))
或者要處理很多很多的小文件,而且文件總大小比內(nèi)存大很多的時(shí)候,也可以把進(jìn)程數(shù)增加,以充分利用IO帶寬(主要似乎是IO操作有block)
1、 7242 2、7228 3、7275 4、7234 5、7231 平均:7242
單個(gè)進(jìn)程允許的客戶端最大連接數(shù),一般來說,連接數(shù)可以設(shè)置和端口數(shù)一樣。
1、 7212 2、7236 3、7223 4、7260 5、7230 平均 7232
worker進(jìn)程最大打開文件數(shù),一般可以優(yōu)化設(shè)置成和端口數(shù)一樣
1、 7243 2、7236 3、7146 4、7243 5、7196 平均 7212.8
使用epoll的I/O模型,事件處理模型優(yōu)化。
1、7265 2、7196 3、7227 4、7216 5、7253 平均 7231
multi_accept指令使得NGINX worker能夠在獲得新連接的通知時(shí)盡可能多的接受連接。 此指令的作用是立即接受所有連接放到監(jiān)聽隊(duì)列中。 如果指令被禁用,worker進(jìn)程將逐個(gè)接受連接。
1、 7273 2、7281 3、7308 4、7299 5、7290 平均 7290
由于我們?cè)贜GINX中配置了多個(gè)workers,因此我們還應(yīng)配置影響worker的相關(guān)指令。 events區(qū)域下accept_mutex參數(shù)將使每個(gè)可用的worker進(jìn)程逐個(gè)接受新連接。設(shè)置網(wǎng)路連接序列化,防止驚群現(xiàn)象發(fā)生,默認(rèn)為on。
服務(wù)器是1核,所以影響不大
1、7268 2、7295 3、7308 4、7274 5、7261 平均 7281
TCP_CORK作為Nagle算法的替代方案,Linux提供了TCP_CORK選項(xiàng)。 該選項(xiàng)告訴TCP堆棧附加數(shù)據(jù)包,并在它們已滿或當(dāng)應(yīng)用程序通過顯式刪除TCP_CORK指示發(fā)送數(shù)據(jù)包時(shí)發(fā)送它們。 這使得發(fā)送的數(shù)據(jù)分組是最優(yōu)量,并且因此提高了網(wǎng)絡(luò)的效率。
NGINX提供了tcp_nopush指令,在連接套接字時(shí)啟用TCP_CORK。 該指令可用于http,server和location區(qū)塊:
http{
tcp_nopush on;
}
1、7309 2、7321 3、7292 4、7308 5、7322 平均 7310
TCP/IP網(wǎng)絡(luò)存在“小包”問題,其中單字符消息可能在高負(fù)載網(wǎng)絡(luò)上導(dǎo)致網(wǎng)絡(luò)擁塞。 例如分組大小為41字節(jié),其中40字節(jié)用于TCP報(bào)頭,只有1字節(jié)是有用信息。 這些小包占用了大約4000%的巨大開銷并且使得網(wǎng)絡(luò)飽和
ohn Nagle通過不立即發(fā)送小包來解決問題(Nagle的算法)。 所有這樣的分組被收集一定量的時(shí)間,然后作為單個(gè)分組一次發(fā)送。 這改進(jìn)了底層網(wǎng)絡(luò)的的效率。 因此,典型的TCP/IP協(xié)議棧在將數(shù)據(jù)包發(fā)送到客戶端之前需要等待200毫秒。
在打開套接字時(shí)可以使用TCP_NODELAY選項(xiàng)來禁用Nagle的緩沖算法,并在數(shù)據(jù)可用時(shí)立即發(fā)送。 NGINX提供了tcp_nodelay指令來啟用此選項(xiàng)。 該指令可用于http,server和location區(qū)塊:
http{
tcp_nodelay on;
}
1、 7326 2、7316 3、7334 4、7274 5、7290 平均 7308
指明worker進(jìn)程的nice值
Linux系統(tǒng)中,優(yōu)先級(jí)高的進(jìn)程會(huì)占用更多的系統(tǒng)資源,這里配置的是進(jìn)程的靜態(tài)優(yōu)先級(jí),取值范圍-20到+19,-20級(jí)別最高。因此可以把這個(gè)值設(shè)置小一點(diǎn),但不建議比內(nèi)核進(jìn)程的值低(通常為-5)
測(cè)試中 0到-5的性能提升明顯 0可達(dá)到8000均值
1、 7982 2、8023 3、7932 4、7911 5、8052 平均 7980
pm = dynamic;
表示使用哪種進(jìn)程數(shù)量管理方式
dynamic表示php-fpm進(jìn)程數(shù)是動(dòng)態(tài)的,最開始是pm.start_servers指定的數(shù)量,如果請(qǐng)求較多,則會(huì)自動(dòng)增加,保證空閑的進(jìn)程數(shù)不小于pm.min_spare_servers,如果進(jìn)程數(shù)較多,也會(huì)進(jìn)行相應(yīng)清理,保證多余的進(jìn)程數(shù)不多于pm.max_spare_servers
static表示php-fpm進(jìn)程數(shù)是靜態(tài)的, 進(jìn)程數(shù)自始至終都是pm.max_children指定的數(shù)量,不再增加或減少
1.pm.start_servers = 15; 動(dòng)態(tài)方式下的起始php-fpm進(jìn)程數(shù)量
2.pm.min_spare_servers = 5; 動(dòng)態(tài)方式下的最小php-fpm進(jìn)程數(shù)量
3.pm.max_spare_servers = 25; 動(dòng)態(tài)方式下的最大php-fpm進(jìn)程數(shù)量
4.pm.max_requests = 5000
設(shè)置每個(gè)子進(jìn)程重生之前服務(wù)的請(qǐng)求數(shù). 對(duì)于可能存在內(nèi)存泄漏的第三方模塊來說是非常有用的. 如果設(shè)置為 ’0′ 則一直接受請(qǐng)求. 等同于 PHP_FCGI_MAX_REQUESTS 環(huán)境變量. 默認(rèn)值: 0.這段配置的意思是,當(dāng)一個(gè) PHP-CGI 進(jìn)程處理的請(qǐng)求數(shù)累積到 5000 個(gè)后,自動(dòng)重啟該進(jìn)程。
7934 2 、8107 3 、8013 4、8039 5、7990 均值 8016
opcache 絕對(duì)是優(yōu)化的利器,Opcache是字節(jié)碼緩存,也就是PHP在被編譯的時(shí)候,首先會(huì)把php代碼轉(zhuǎn)換為字節(jié)碼,字節(jié)碼然后被執(zhí)行。
php文件第二次執(zhí)行時(shí),同樣還是會(huì)重新轉(zhuǎn)換為字節(jié)碼,但是很多時(shí)候,文件內(nèi)容幾乎是一樣的,比如靜態(tài)HTML文件,生成后內(nèi)容許久都不會(huì)改變,用戶訪問請(qǐng)求直接由服務(wù)器讀取響應(yīng)給客戶端瀏覽器。都不用經(jīng)過PHP進(jìn)行解析構(gòu)建了。
內(nèi)存中的字節(jié)碼數(shù)據(jù),可以直接緩存進(jìn)行二次編譯。這樣程序就會(huì)快一些,cpu的消耗也少了。
php-fpm 采用 prefork的方式 (listen同一個(gè)地址,然后fork出若干子進(jìn)程),fast-cgi管理器實(shí)現(xiàn)的是多進(jìn)程模型。
但是在php運(yùn)行時(shí),每一個(gè)進(jìn)程只能處理一個(gè)請(qǐng)求,實(shí)際上,運(yùn)行時(shí)是單進(jìn)程,單線程的。
php-fpm一個(gè)線程是阻塞模型,必須等待該客戶端請(qǐng)求php服務(wù)端返回?cái)?shù)據(jù),下一個(gè)nginx發(fā)過來的請(qǐng)求才能被受理,這個(gè)時(shí)候FPM就需要增多進(jìn)程去應(yīng)付并發(fā),更高的qps 需要更多的進(jìn)程處理,當(dāng)處理請(qǐng)求的時(shí)候發(fā)生了時(shí)間較長(zhǎng)阻塞,導(dǎo)致進(jìn)程內(nèi)存無法釋放,后續(xù)請(qǐng)求沒有足夠的子進(jìn)程去處理,更多的瓶頸在于 PHP-FPM 大量子進(jìn)程的處理和消耗內(nèi)存上面。
到此,關(guān)于“nginx+php的性能優(yōu)化設(shè)置是什么意思”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!