Nginx高性能web服務器之性能優化(八)

     咱們該如何充分發揮Nginx的高效和穩定性呢?這裏我介紹下從編譯安裝開始,到系統內核,和利用第三方插件對Nginx進行優化,最大限度的發揮Nginx的性能。
mysql

1、編譯安裝過程的優化nginx

1.減少Nginx編譯安裝後的文件大小web

     在編譯Nginx的時候,默認是以debug模式進行的。而在debug模式下面會插入不少跟蹤ASSERT之類的信息。當編譯完成以後,一個Nginx要有好幾M的字節。若是咱們取消Nginx的debug模式,那麼Nginx只有幾百個字節。由於咱們修改相關源碼,取消debug模式:sql

     在解壓Nginx源碼文件後,找到源碼目錄下的auto/cc/gcc文件,而後找到以下幾行:bash

#debug服務器

CFLAGS=" $CFLAGS -g"cookie

註釋或者刪除這兩行,就能夠取消debug模式了網絡


2.爲特定的CPU指定CPU類型編譯優化socket

    在編譯Nginx的時候,默認的GCC編譯參數是"-O",優化GCC編譯,可使用如下兩個參數:tcp

--with-cc-opt='-O3'

--with-cpu-opt=CPU

若是你想肯定本身CPU的類型,能夠經過如下命令獲取:

cat /proc/cpuinfo|grep "model name"


2、利用TCMalloc優化Nginx的性能

    首先要解決依賴庫:

1.安裝libunwind庫

下載地址:http://download.savannah.gnu.org/releases/libunwind

[root@mysql ~]# tar zxvf libunwind-1.1.tar.gz 
[root@mysql ~]# cd libunwind-1.1
[root@mysql libunwind-1.1]# CFLAGS=-fPIC ./configure
[root@mysql libunwind-1.1]# make CFLAGS=-fPIC
[root@mysql libunwind-1.1]# make CFLAGS=-fPIC install

2.安裝google-perftools

下載地址:https://code.google.com/p/gperftools (注意:要×××才能下載)

[root@mysql ~]#tar zxvf gperftools-2.1.tar.gz 
[root@mysql ~]#cd gperftools-2.1
[root@mysql gperftools-2.1]# ./configure 
[root@mysql gperftools-2.1]# make && make install
[root@mysql gperftools-2.1]# echo "/usr/local/lib" > /etc/ld.so.conf.d/usr_local_lib.conf
[root@mysql gperftools-2.1]# ldconfig

3.從新編譯Nginx

 要讓Nginx支持google-perftools,要在安裝過程當中添加--with-google_perftools_module模塊:

[root@mysql nginx-1.6.2]# ./configure --prefix=/usr/local/nginx/ \
> --with-google_perftools_module \
> --with-http_stub_status_module
[root@mysql nginx-1.6.2]# make && make install

4.建立一個線程目錄,把文件放在/tmp/tcmalloc下面:

[root@mysql ~]# mkdir /tmp/tcmalloc
[root@mysql ~]# chmod 0777 /tmp/tcmalloc/

5.修改Nginx主配置文件

在pid行下面添加以下代碼:

#pid        /usr/local/nginx/nginx.pid;
google_perftools_profiles /tmp/tcmalloc;

重啓Nginx,完成加載!

6.驗證運行狀態

lsof -n|grep tcamlloc


3、Nginx內核參數優化

關於內核參數的優化(/etc/sysctl.conf):

net.ipv4.tcp_max_tw_buckets = 6000timewait的數量,默認是180000。

net.ipv4.ip_local_port_range =1024    65000容許系統打開的端口範圍。

net.ipv4.tcp_tw_recycle = 1啓用timewait快速回收。

net.ipv4.tcp_tw_reuse = 1開啓重用。容許將TIME-WAITsockets從新用於新的TCP鏈接。

net.ipv4.tcp_syncookies = 1開啓SYN Cookies,當出現SYN等待隊列溢出時,啓用cookies來處理。

net.core.somaxconn = 262144web應用中listen函數的backlog默認會給咱們內核參數的net.core.somaxconn限制到128,而nginx定義的NGX_LISTEN_BACKLOG默認爲511,因此有必要調整這個值。

net.core.netdev_max_backlog = 262144每一個網絡接口接收數據包的速率比內核處理這些包的速率快時,容許送到隊列的數據包的最大數目。

net.ipv4.tcp_max_orphans = 262144系統中最多有多少個TCP套接字不被關聯到任何一個用戶文件句柄上。若是超過這個數字,孤兒鏈接將即刻被複位並打印出警告信息。這個限制僅僅是爲了防止簡單的DoS***,不能過度依靠它或者人爲地減少這個值,更應該增長這個值(若是增長了內存以後)。

net.ipv4.tcp_max_syn_backlog = 262144記錄的那些還沒有收到客戶端確認信息的鏈接請求的最大值。對於有128M內存的系統而言,缺省值是1024,小內存的系統則是128。

net.ipv4.tcp_timestamps = 0時間戳能夠避免序列號的卷繞。一個1Gbps的鏈路確定會遇到之前用過的序列號。時間戳可以讓內核接受這種「異常」的數據包。這裏須要將其關掉。

net.ipv4.tcp_synack_retries = 1爲了打開對端的鏈接,內核須要發送一個SYN並附帶一個迴應前面一個SYN的ACK。也就是所謂三次握手中的第二次握手。這個設置決定了內核放棄鏈接以前發送SYN+ACK包的數量。

net.ipv4.tcp_syn_retries = 1在內核放棄創建鏈接以前發送SYN包的數量。

net.ipv4.tcp_fin_timeout = 1若是套接字由本端要求關閉,這個參數決定了它保持在FIN-WAIT-2狀態的時間。對端能夠出錯並永遠不關閉鏈接,甚至意外當機。缺省值是60 秒。2.2 內核的一般值是180秒,你能夠按這個設置,但要記住的是,即便你的機器是一個輕載的WEB服務器,也有由於大量的死套接字而內存溢出的風險,FIN- WAIT-2的危險性比FIN-WAIT-1要小,由於它最多隻能吃掉1.5K內存,可是它們的生存期長些。

net.ipv4.tcp_keepalive_time = 30當keepalive起用的時候,TCP發送keepalive消息的頻度。缺省是2小時。

相關文章
相關標籤/搜索