中文字幕在线观看,亚洲а∨天堂久久精品9966,亚洲成a人片在线观看你懂的,亚洲av成人片无码网站,亚洲国产精品无码久久久五月天

Nginx 作為web server 的優(yōu)化要點(diǎn)

2019-03-26    來源:開源中國(guó)

容器云強(qiáng)勢(shì)上線!快速搭建集群,上萬Linux鏡像隨意使用

Nginx既可作為web server,也可作為反向proxy,這里先討論作為web server的一般性優(yōu)化要點(diǎn)。

常用優(yōu)化要點(diǎn)

nginx使用的是固定數(shù)量的workers, 每個(gè)worker都處理進(jìn)入的請(qǐng)求。最佳實(shí)踐是每個(gè)CPU內(nèi)核配置一個(gè)worker.

如何知道您的系統(tǒng)有幾個(gè)CPU?

  • $ grep ^processor /proc/cpuinfo | wc -l

對(duì)于一個(gè)四核處理器,配置文件類似:

# One worker per CPU-core.

  • worker_processes  4;
  • events {
  •     worker_connections  8096;
  •     multi_accept        on;
  •     use                 epoll;
  • }
  • worker_rlimit_nofile 40000;
  • http {
  •     sendfile           on;
  •     tcp_nopush         on;
  •     tcp_nodelay        on;
  •     keepalive_timeout  15;
  •     # Your content here ..
  • }

這里我們提高了 worker_connections 設(shè)置,定義了每個(gè)worker進(jìn)程能處理多少連接。

服務(wù)器的最大連接數(shù)量是:

  • worker_processes * worker_connections (= 32384 本例中)

這里啟用了 multi_accept,該配置項(xiàng)使nginx能盡快接收盡可能多的請(qǐng)求,減少客戶端的連接初始化時(shí)間。

最后,本例中使用了 epoll 的事件模型,這也是最佳實(shí)踐建議。

壓縮

很多用戶會(huì)啟用 gzip壓縮模塊,使得返回客戶端的內(nèi)容更簡(jiǎn)短,傳輸更快。

但是壓縮會(huì)消耗用戶服務(wù)器資源,通過監(jiān)控CPU使用率(可采用開源Hyperic),如果過高,可以考慮禁用壓縮。

通常只壓縮大文件,避免壓縮那些壓縮效果不好的文件,例如圖片,可執(zhí)行文件等二進(jìn)制文件。

用戶可參考下面配置:

  • gzip  on;
  • gzip_vary on;
  • gzip_min_length 10240;
  • gzip_proxied expired no-cache no-store private auth;
  • gzip_types text/plain text/css text/xml text/javascript application/x-javascript application/xml;
  • gzip_disable "MSIE [1-6]\.";

上面配置,只對(duì)文件大于10k的文本文件進(jìn)行壓縮。

客戶端緩存

如果客戶端(一般是瀏覽器)認(rèn)為已經(jīng)保存了要下載的最新內(nèi)容,就不會(huì)向nginx服務(wù)器再發(fā)請(qǐng)求。

這需要做一些緩存設(shè)置。最簡(jiǎn)單的辦法是將所有的圖片,js等靜態(tài)內(nèi)容設(shè)置一個(gè)固定的時(shí)間長(zhǎng)度:

  • location ~* \.(jpg|jpeg|gif|png|css|js|ico|xml)$ {
  •          access_log        off;
  •          log_not_found     off;
  •          expires           30d;
  •      }

這里我們也禁用了媒體文件的日志,將一些文件后綴文件的過期時(shí)間設(shè)置為30天。

文件句柄緩存

如果需要處理大量靜態(tài)文件,需要保持這些文件句柄為打開狀態(tài),避免后續(xù)再次打開。

下面示例,既可放在nginx配置的 server 部分,也可放在主 http 塊中。:

  • open_file_cache          max=2000 inactive=20s;
  • open_file_cache_valid    60s;
  • open_file_cache_min_uses 5;
  • open_file_cache_errors   off;

