視頻學習地址:燕十八nginx精品****
一、Nginx配置段
// 全局區
worker_processes 1; // 有1個工作的子進程,可以自行修改,但太大無益,因爲要爭奪CPU,最多設置爲 CPU數*核數 ,再多無意義
具體查看worker_processes的方式:
events {
// 一般是配置 nginx 鏈接的特性
// 例:一個word能同時允許多少個鏈接
worker_connections 256; // 這是指一個子進程最大允許連 256 個連接
}
http { //這是配置http服務器的主要段
Server1 { // 這是虛擬主機段
Location { //定位,把特殊的路徑或文件再次定位,如image目錄單獨處理
} /// 如.php單獨處理
}
Server2 {
}
}
二、虛擬主機配置
例子1: 基於域名的虛擬主機(簡單配置)
server {
listen 80; #監聽端口
server_name a.com; #監聽域名
location / {
root /var/www/a.com; #根目錄定位(可以寫相對目錄,但這是相對於nginx所在目錄的,nginx默認是nginx/html目錄。Mac中nginx的目錄:/usr/local/Cellar/nginx/(nginx版本號)/
linux中nginx的目錄:/usr/local/nginx/)
index index.html;
}
}
例子2: 基於端口的虛擬主機配置
server {
listen 8080;
server_name 192.168.1.204;
location / {
root /var/www/html8080;
index index.html;
}
}
三、日誌管理
我們觀察nginx的server段,可以看到如下類似信息
#access_log logs/host.access.log main;
這說明該server, 它的訪問日誌的文件是 logs/host.access.log ,
使用的格式」main」格式.
除了main格式,你可以自定義其他格式.
main格式是什麼?
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
main格式是我們定義好一種日誌的格式,並起個名字,便於引用.
以上面的例子, main類型的日誌,記錄的remote_addr.... http_x_forwarded_for等選項.
1: 日誌格式是指記錄哪些選項
默認的日誌格式: main
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
如默認的main日誌格式,記錄這麼幾項
遠程IP- 遠程用戶/用戶時間請求方法(如GET/POST) 請求體body長度referer來源信息
http-user-agent用戶代理/蜘蛛,被轉發的請求的原始IP
http_x_forwarded_for:在經過代理時,代理把你的本來IP加在此頭信息中,傳輸你的原始IP
2: 聲明一個獨特的log_format並命名
log_format mylog '$remote_addr- "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
在下面的server/location,我們就可以引用mylog
在server段中,這樣來聲明:
Nginx允許針對不同的server做不同的Log ,(有的web服務器不支持,如lighttp)
access_log logs/access_8080.log mylog;
聲明log log位置 log格式;
例:access_log logs/access.log mylog;