環境:CentOS-6.4php
Nginx版本:nginx-1.6.2.tarhtml
Linux鏈接工具:XShellnginx
VMWare虛擬機上準備兩臺CentOS:c++
兩臺機器作一樣操做(後邊作負載均衡、高可用的時候用)web
1,上傳包:shell
使用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
咱們觀察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
其中黃色部分應該和 /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 天天0時1分(建議在02-04點之間,系統負載小)