linux nginx虛擬主機配置和日誌管理

 

nginx配置文件:php

/usr/local/nginx/conf/nginx.confhtml

Nginx配置段nginx

// 全局區
worker_processes 1; // 有1個工做的子進程,能夠自行修改,但太大無益,由於要爭奪CPU,通常設置爲 CPU數*核數web

event {
// 通常是配置nginx鏈接的特性
// 如1個worker能同時容許多少鏈接
 worker_connections  1024; // 這是指 一個子進程最大容許連1024個鏈接
}shell

http {  //這是配置http服務器的主要段
     server1 { // 這是虛擬主機段
       
            location {  //定位,把特殊的路徑或文件再次定位 ,如image目錄單獨處理
            }             /// 如.php單獨處理服務器

     }3d

     server2 {
     }
}代理

1.基於域名的虛擬主機日誌

server {
        listen 80;  #監聽端口
        server_name a.com; #監聽域名
orm

        location / {
                root /var/www/a.com;   #根目錄定位
                index index.html;
        }
    }

編輯/usr/local/nginx/conf/nginx.conf,添加配置:

在 /usr/local/nginx/ 下建立目錄 lhy ,並在/lhy 下建立 index.html 

index.html :

宿主機器配置host: 192.168.85.3  lhy.com 

重啓nginx,訪問 lhy.com:8888 :

2.日誌管理:

access.log  : 正確訪問日誌

error.log  : 錯誤日誌

裏面有個nginx.pid 文件,記錄着當前nginx的進程號:

關閉 nginx 就是根據這個文件來找到nginx進程的,而後kill掉。

查看日誌:tail -f -n 200 access.log 

日誌文件配置:

Nginx容許針對不一樣的server作不一樣的Log

 

咱們觀察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格式;

 

例子:自定義日誌文件,指定好目錄後,nginx會自動建立該日誌文件

Nginx作日誌切分

步驟:一、編寫shell  二、定時任務對腳本進行調度 :crontab -e

******************************************************************************************************************************************************************************

使用crontab你能夠在指定的時間執行一個shell腳本或者一系列Linux命令。例如系統管理員安排一個備份任務使其天天都運行

如何往 cron 中添加一個做業?

 

# crontab –e
0 5 * * * /root/bin/backup.sh

 

這將會在天天早上5點運行 /root/bin/backup.sh

*******************************************************************************************************************************************************************************

shell腳本 log.sh:這裏演示每分鐘一本分,實際一天一備份就行。

#!/bin/sh

BASE_DIR=/usr/local/nginx
BASE_FILE_NAME=lhy.access.log

CURRENT_PATH=$BASE_DIR/logs
BAK_PATH=$BASE_DIR/datalogs

CURRENT_FILE=$CURRENT_PATH/$BASE_FILE_NAME
BAK_TIME=`/bin/date -d yesterday +%Y%m%d%H%M`
BAK_FILE=$BAK_PATH/$BAK_TIME-$BASE_FILE_NAME
echo $BAK_FILE

$BASE_DIR/sbin/nginx -s stop

mv $CURRENT_FILE $BAK_FILE

$BASE_DIR/sbin/nginx

 

更多php技術交流,可加Q羣:884743303,裏面各路大神爲您保駕護航,

相關文章
相關標籤/搜索