如何使用 shell 脚本从 vsftpd 日志中提取文件名?
How to extract file name from vsftpd log with shell script?
我正在使用 vsftpd,我想从成功上传的文件中提取文件名。
日志示例:
Tue Feb 6 11:49:25 2018 [pid 13018] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 19607.40Kbyte/sec
Tue Feb 6 11:49:25 2018 [pid 13017] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 24426.38Kbyte/sec
Tue Feb 6 11:49:30 2018 [pid 13018] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 25387.19Kbyte/sec
我正在使用此代码:
#!/bin/sh
tail -F /var/log/vsftpd.log | while read line; do
if echo "$line" | grep -q 'OK UPLOAD:'; then
line=$(echo "$line" | tr -s " ")
filename=$(echo "$line" | cut -d, -f2)
echo "$filename"
fi
done
问题是如果文件名里面有逗号,将无法正常工作。
不要为此使用 bash
命令,最好将此 gnu awk
解决方案与 FPAT
:
一起使用
tail /var/log/vsftpd.log |
awk -v FPAT='\[[^]]*\]|"[^"]*"' '/OK UPLOAD/{gsub(/[][]/, "", );
gsub(/"/, "", ); cmd=sprintf("echo php /path/to/my/script.php \"%s\" \"%s\"", , );
cmd | getline result; close(cmd); print result}'
php /path/to/my/script.php xyz /filename.zip
php /path/to/my/script.php xyz /filename.zip
php /path/to/my/script.php xyz /filename.zip
一旦您对输出感到满意,然后删除 php
之前的 echo
。
我正在使用 vsftpd,我想从成功上传的文件中提取文件名。 日志示例:
Tue Feb 6 11:49:25 2018 [pid 13018] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 19607.40Kbyte/sec
Tue Feb 6 11:49:25 2018 [pid 13017] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 24426.38Kbyte/sec
Tue Feb 6 11:49:30 2018 [pid 13018] [xyz] OK UPLOAD: Client "1.2.3.4", "/filename.zip", 131072000 bytes, 25387.19Kbyte/sec
我正在使用此代码:
#!/bin/sh
tail -F /var/log/vsftpd.log | while read line; do
if echo "$line" | grep -q 'OK UPLOAD:'; then
line=$(echo "$line" | tr -s " ")
filename=$(echo "$line" | cut -d, -f2)
echo "$filename"
fi
done
问题是如果文件名里面有逗号,将无法正常工作。
不要为此使用 bash
命令,最好将此 gnu awk
解决方案与 FPAT
:
tail /var/log/vsftpd.log |
awk -v FPAT='\[[^]]*\]|"[^"]*"' '/OK UPLOAD/{gsub(/[][]/, "", );
gsub(/"/, "", ); cmd=sprintf("echo php /path/to/my/script.php \"%s\" \"%s\"", , );
cmd | getline result; close(cmd); print result}'
php /path/to/my/script.php xyz /filename.zip
php /path/to/my/script.php xyz /filename.zip
php /path/to/my/script.php xyz /filename.zip
一旦您对输出感到满意,然后删除 php
之前的 echo
。