肝貨!Nginx 高性能優化配置實戰總結

Nginx是Apache服務不錯的替代品。其特色是佔有內存少,併發能力強,事實上nginx的併發能力在同類型的網頁服務器中表現較好,所以國內知名大廠例如:淘寶,京東,百度,新浪,網易,騰訊等等都在使用Nginx網站。css

在咱們的平常工做學習中,咱們會該如何去優化本身的Nginx服務器?遇到如下問題咱們該如何處理呢?html

1、如何自定義返回給客戶端的404錯誤頁面

1)優化前,客戶端使用瀏覽器訪問不存在的頁面,會提示404文件未找到linux

[root@client ~]# firefox http://192.168.4.5/xxxxx        //訪問一個不存在的頁面

2)修改Nginx配置文件,自定義報錯頁面nginx

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
    charset utf-8;               //僅在須要中文時修改該選項
error_page   404  /404.html;    //自定義錯誤頁面
.. ..
[root@proxy ~]# vim /usr/local/nginx/html/404.html      //生成錯誤頁面
Oops,No NO no page …
[root@proxy ~]# nginx -s reload
#請先確保nginx是啓動狀態,不然運行該命令會報錯,報錯信息以下:
#[error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory)

3)優化後,客戶端使用瀏覽器訪問不存在的頁面,會提示本身定義的40x.html頁面vim

[root@client ~]# firefox http://192.168.4.5/xxxxx    //訪問一個不存在的頁面

常見的http狀態碼可用參考表所示瀏覽器

2、如何查看服務器狀態信息(很是重要的功能)

1)編譯安裝時使用--with-http_stub_status_module開啓狀態頁面模塊緩存

[root@proxy ~]# tar  -zxvf   nginx-1.12.2.tar.gz
[root@proxy ~]# cd  nginx-1.12.2
[root@proxy nginx-1.12.2]# ./configure   
> --with-http_ssl_module                        //開啓SSL加密功能
> --with-stream                                //開啓TCP/UDP代理模塊
> --with-http_stub_status_module                //開啓status狀態頁面
[root@proxy nginx-1.12.2]# make && make install    //編譯並安裝

2)啓用Nginx服務並查看監聽端口狀態bash

ss命令能夠查看系統中啓動的端口信息,該命令經常使用選項以下:服務器

  • -a顯示全部端口的信息
  • -n以數字格式顯示端口號
  • -t顯示TCP鏈接的端口
  • -u顯示UDP鏈接的端口
  • -l顯示服務正在監聽的端口信息,如httpd啓動後,會一直監聽80端口
  • -p顯示監聽端口的服務名稱是什麼(也就是程序名稱)

注意:在RHEL7系統中可使用ss命令替代netstat命令,功能同樣,選項同樣。併發

[root@proxy ~]# /usr/local/nginx/sbin/nginx
[root@proxy ~]# netstat  -anptu  |  grep nginx
tcp        0        0 0.0.0.0:80        0.0.0.0:*        LISTEN        10441/nginx
[root@proxy ~]# ss  -anptu  |  grep nginx

3)修改Nginx配置文件,定義狀態頁面

[root@proxy ~]# cat /usr/local/nginx/conf/nginx.conf
… …
location /status {
                stub_status on;
                 #allow IP地址;
                 #deny IP地址;
        }
… …
[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload

4)優化後,查看狀態頁面信息

[root@proxy ~]# curl  http://192.168.4.5/status
Active connections: 1 
server accepts handled requests
 10 10 3 
Reading: 0 Writing: 1 Waiting: 0
  • Active connections:當前活動的鏈接數量。
  • Accepts:已經接受客戶端的鏈接總數量。
  • Handled:已經處理客戶端的鏈接總數量。(通常與accepts一致,除非服務器限制了鏈接數量)。
  • Requests:客戶端發送的請求數量。
  • Reading:當前服務器正在讀取客戶端請求頭的數量。
  • Writing:當前服務器正在寫響應信息的數量。
  • Waiting:當前多少客戶端在等待服務器的響應。

3、優化Nginx併發量

1)優化前使用ab高併發測試

[root@proxy ~]# ab -n 2000 -c 2000 http://192.168.4.5/
Benchmarking 192.168.4.5 (be patient)
socket: Too many open files (24)                //提示打開文件數量過多

2)修改Nginx配置文件,增長併發量

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
worker_processes  2;                    //與CPU核心數量一致
events {
worker_connections 65535;        //每一個worker最大併發鏈接數
}
.. ..
[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload

3)優化Linux內核參數(最大文件數量)

[root@proxy ~]# ulimit -a                        //查看全部屬性值
[root@proxy ~]# ulimit -Hn 100000                //設置硬限制(臨時規則)
[root@proxy ~]# ulimit -Sn 100000                //設置軟限制(臨時規則)
[root@proxy ~]# vim /etc/security/limits.conf
    .. ..
*               soft    nofile            100000
*               hard    nofile            100000
#該配置文件分4列,分別以下:
#用戶或組    硬限制或軟限制    須要限制的項目   限制的值

4)優化後測試服務器併發量(由於客戶端沒調內核參數,因此在proxy測試)

[root@proxy ~]# ab -n 2000 -c 2000 http://192.168.4.5/

4、優化Nginx數據包頭緩存

1)優化前,使用腳本測試長頭部請求是否能得到響應

[root@proxy ~]# cat lnmp_soft/buffer.sh 
#!/bin/bash
URL=http://192.168.4.5/index.html?
for i in {1..5000}
do
    URL=${URL}v$i=$i
done
curl $URL                                //通過5000次循環後,生成一個長的URL地址欄
[root@proxy ~]# ./buffer.sh
.. ..
<center><h1>414 Request-URI Too Large</h1></center>        //提示頭部信息過大

2)修改Nginx配置文件,增長數據包頭部緩存大小

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
http {
client_header_buffer_size    1k;        //默認請求包頭信息的緩存    
large_client_header_buffers  4 4k;        //大請求包頭部信息的緩存個數與容量
.. ..
}
[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload

3)優化後,使用腳本測試長頭部請求是否能得到響應

[root@proxy ~]# cat buffer.sh 
#!/bin/bash
URL=http://192.168.4.5/index.html?
for i in {1..5000}
do
    URL=${URL}v$i=$i
done
curl $URL
[root@proxy ~]# ./buffer.sh

5、瀏覽器本地緩存靜態數據

1)使用Firefox瀏覽器查看緩存

以Firefox瀏覽器爲例,在Firefox地址欄內輸入about:cache將顯示Firefox瀏覽器的緩存信息,如圖所示,點擊List Cache Entries能夠查看詳細信息。2)清空firefox本地緩存數據,如圖所示。3)改Nginx配置文件,定義對靜態頁面的緩存時間

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
        }
location ~* .(jpg|jpeg|gif|png|css|js|ico|xml)$ {
expires        30d;            //定義客戶端緩存時間爲30天
}
}
[root@proxy ~]# cp /usr/share/backgrounds/day.jpg /usr/local/nginx/html
[root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload
#請先確保nginx是啓動狀態,不然運行該命令會報錯,報錯信息以下:
#[error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory)

4)優化後,使用Firefox瀏覽器訪問圖片,再次查看緩存信息

[root@client ~]# firefox http://192.168.4.5/day.jpg

在firefox地址欄內輸入about:cache,查看本地緩存數據,查看是否有圖片以及過時時間是否正確。

來源:https://blog.csdn.net/mage_li...

image

相關文章
相關標籤/搜索