nginx 配置模板

請求反向代理:javascript

1.注意nginx代理的是請求,nginx代理服務器做用是把請求轉發到目標服務器,而不是替代客服端直接訪問目標服務;php

2.訪問目標服務器。客戶端request使用代理服務器的域訪問,nginx接到請求,處理模塊處理,根據location匹配規則,轉發到目標服務器,css

  目標服務器不知道是nginx轉發的,接受到的request使用的ip仍然是客戶端ip。若是客服端與目標服務器網絡不通,請求失敗。html

正向代理:java

客戶端沒法直接訪問目標服務器,nginx做爲跳板訪問目標服務器,把結果給客服端node

 

# 運行用戶
user www-data; 
# 啓動進程,一般設置成和cpu的數量相等
worker_processes 1;

# 全局錯誤日誌及PID文件
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;

# 工做模式及鏈接數上限
events {
 use epoll; #epoll是多路複用IO(I/O Multiplexing)中的一種方式,可是僅用於linux2.6以上內核,能夠大大提升nginx的性能
 worker_connections 1024; #單個後臺worker process進程的最大併發連接數
 # multi_accept on; 
}

#設定http服務器,利用它的反向代理功能提供負載均衡支持
http {
 #設定mime類型,類型由mime.type文件定義
 include /etc/nginx/mime.types;
 default_type application/octet-stream;
 #設定日誌格式
 access_log /var/log/nginx/access.log;

 #sendfile 指令指定 nginx 是否調用 sendfile 函數(zero copy 方式)來輸出文件,對於普通應用,
 #必須設爲 on,若是用來進行下載等應用磁盤IO重負載應用,可設置爲 off,以平衡磁盤與網絡I/O處理速度,下降系統的uptime.
 sendfile on;
 #將tcp_nopush和tcp_nodelay兩個指令設置爲on用於防止網絡阻塞
 tcp_nopush on;
 tcp_nodelay on;
 #鏈接超時時間
 keepalive_timeout 65;

 #開啓gzip壓縮
 gzip on;
 gzip_disable "MSIE [1-6]\.(?!.*SV1)";

 #設定請求緩衝
 client_header_buffer_size 1k;
 large_client_header_buffers 4 4k;

 include /etc/nginx/conf.d/*.conf;
 include /etc/nginx/sites-enabled/*;

 #設定負載均衡的服務器列表
 upstream mysvr {
 #weigth參數表示權值,權值越高被分配到的概率越大
 #本機上的Squid開啓3128端口
 server 192.168.8.1:3128 weight=5;
 server 192.168.8.2:80 weight=1;
 server 192.168.8.3:80 weight=6;
 }


 server {
 #偵聽80端口
 listen 80;
 #定義使用www.xx.com訪問
 server_name www.xx.com;

 #設定本虛擬主機的訪問日誌
 access_log logs/www.xx.com.access.log main;

 #默認請求
 location / {
 root /root; #定義服務器的默認網站根目錄位置
 index index.php index.html index.htm; #定義首頁索引文件的名稱

 fastcgi_pass www.xx.com;
 fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name; 
 include /etc/nginx/fastcgi_params;
 }

 # 定義錯誤提示頁面
 error_page 500 502 503 504 /50x.html; 
 location = /50x.html {
 root /root;
 }

 #靜態文件,nginx本身處理
 location ~ ^/(images|javascript|js|css|flash|media|static)/ {
 root /var/www/virtual/htdocs;
 #過時30天,靜態文件不怎麼更新,過時能夠設大一點,若是頻繁更新,則能夠設置得小一點。
 expires 30d;
 }
 #PHP 腳本請求所有轉發到 FastCGI處理. 使用FastCGI默認配置.
 location ~ \.php$ {
 root /root;
 fastcgi_pass 127.0.0.1:9000;
 fastcgi_index index.php;
 fastcgi_param SCRIPT_FILENAME /home/www/www$fastcgi_script_name;
 include fastcgi_params;
 }
 #設定查看Nginx狀態的地址
 location /NginxStatus {
 stub_status on;
 access_log on;
 auth_basic "NginxStatus";
 auth_basic_user_file conf/htpasswd;
 }
 #禁止訪問 .htxxx 文件
 location ~ /\.ht {
 deny all;
 }

 }

 #第一個虛擬服務器
 server {
 #偵聽192.168.8.x的80端口
 listen 80;
 server_name 192.168.8.x;

 #對aspx後綴的進行負載均衡請求
 location ~ .*\.aspx$ {
 root /root;#定義服務器的默認網站根目錄位置
 index index.php index.html index.htm;#定義首頁索引文件的名稱

 proxy_pass http://mysvr;#請求轉向mysvr 定義的服務器列表

 #如下是一些反向代理的配置可刪除.
 proxy_redirect off;

 #後端的Web服務器能夠經過X-Forwarded-For獲取用戶真實IP
 proxy_set_header Host $host;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 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服務器傳
 }
 }
}

  

# 運行用戶user www-data; # 啓動進程,一般設置成和cpu的數量相等worker_processes 1;
# 全局錯誤日誌及PID文件error_log /var/log/nginx/error.log;pid /var/run/nginx.pid;
# 工做模式及鏈接數上限events { use epoll; #epoll是多路複用IO(I/O Multiplexing)中的一種方式,可是僅用於linux2.6以上內核,能夠大大提升nginx的性能 worker_connections 1024; #單個後臺worker process進程的最大併發連接數 # multi_accept on; }
#設定http服務器,利用它的反向代理功能提供負載均衡支持http { #設定mime類型,類型由mime.type文件定義 include /etc/nginx/mime.types; default_type application/octet-stream; #設定日誌格式 access_log /var/log/nginx/access.log;
 #sendfile 指令指定 nginx 是否調用 sendfile 函數(zero copy 方式)來輸出文件,對於普通應用, #必須設爲 on,若是用來進行下載等應用磁盤IO重負載應用,可設置爲 off,以平衡磁盤與網絡I/O處理速度,下降系統的uptime. sendfile on; #將tcp_nopush和tcp_nodelay兩個指令設置爲on用於防止網絡阻塞 tcp_nopush on; tcp_nodelay on; #鏈接超時時間 keepalive_timeout 65;
 #開啓gzip壓縮 gzip on; gzip_disable "MSIE [1-6]\.(?!.*SV1)";
 #設定請求緩衝 client_header_buffer_size 1k; large_client_header_buffers 4 4k;
 include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*;
 #設定負載均衡的服務器列表 upstream mysvr { #weigth參數表示權值,權值越高被分配到的概率越大 #本機上的Squid開啓3128端口 server 192.168.8.1:3128 weight=5; server 192.168.8.2:80 weight=1; server 192.168.8.3:80 weight=6; }

 server { #偵聽80端口 listen 80; #定義使用www.xx.com訪問 server_name www.xx.com;
 #設定本虛擬主機的訪問日誌 access_log logs/www.xx.com.access.log main;
 #默認請求 location / { root /root; #定義服務器的默認網站根目錄位置 index index.php index.html index.htm; #定義首頁索引文件的名稱
 fastcgi_pass www.xx.com; fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;  include /etc/nginx/fastcgi_params; }
 # 定義錯誤提示頁面 error_page 500 502 503 504 /50x.html;  location = /50x.html { root /root; }
 #靜態文件,nginx本身處理 location ~ ^/(images|javascript|js|css|flash|media|static)/ { root /var/www/virtual/htdocs; #過時30天,靜態文件不怎麼更新,過時能夠設大一點,若是頻繁更新,則能夠設置得小一點。 expires 30d; } #PHP 腳本請求所有轉發到 FastCGI處理. 使用FastCGI默認配置. location ~ \.php$ { root /root; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /home/www/www$fastcgi_script_name; include fastcgi_params; } #設定查看Nginx狀態的地址 location /NginxStatus { stub_status on; access_log on; auth_basic "NginxStatus"; auth_basic_user_file conf/htpasswd; } #禁止訪問 .htxxx 文件 location ~ /\.ht { deny all; }
 }
 #第一個虛擬服務器 server { #偵聽192.168.8.x的80端口 listen 80; server_name 192.168.8.x;
 #對aspx後綴的進行負載均衡請求 location ~ .*\.aspx$ { root /root;#定義服務器的默認網站根目錄位置 index index.php index.html index.htm;#定義首頁索引文件的名稱
 proxy_pass http://mysvr;#請求轉向mysvr 定義的服務器列表
 #如下是一些反向代理的配置可刪除. proxy_redirect off;
 #後端的Web服務器能夠經過X-Forwarded-For獲取用戶真實IP proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 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服務器傳 } }}linux

相關文章
相關標籤/搜索