Nginx服務(wù)器進(jìn)程數(shù)設(shè)置和利用多核CPU的方法
Nginx 配置文件 nginx.conf
首先需要找到 Nginx 的配置文件 nginx.conf 才能進(jìn)行下面的操作,在LNMP一鍵安裝包默認(rèn)配置下,nginx.conf 存放在
/usr/local/nginx/conf/nginx.conf
至于其他環(huán)境下安裝 Nginx 可以用
find / -name nginx.conf
來(lái)查找配置文件的存放路徑。
Nginx worker_processes進(jìn)程數(shù)設(shè)置
Nginx 的配置文檔 nginx.conf 中可以設(shè)置 worker_processes 來(lái)更改 Nginx 的進(jìn)程數(shù)量,根據(jù)這篇問(wèn)答number of nginx worker processes顯示,建議 Nginx worker_processes進(jìn)程數(shù)設(shè)置為1,因?yàn)椋?/p>
但我們的目的是要把不同的 worker_processes 進(jìn)程分配至不同核上的 CPU 上運(yùn)行,所以以我目前的VPS提供商Linode的512配置為例,服務(wù)器母雞擁有8個(gè)邏輯CPU,但是作為用戶我只得到4個(gè)邏輯CPU,所以在這里我設(shè)置為運(yùn)行3個(gè)worker_processes進(jìn)程,原因是在默認(rèn)情況下,其他的程序會(huì)在第1個(gè)邏輯CPU(CPU0)上運(yùn)行,為了不影響其他程序,我將會(huì)把這3個(gè)進(jìn)程分配至另外3個(gè)邏輯CPU(CPU1、CPU2、CPU3)上運(yùn)行:
worker_processes 3;
一般來(lái)說(shuō),擁有幾個(gè)邏輯CPU,就設(shè)置為幾個(gè)worker_processes 為宜,但是 worker_processes 超過(guò)8個(gè)就沒(méi)有多大意義了,原因再上面那段英文里已經(jīng)提到了。
你可以使用這條命令來(lái)查看當(dāng)前的CPU情況:
cat /proc/cpuinfo
或者直接顯示邏輯CPU的個(gè)數(shù):
cat /proc/cpuinfo |grep "processor"|wc -l
Nginx worker_cpu_affinity 設(shè)置
根據(jù) Nginx Wiki 上的資料顯示:
worker_cpu_affinity 默認(rèn)是沒(méi)有開(kāi)啟的,根據(jù)例子我們可以看得出,0001 0010 0100 1000 分別代表第1、2、3、4個(gè)邏輯CPU,所以我們可以設(shè)置0010 0100 1000來(lái)將3個(gè)進(jìn)程分別綁定到第2、3、4個(gè)邏輯CPU上:
worker_processes 3; worker_cpu_affinity 0010 0100 1000;
同時(shí)根據(jù)例子我們也可以看出,worker_cpu_affinity 可以將同1個(gè)進(jìn)程綁定在2個(gè)邏輯CPU上:
worker_processes 2; worker_cpu_affinity 0101 1010;
0101也就是第1、3個(gè)邏輯CPU上,1010就是第2、4個(gè)邏輯CPU上。
Nginx 進(jìn)程分配至多核CPU設(shè)置的啟用和測(cè)試
保存 nginx.conf 文件,并重新加載 Nginx 配置文件:
/usr/local/nginx/sbin/nginx -s reload
在另一臺(tái)安裝了 Apache 的主機(jī)下運(yùn)行 ab 來(lái)測(cè)試:
ab -n 20000 -k http://www.1990y.com/p.php
你可以測(cè)試一個(gè)需要MySQL查詢的PHP頁(yè)面,也可以測(cè)試一個(gè)靜態(tài)圖片或者頁(yè)面。
在被測(cè)試服務(wù)器上可以使用 top 查看當(dāng)前服務(wù)器情況,然后按 1 來(lái)顯示各個(gè)邏輯CPU的使用情況。
開(kāi)啟CPU多核利用
規(guī)則設(shè)定
(1)cpu有多少個(gè)核,就有幾位數(shù),1代表內(nèi)核開(kāi)啟,0代表內(nèi)核關(guān)閉
(2)worker_processes最多開(kāi)啟8個(gè),8個(gè)以上性能就不會(huì)再提升了,而且穩(wěn)定性會(huì)變的更低,因此8個(gè)進(jìn)程夠用了
演示實(shí)例
兩核cpu,開(kāi)啟兩個(gè)進(jìn)程
worker_processes 2; worker_cpu_affinity 01 10;
01表示啟用了第一個(gè)cpu內(nèi)核,10表示啟用了第二個(gè)cpu內(nèi)核
worker_cpu_affinity 01 10;表示開(kāi)啟了兩個(gè)進(jìn)程,第一個(gè)進(jìn)程對(duì)應(yīng)著第一個(gè)cpu內(nèi)核,第二個(gè)進(jìn)程對(duì)應(yīng)著第二個(gè)cpu內(nèi)核
兩核cpu,開(kāi)啟八個(gè)進(jìn)程
worker_processes 8; worker_cpu_affinity 01 10 01 10 01 10 01 10;
開(kāi)啟了8個(gè)進(jìn)程,它們分別對(duì)應(yīng)了開(kāi)啟2個(gè)內(nèi)核
8核cpu,開(kāi)啟8個(gè)進(jìn)程
worker_processes 8; worker_cpu_affinity 10000000 01000000 00100000 00010000 00001000 00000100 00000010 00000001;
00000001表示開(kāi)啟第一個(gè)cpu內(nèi)核,00000010表示開(kāi)啟第二個(gè)cpu內(nèi)核,依次類推
8核cpu,開(kāi)啟2個(gè)進(jìn)程
worker_processes 2; worker_cpu_affinity 10101010 01010101;
10101010表示開(kāi)啟了第2,4,6,8內(nèi)核,01010101表示開(kāi)始了1,3,5,7內(nèi)核
2個(gè)進(jìn)程對(duì)應(yīng)著8個(gè)內(nèi)核
重啟nginx
配置完成后,需要重啟nginx服務(wù)
/etc/init.d/nginx restart
相關(guān)文章
針對(duì)OpenSSL安全漏洞調(diào)整Nginx服務(wù)器的方法
這篇文章主要介紹了針對(duì)OpenSSL漏洞調(diào)整Nginx服務(wù)器的方法,2014年爆出的SSL安全漏洞震驚了全世界,需要的朋友可以參考下2015-06-06windows下nginx服務(wù)關(guān)不掉問(wèn)題解決
這篇文章主要給大家介紹了關(guān)于windows下nginx服務(wù)關(guān)不掉問(wèn)題解決的相關(guān)資料,nginx是一種網(wǎng)絡(luò)服務(wù)器,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08Nginx配置WebSocket反向代理的實(shí)現(xiàn)示例
本文主要介紹了Nginx配置WebSocket反向代理的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08Nginx使用limit_req_zone對(duì)同一IP訪問(wèn)進(jìn)行限流的方法
今天小編就為大家分享一篇Nginx使用limit_req_zone對(duì)同一IP訪問(wèn)進(jìn)行限流的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08簡(jiǎn)介使用Nginx Plus的在線活動(dòng)監(jiān)控功能的方法
這篇文章主要介紹了簡(jiǎn)介使用Nginx Plus的在線活動(dòng)監(jiān)控功能的方法,注意其目前暫時(shí)為收費(fèi)項(xiàng)目,需要的朋友可以參考下2015-06-06