Nginx是Apache服務不錯的替代品。其特色是佔有內存少,併發能力強,事實上nginx的併發能力在同類型的網頁服務器中表現較好,所以國內知名大廠例如:淘寶,京東,百度,新浪,網易,騰訊等等都在使用Nginx網站。css
在咱們的平常工做學習中,咱們會該如何去優化本身的Nginx服務器?遇到如下問題咱們該如何處理呢?html
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狀態碼可用參考表所示瀏覽器
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命令能夠查看系統中啓動的端口信息,該命令經常使用選項以下:服務器
注意:在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
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/
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
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...