CentOS安裝Nginx 以及日志管理


環境:CentOS-6.4

Nginx版本:nginx-1.6.2.tar

Linux連接工具:XShell

VMWare虛擬機上准備兩台CentOS:

兩台機器做同樣操作(后邊做負載均衡、高可用的時候用)

1,上傳包:

使用rz命令,將准備好的nginx的包上傳到Linux:(或者使用 wget下載: http://nginx.org/download/nginx-1.4.2.tar.gz )

2,下載鎖需要的依賴庫文件:

yum install pcre

yum install pcre-devel

yum install zlib

yum install zlib-devel

3,解壓

 將nginx壓縮包解壓到 /usr/local 目錄下命令:  tar -zxvf nginx-1.6.2.tar.gz -C /usr/local     

4,

進行configure配置:cd nginx-1.6.2 && ./configure --prefix=/usr/local/nginx  查看是否報錯

 

出現:

 說明沒什么問題。

但是我的就報錯了,缺少一些包,沒報錯的略過此步驟。

yum -y install gcc

yum -y install gcc-c++

yum install make

 5,編譯安裝 make && make install 

安裝完成。

 安裝完成后,在 /usr/local 下,可以看到兩個有關nginx的目錄:

 nginx目錄:

cd /usr/local/nginx目錄下: 看到如下4個目錄

 ....conf 配置文件  

 ... html 網頁文件

 ...logs  日志文件 

 ...sbin  主要二進制程序

啟動ngxin :cd 到nginx目錄下, ./nginx  或者 /usr/local/nginx/sbin/nginx

瀏覽器輸入:http://192.168.85.3  可以看到歡迎頁面:

重啟:/usr/local/nginx/sbin/nginx -s reload

關閉:/usr/local/nginx/sbin/nginx -s stop

 nginx配置文件:

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

Nginx配置段

// 全局區
worker_processes 1; // 有1個工作的子進程,可以自行修改,但太大無益,因為要爭奪CPU,一般設置為 CPU數*核數

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

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

     }

     server2 {
     }
}

 例子1: 基於域名的虛擬主機

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

        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 :

 日志管理:

access.log  : 正確訪問日志

error.log  : 錯誤日志

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

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

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

日志文件配置:

Nginx允許針對不同的server做不同的Log

 

我們觀察nginxserver

 

 

,可以看到如下類似信息

 #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做日志切分

步驟:1、編寫shell  2、定時任務對腳本進行調度 :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

其中黃色部分應該和 /nginx.conf 中的 

一致。

綠色部分是 日志文件存放的目錄,提前在 /nginx下建好。

 

將日志文件上傳到 /usr/local/nginx/sbin  並用命令 chmod 777 log.sh  給log.sh 授權,賦予可讀可寫可執行 權限:

 

新建定時任務:

輸入 

*/1 * * * * sh /usr/local/nginx/sbin/log.sh 

保存並退出。至此完成。

定時切分日志:

 

 

定時任務

Crontab 編輯定時任務

01 00 * * * /xxx/path/b.sh  每天01(建議在02-04點之間,系統負載小)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM