* 因為本例中設置每天0點進行日志的拆分,所以folder和rq均設置采用昨天的日期進行歸檔。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#!/bin/bash folder=` date -d yesterday +%Y%m` rq=` date -d yesterday +%Y%m%d` # 原始日志路徑 logs_path= "/var/log/nginx/sitename.com/" # 日志備份路徑 logs_backup_path= "/var/log/nginx/sitename.com/$folder" # 要分割的日志 logs_access= "access" logs_error= "error" # 創建備份路徑 [ -d $logs_backup_path ]|| mkdir -p $logs_backup_path # 將日志移入備份文件夾 mv ${logs_path}${logs_access}.log ${logs_backup_path}/${logs_access}_${rq}.log mv ${logs_path}${logs_error}.log ${logs_backup_path}/${logs_error}_${rq}.log # 終止nginx的pid pid_path= "/var/run/nginx.pid" kill -USR1 $( cat $pid_path) |
二、測試日志拆分腳本
在.sh文件的存放目錄下運行如下語句,測試拆分腳本是否成功。
# sh splitNginxLog.sh
如果提示$'\r': 未找到命令的解決,則有可能是.sh文件編碼問題,是因為在Windows編輯器中編寫的腳本與在linux中的有一些區別。
處理方法:
1. 安裝dos2unix用于轉化編碼
# yum install dos2unix
2. 轉換編碼
# dos2unix splitNginx.sh
三、設置定時自動執行
# crontab -l //列出所有的定時任務
# crontab -e //編輯定時任務
在其中編寫如下語句:
00 00 * * * bash /root/splitNginxLog.sh
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://www.cnblogs.com/yangjisen/p/12811711.html