nginx配置優化+負載均衡+動靜分離詳解

nginx配置以下:javascript

#指定nginx進程運行用戶以及用戶組
user www www;
#nginx要開啓的進程數爲8
worker_processes 8;
#全局錯誤日誌文件
#debug輸出日誌最爲詳細,而crit輸出日誌最少/var/log目錄是linux下的日誌存放目錄
error_log /var/log/nginx/nginx_error.log crit;
#指定進程id的存儲位置
pid /var/run/nginx.pid;
#綁定worker進程和CPU,linux內核2.4以上可用
worker_rlimit_nofile 51200;
#nginx的工做模式及鏈接輸上線
events {
#nginx工做模式,epoll是linux平臺下的高效模式
use epoll;
#定義nginx每一個進程的最大鏈接數爲51200,通常網上都配置65535,根據張宴大神的建議51200便可
worker_connections 51200;
}css

http {
#實現對配置文件所包含的文件的設定
include mime.types;
#設置默認類型爲二進制流
default_type application/octet-stream;html

server_names_hash_bucket_size 128;
#指定來自客戶端請求頭的headerbuffer大小,設置爲32KB
client_header_buffer_size 32k;
#指定客戶端請求中較大的消息頭的緩存最大數量和大小,這裏是4個32KB
large_client_header_buffers 4 32k;
#上傳文件大小
client_max_body_size 356m;
#nginx的HttpLog模塊指定,指定nginx日誌的輸出格式,輸出格式爲access
log_format access '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
#access日誌存在未知
access_log /var/log/nginx/access.log access;
#開啓高效模式文件傳輸模式,將tcp_nopush和tcp_nodely兩個指另設置爲on,用於防止網絡阻塞。
sendfile on;
tcp_nopush on;
tcp_nodely on;
#設置客戶端鏈接保持活動的超時時間
keepalive_timeout 65;
server_tokens off;
#客戶端請求主體讀取緩存
client_body_buffer_size 512k;
proxy_connect_timeout 5;
proxy_send_timeout 60;
proxy_read_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 128k; 前端

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

#開啓gzip
gzip on;
#容許壓縮的最小字節數
gzip_min_length 1k;
#4個單位爲16k的內存做爲壓縮結果流緩存
gzip_buffers 4 16k;
#設置識別HTTP協議版本,默認是1.1
gzip_http_version 1.1;
#gzip壓縮比,可在1~9中設置,1壓縮比最小,速度最快,9壓縮比最大,速度最慢,消耗CPU
gzip_comp_level 2;
#壓縮的類型
gzip_types text/plain application/x-javascript text/css application/xml;
#讓前端的緩存服務器混村通過的gzip壓縮的頁面
gzip_vary on;

#負載均衡
upstream localhost.com {
#每一個請求按照ip的hash結果分配,同一個ip的訪客固定訪問一個後端服務器,可解決動態網頁session共享問題。
ip_hash;
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
禁止經過ip訪問
server {
server_name _;
return 404;
}
server {
listen 88;
server_name www.test.com;# 對應你的域名
charset utf-8; #設置編碼爲utf-8
index index.html index.htm index.jsp index.do index.action;
#指定虛擬主機根目錄爲/var/www/
root /var/www/;
if ( -d $request_filename)
{
rewrite ^/(.*)([^/])$ http://$host/$1$2/permanent;
}
#方法1:將jsp等動態文件交給的localhost.com處理,此方法用的很少
location ~ \.(jsp|jspx|do|action)(\/.*)?$ {
index index.jsp;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://localhost.com;
}
#方法2:將全部請求交給localhost.com處理,靜態文件經過額外定義location交給nginx處理。
location / {
#當502或504時,將請求轉發到負載均衡中正常server中
proxy_next_upstream http_502 http_504 error timeout invalid_header;
proxy_pass http://localhost.com;
proxy_redirect off;
proxy_set_header Host $host;
#若nginx爲最前端時,後端得到X-Real-IP傳遞的ip即爲實際ip,若nginx不是最前端時,實際ip爲X-Forwarded-For值。
proxy_set_header X-Forwarded-For $remote_addr;
}
#靜態文件交給nginx處理
location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$
{
root /var/www;
expires 30d;
}
#靜態文件交給nginx處理
location ~ .*\.(js|css)?$
{
root /var/www;
expires 1h;
}
location /media {
#指定後端服務器地址和端口
proxy_pass http://localhost.com;
#proxy_next_upstream 故障轉移待空
proxy_redirect off;
#後端服務器獲取用戶的主機名或真實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;
#後端服務器的數據回傳時間90s,90s內未傳回,nginx將斷開鏈接
proxy_send_timeout 90;
#nginx從代理的後端服務器獲取信息的時間90s
proxy_read_timeout 90;

#緩衝區大小默認等於proxy_buffers設置的大小
proxy_buffer_size 4k;
#設置緩衝區的數量和大小
proxy_buffers 4 32k;
#設置系統很忙時能夠使用的proxy_buffers的大小,官方推薦位proxy_buffersX2
proxy_busy_buffers_size 64k;
#指定proxy緩存臨時文件的大小
proxy_temp_file_write_size 64k;
}
location /files/ {
#靜止外部訪問
internal;
#
alias /home/nfs/media/;
}
}
# HTTPS server配置
server {
listen 443;
server_name www.test.com; # 對應你的域名
root /var/www/webapps;

ssl on;
ssl_certificate /usr/local/nginx/conf/test.crt;
ssl_certificate_key /usr/local/nginx/conf/test_nopass.key;java

ssl_session_timeout 5m;node

ssl_protocols SSLv2 SSLv3 TLSv1;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;linux

location / {
root html;
index index.html index.htm;
}
}
}nginx

 

更多信息請關注個人我的博客 http://www.chainhots.com/web

相關文章
相關標籤/搜索