1. 程式人生 > >nginx基本配置與引數說明以及Nginx中的upstream輪詢機制介紹

nginx基本配置與引數說明以及Nginx中的upstream輪詢機制介紹

一.nginx簡介

        Nginx (發音為[engine x])專為效能優化而開發,其最知名的優點是它的穩定性和低系統資源消耗,以及對併發連線的高處理能力(單臺物理伺服器可支援30000~50000個併發連線), 是一個高效能的 HTTP 和反向代理伺服器,也是一個IMAP/POP3/SMTP 代理服。

        實際使用中,nginx主要:反向代理、負載均衡

二.nginx基本配置與引數說明

#執行使用者

user nobody;

#啟動程序,通常設定成和cpu的數量相等

worker_processes  1;
#全域性錯誤日誌及PID檔案
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;
#工作模式及連線數上限

events {

    #epoll是多路複用IO(I/O Multiplexing)中的一種方式,

    #僅用於linux2.6以上核心,可以大大提高nginx的效能 

use   epoll;
    #單個後臺worker process程序最大併發連結數 
worker_connections  1024;

    # 併發總數是 worker_processes 和 worker_connections 的乘積

    # 即 max_clients = worker_processes * worker_connections

    # 在設定了反向代理的情況下,max_clients = worker_processes * worker_connections / 4  為什麼

    # 為什麼上面反向代理要除以4,應該說是一個經驗值

    # 根據以上條件,正常情況下的Nginx Server可以應付的最大連線數為:4 * 8000 = 32000

    # worker_connections 值的設定跟實體記憶體大小有關

    # 因為併發受IO約束,max_clients的值須小於系統可以開啟的最大檔案數

    # 而系統可以開啟的最大檔案數和記憶體大小成正比,一般1GB記憶體的機器上可以開啟的檔案數大約是10萬左右

    # 我們來看看360M記憶體的VPS可以開啟的檔案控制代碼數是多少:

    # $ cat /proc/sys/fs/file-max

    # 輸出 34336

    # 32000 < 34336,即併發連線總數小於系統可以開啟的檔案控制代碼總數,這樣就在作業系統可以承受的範圍之內

    # 所以,worker_connections 的值需根據 worker_processes 程序數目和系統可以開啟的最大檔案總數進行適當地進行設定

    # 使得併發總數小於作業系統可以開啟的最大檔案數目

    # 其實質也就是根據主機的物理CPU和記憶體進行配置

    # 當然,理論上的併發總數可能會和實際有所偏差,因為主機還有其他的工作程序需要消耗系統資源。

    # ulimit -SHn 65535

}

#設定http伺服器

http {

    #設定mime型別,型別由mime.type檔案定義  

include    mime.types;

default_type  application/octet-stream;

    #設定日誌格式

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

access_log  logs/access.log  main;

    #sendfile 指令指定 nginx 是否呼叫 sendfile 函式(zero copy 方式)來輸出檔案,

    #對於普通應用,必須設為 on,

    #如果用來進行下載等應用磁碟IO重負載應用,可設定為 off,

    #以平衡磁碟與網路I/O處理速度,降低系統的uptime. 

sendfile     on;

    #tcp_nopush     on;

    #連線超時時間

    #keepalive_timeout  0;  

keepalive_timeout  65;
tcp_nodelay     on;

 #FastCGI相關引數是為了改善網站的效能:減少資源佔用,提高訪問速度。下面引數看字面意思都能理解。

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;

      #upstream的負載均衡,(以權重方式分發),weight是權重,可以根據機器配置定義權重。weigth引數表示權值,權值越高被分配到的機率越大。

upstream blog.nginx.com {
    server 192.168.80.121:80 weight=3;
    server 192.168.80.122:80 weight=2;
    server 192.168.80.123:80 weight=3;
}

      #upstream的負載均衡,(以nginx熱備方式分發),其它所有的非backup Server down或者忙的時候,請求backup機器。所以這臺機器壓力會最輕

upstream blog.nginx.com {
    server 192.168.80.121:80;
    server 192.168.80.122:80;
    server 192.168.80.123:80 backup;
}

    #開啟gzip壓縮   

gzip  on;
gzip_disable "MSIE [1-6].";

    #設定請求緩衝   

client_header_buffer_size    128k;
large_client_header_buffers  4 128k; 

    #設定虛擬主機配置

    server {

        #偵聽80埠   

listen    80;

        #定義訪問地址,域名可以有多個,用空格隔開     

server_name www.nginx.cn nginx.cn ;

        #定義伺服器的預設網站根目錄位置 

root html;

        #設定本虛擬主機的訪問日誌   

access_log  logs/nginx.access.log  main; 

        #預設請求      

location / {            
   #定義首頁索引檔案的名稱
   index index.php index.html index.htm;   
}
        #對 “/” 啟用反向代理
location / {
    proxy_pass http://127.0.0.1:88;
    proxy_redirect off;
    proxy_set_header X-Real-IP $remote_addr;
    #後端的Web伺服器可以通過X-Forwarded-For獲取使用者真實IP
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    #以下是一些反向代理的配置,可選。
    proxy_set_header Host $host;
    client_max_body_size 10m; #允許客戶端請求的最大單檔案位元組數
    client_body_buffer_size 128k; #緩衝區代理緩衝使用者端請求的最大位元組數,
    proxy_connect_timeout 90; #nginx跟後端伺服器連線超時時間(代理連線超時)
    proxy_send_timeout 90; #後端伺服器資料回傳時間(代理髮送超時)
    proxy_read_timeout 90; #連線成功後,後端伺服器響應時間(代理接收超時)
    proxy_buffer_size 4k; #設定代理伺服器(nginx)儲存使用者頭資訊的緩衝區大小
    proxy_buffers 4 32k; #proxy_buffers緩衝區,網頁平均在32k以下的設定
    proxy_busy_buffers_size 64k; #高負荷下緩衝大小(proxy_buffers*2)
    proxy_temp_file_write_size 64k;
    #設定快取資料夾大小,大於這個值,將從upstream伺服器傳
}
       #設定檢視Nginx狀態的地址
location /NginxStatus {
    stub_status on;
    access_log on;
    auth_basic “NginxStatus”;
    auth_basic_user_file conf/htpasswd;
    #htpasswd檔案的內容可以用apache提供的htpasswd工具來產生。
}
       #本地動靜分離反向代理配置

        #所有jsp的頁面均交由tomcat或resin處理

location ~ .(jsp|jspx|do)?$ {
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://127.0.0.1:8080;
}

    #所有靜態檔案由nginx直接讀取不經過tomcat或resin

location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt
                |pdf|xls|mp3|wma)$ { 
    expires 15d; 
}
location ~ .*.(js|css)?$ { 
    expires 1h; 
}

        # 定義錯誤提示頁面     

error_page   500 502 503 504 /50x.html;
location = /50x.html {
} 

        #靜態檔案快取時間設定,nginx自己處理    

location ~ ^/(images|javascript|js|css|flash|media|static)/ {            
   #過期30天,靜態檔案不怎麼更新,過期可以設大一點,
   #如果頻繁更新,則可以設定得小一點。
   expires 30d;
}

        #PHP 指令碼請求全部轉發到 FastCGI處理. 使用FastCGI預設配置.

location ~ .php$ {
   fastcgi_pass 127.0.0.1:9000;
   fastcgi_index index.php;
   fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
   include fastcgi_params;
}

        #禁止訪問 .htxxx 檔案    

location ~ /.ht {
   deny all;
}

    }

}

三.nginx配置超時時間

四.Nginx中的upstream輪詢機制介紹【負載均衡】

Nginx中upstream有以下幾種方式:

1、輪詢(weight=1) 
預設選項,當weight不指定時,各伺服器weight相同, 每個請求按時間順序逐一分配到不同的後端伺服器,如果後端伺服器down掉,能自動剔除。

upstream bakend {
    server 192.168.1.10;
    server 192.168.1.11;
}

2、weight 
指定輪詢機率,weight和訪問比率成正比,用於後端伺服器效能不均的情況。 
 如果後端伺服器down掉,能自動剔除。 
 比如下面配置,則1.11伺服器的訪問量為1.10伺服器的兩倍。

