2017-05-08 27 views
1

請不要告訴我關於unix中的日誌輪換和其他工具。我需要這個腳本。 時,我試圖做到這一點:不工作的腳本,它使nginx的每個日誌文件的gzip

find /root/nginx.log* -type f -print0 -and ! -name "*.gz" -and ! -name "nginx.log.2017.05.08" -exec gzip "{}" \; 

一切正常,我有這樣的結果,我需要:

-rw-r--r-- 1 root root 1381791 May 8 10:33 nginx.log.2017.05.07.gz 
-rw-r--r-- 1 root root 17942221 May 8 10:33 nginx.log.2017.05.08 
-rw-r--r-- 1 root root 1381791 May 8 10:33 nginx.log.2017.05.09.gz 
-rw-r--r-- 1 root root 1381791 May 8 10:33 nginx.log.2017.05.10.gz 
-rw-r--r-- 1 root root 1381791 May 8 10:33 nginx.log.2017.05.11.gz 
-rw-r--r-- 1 root root 1381791 May 8 10:33 nginx.log.2017.05.12.gz 

當我嘗試寫劇本:

#!/bin/bash 

name="nginx" 
data=$(date +%Y.%m.%d) 
current_nginx=$name.$data 
echo $current_nginx 

find /root/nginx.log* -type f -print0 -and ! -name "*.gz" -and ! -name "$current_nginx" -exec gzip "{}" \; 

執行此腳本後,我有:

-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.07.gz 
-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.08.gz 
-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.09.gz 
-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.10.gz 
-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.11.gz 
-rw-r--r-- 1 root root 1379440 May 8 10:35 nginx.log.2017.05.12.gz 

調試腳本:

bash -x test.sh 
+ name=nginx 
++ date +%Y.%m.%d 
+ data=2017.05.08 
+ current_nginx=nginx.2017.05.08 
+ echo nginx.2017.05.08 
nginx.2017.05.08 
+ find /root/nginx.log.2017.05.07.gz /root/nginx.log.2017.05.08.gz /root/nginx.log.2017.05.09.gz /root/nginx.log.2017.05.10.gz /root/nginx.log.2017.05.11.gz /root/nginx.log.2017.05.12.gz /root/nginx.log.2017.05.13.gz /root/nginx.log.2017.05.14.gz -type f -print0 -and '!' -name '*.gz' -and '!' -name nginx.2017.05.08 -exec gzip '{}' ';' 
/root/nginx.log.2017.05.07.gz/root/nginx.log.2017.05.08.gz/root/nginx.log.2017.05.09.gz/root/nginx.log.2017.05.10.gz/root/nginx.log.2017.05.11.gz/root/nginx.log.2017.05.12.gz/root/nginx.log.2017.05.13.gz/root/nginx.log.2017.05.14.gz 

我的條件-and ! -name "$current_nginx"不起作用。我錯了哪裏?請幫忙。

回答

0

您缺少current_nginx中的.log

+0

很好。我忘了它。謝謝。 – Piduna