這里設(shè)置服務(wù)器最大緩存2000個(gè)打開的文件句柄,關(guān)閉20秒內(nèi)無請(qǐng)求的文件句柄,句柄的有效時(shí)間是60秒,并且只有訪問次數(shù)超過5次的才會(huì)被緩存。這樣只緩存頻繁訪問的文件,降低文件系統(tǒng)的訪問。

優(yōu)化PHP

很多站點(diǎn)使用了PHP,例如drupal, wordpress。

由于nginx沒有自己的mod_php,推薦的方式是使用 PHP-FPM,需要將請(qǐng)求轉(zhuǎn)發(fā),例如:

  • # execute all .php files via php-fpm
  •         location ~ .php$ {
  •             # connect to a unix domain-socket:
  •             fastcgi_pass   unix:/var/run/php5-fpm.sock;
  •             fastcgi_index  index.php;
  •             fastcgi_param   SCRIPT_FILENAME $document_root$fastcgi_script_name;
  •             fastcgi_param   SCRIPT_NAME        $fastcgi_script_name;
  •             fastcgi_buffer_size 128k;
  •             fastcgi_buffers 256 16k;
  •             fastcgi_busy_buffers_size 256k;
  •             fastcgi_temp_file_write_size 256k;
  •             # This file is present on Debian systems..
  •             include fastcgi_params;
  •         }

注意這里使用了 Unix domain-socket 連接 FPM, 所以需要修改/etc/php5/fpm/pool.d/www.conf 如下:

  •  listen = /var/run/php5-fpm.sock

這保證FPM監(jiān)聽一個(gè)domain socket,而不是默認(rèn)的( "listen=127.0.0.1:9000").

默認(rèn)的PHP-FPM將啟動(dòng)一些專用的worker,每個(gè)運(yùn)行一個(gè)PHP實(shí)例。如果內(nèi)存足夠,可以增加worker數(shù)量來提升并發(fā)吞吐量。

編輯文件 /etc/php5/fpm/pool.d/www.conf,改變數(shù)量,例如:

  • ; set a fixed number of php workers
  • pm = static
  • ; start up 12 php processes
  • pm.max_children = 12

該值需要根據(jù)實(shí)際環(huán)境調(diào)整。調(diào)整的依據(jù)是使用監(jiān)控工具所采集的數(shù)據(jù)。

最后可配置PHP-FPM自動(dòng)重啟。如果出現(xiàn)問題,例如下面的配置是,在1分鐘內(nèi)十個(gè)子進(jìn)程死掉,就重啟,允許進(jìn)程有十秒失去控制。

下面是/etc/php5/fpm/php-fpm.conf 中的全局配置:

  • emergency_restart_threshold 10
  • emergency_restart_interval
  •  1m process_control_timeout 10s

檢驗(yàn)

優(yōu)化配置的效果需要實(shí)踐檢驗(yàn),建議部署一個(gè)監(jiān)控工具,監(jiān)控的內(nèi)容應(yīng)包括:

Nginx:開源版提供的監(jiān)控指標(biāo),僅有如下6個(gè):

Connections,Accepts,Handled,Requests,Writing,Waiting

從操作系統(tǒng)的角度:應(yīng)包括Nginx進(jìn)程的CPU使用率,內(nèi)存占用,整體CPU使用率,交換區(qū)使用率等指標(biāo)。

如果是在虛擬機(jī)上運(yùn)行,還應(yīng)關(guān)注 操作系統(tǒng)的 ST( Steal Time)指標(biāo),判斷是否有超賣,過載等現(xiàn)象;

這里推薦一個(gè)免費(fèi)開源工具, Hyperic

標(biāo)簽: Web服務(wù)器優(yōu)化 Nginx配置 Nginx重啟 

版權(quán)申明:本站文章部分自網(wǎng)絡(luò),如有侵權(quán),請(qǐng)聯(lián)系:west999com@outlook.com
特別注意:本站所有轉(zhuǎn)載文章言論不代表本站觀點(diǎn)!
本站所提供的圖片等素材,版權(quán)歸原作者所有,如需使用,請(qǐng)與原作者聯(lián)系。

上一篇:隨機(jī)應(yīng)變的百度排名策略

下一篇:移動(dòng)站點(diǎn)站內(nèi)優(yōu)化Checklist