upstream bakend {
    server 192.168.1.10 weight=1;
    server 192.168.1.11 weight=2;
}

3、ip_hash 
每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問一個後端伺服器,可以解決session不能跨伺服器的問題。 
如果後端伺服器down掉,要手工down掉。

upstream resinserver{
    ip_hash;
    server 192.168.1.10:8080;
    server 192.168.1.11:8080;
}

4、fair(第三方外掛) 
按後端伺服器的響應時間來分配請求,響應時間短的優先分配。

upstream resinserver{
    server 192.168.1.10:8080;
    server 192.168.1.11:8080;
    fair;
}

5、url_hash(第三方外掛) 
 按訪問url的hash結果來分配請求,使每個url定向到同一個後端伺服器,後端伺服器為快取伺服器時比較有效。 
 在upstream中加入hash語句,hash_method是使用的hash演算法

upstream resinserver{
   server 192.168.1.10:8080;
   server 192.168.1.11:8080;
   hash $request_uri;
   hash_method crc32;
}

裝置的狀態有: 
1.down 表示單前的server暫時不參與負載 
2.weight 權重,預設為1。 weight越大,負載的權重就越大。 
3.max_fails 允許請求失敗的次數預設為1。當超過最大次數時,返回proxy_next_upstream 模組定義的錯誤 
4.fail_timeout max_fails次失敗後,暫停的時間。 
5.backup 備用伺服器, 其它所有的非backup機器down或者忙的時候,請求backup機器。所以這臺機器壓力會最輕。

五.nginx啟動、重啟、關閉操作介紹

啟動nginx:
nginx -c /path/to/nginx.conf

重啟nginx:
nginx -s reload  :修改配置後重新載入生效
nginx -s reopen  :重新開啟日誌檔案
nginx -t -c /path/to/nginx.conf 測試nginx配置檔案是否正確

關閉nginx:
nginx -s stop  :快速停止nginx
         quit  :完整有序的停止nginx

其他的停止nginx 方式:

ps -ef | grep nginx

kill -QUIT 主程序號     :從容停止Nginx
kill -TERM 主程序號     :快速停止Nginx
pkill -9 nginx          :強制停止Nginx

平滑重啟nginx:
kill -HUP 主程序號

相關推薦

nginx基本配置引數說明以及Nginxupstream機制介紹

一.nginx簡介         Nginx (發音為[engine x])專為效能優化而開發,其最知名的優點是它的穩定性和低系統資源消耗,以及對併發連線的高處理能力(單臺物理伺服器可支援30000~50000個併發連線), 是一個高效能的 HTTP 和反向代理伺服器,也

nginx基本配置引數說明

#執行使用者 user nobody;#啟動程序,通常設定成和cpu的數量相等 worker_processes 1;#全域性錯誤日誌及PID檔案#error_log logs/error.log;#error_log logs/error.log notice;

Nginx基本配置應用

sed stat 3.3 star pes nlp lin 查看 mon 一、準備 1.1 環境準備 CentOS7軟件環境 1.2 tomcat多實例 把/etc/profile.d/tomcat.sh中的變量註釋了 #export TOMCAT_HOME=/usr/lo

nginx基本配置參數說明

http 類型 多少 格式 大並發 out 文件的 index str user nobody; #啟動進程,通常設置成和cpu的數量相等 worker_processes 1; #全局錯誤日誌及PID文件 #error_log logs/error.log; #e

nginx配置檔案學習,以及nginx的反向代理和負載均衡

1.nginx.conf主配置檔案學習 worker_processes 4: 表示nginx的程序數,根據CPU的核數來定義,起到優化的作用。通過cat /proc/cpuinfo來檢視核數 events { worker_connections 1024; #連線數 }

nginx基本命令配置

基本命令    /usr/local/nginx/sbin/nginx -h #幫助  /usr/local/nginx/sbin/nginx -v #顯示版本  /usr/local/nginx/sbin/nginx -V #顯示版本和配置資訊 

NGINX基本模組配置

一、NGINX內建的基本模組 1、NGINX核心模組 2、EVENTS模組 3、HTTP核心模組 二、NGINX基本配置檔案 #user nobody; worker_processes 1; #error_log logs/error.log; #error_lo

nginx基本配置參數說明

clas expire 日誌 反向 平衡 file format root pass #運行用戶 user nobody; #啟動進程,通常設置成和cpu的數量相等 worker_processes 1; #全局錯誤日誌及PID文件 #error_log logs/

Djano + Nginx + docker配置管理

file corn 完成 項目 Beginner 一起 管理 add 文件 在配置這個服務之前,應該對docker的基本安裝與使用應該很熟悉了。下面開始直接不如正題 1.讓我們創建一個名為myproject的空目錄,並在src名稱內添加另一個文件夾。src應該包含djang

Nginx安裝配置訪問統計

ln -s 是否 use ati nginx 服務 hat 代理服務 tex smtp Nginx (engine x) 是一個高性能的HTTP和反向代理服務,也是一個IMAP/POP3/SMTP服務。Nginx是由伊戈爾·賽索耶夫為俄羅斯訪問量第二的Rambler.ru站

Nginx基本配置詳解

Nginx在專案使用中,使用最多的三個核心功能是反向代理、負載均衡和靜態伺服器。 1、nginx支援的負載均衡排程演算法方式:     1)weight輪詢(預設):接收到的請求按照順序逐一分配到不同的後端伺服器,即使在使用過程中,某一臺後端伺服器宕       

nginx基本配置學習

關於代理 正向代理:也就是一個代理,其工作原理就是一個跳板,加入我要訪問google.com,但不能直接訪問,可以通過訪問A,A可以訪問到google.com,A此時就可以作為一個正向代理。正向代理是一個位於客戶端和原始伺服器(例如google)之間的伺服器,然後代理向原始伺服器轉交請求並將獲得

Nginx基本配置和作用

nginx可以重新載入檔案的。我們直接執行:nginx -s reload  配置檔案有沒有問題,可以直接輸入:nginx -t nginx -s stop就可以關閉 但有時我們就不想它掛的時候訪問另外一個,而只是希望一個伺服器訪問的機會比另外一個大,使用weight

Nginx安裝配置,支援http以及https

一、Nginx安裝    如果yum安裝失敗,可從這個地方***下載相關rpm包,直接執行install.sh安裝即可二、配置http    修改配置檔案nginx.conf,安裝上邊的步驟安裝,應該是在/usr/local/webserver/nginx/conf這個目錄下

《深入理解Nginx》閱讀實踐(一):Nginx安裝配置HelloWorld

#include <ngx_config.h> #include <ngx_core.h> #include <ngx_http.h> static char* ngx_http_mytest(ngx_conf_t *cf,ngx_command_t *cmd,

apache+nginx基本配置

apache基本配置 在Ubuntu的apache的配置檔案是 /etc/apache2/apache2.conf,apache在啟動時會自動讀取這個檔案的配置資訊。而其他的一些配置檔案,則是通過Include載入的。 # Include module co

nginx基本配置整理

前言 記性不好,遇到的相關nginx問題和解決方法都會擴充在上面,如有問題請留言。 目錄 安裝nginx 裝好gcc g++ 開發庫環境 ubunto $ apt-get install build-essential $ apt-g

nginx基本配置

摘自《Nginx高效能web伺服器實戰教程》 1、配置檔案結構 塊 說明

mybatis入門篇基——基本配置參數說明

*** values resource clas mybatis prop 測試 mapper ppi Mybatis   好吧這是我第一次寫這種文章~如果有不足和錯誤之處歡迎評論,指點。今天想談談關於mybatis的一些基礎入門知識。   進入正題~~:   a.關於my

防火墻(ASA)的基本配置遠程管理

ssh asa asdm 楊書凡 狀態化防火墻 在目前大多數安全解決方案中,防火墻的實施是最為重要的需求,它是每個網絡基礎設施必要且不可分割的組成部分。這篇博客主要介紹防火墻安全算法的原理與基本配置以及遠程管理防火墻的幾種方式硬件與軟件防火墻1.軟件防火墻 軟件防火墻單獨使用軟