if [ $(find /var/log/program_monitor/ -maxdepth 1 -name "*.log" | wc -l) -gt 0 ]; then echo "1" latest_log=$(ls -t /var/log/program_monitor/*.log | head -1) echo "2" echo "$latest_log" date_str=$(echo $latest_log | cut -d'/' -f5 | grep -oE '[0-9]{8}') echo "3" echo "$date_str" latest_time=$(date +%Y%m%d) echo "4" echo "$latest_time" if [ "date_str" == "latest_time" ]; then echo "5" echo ---------$(date)---------- >> $log_file else touch ${log_file} fi else touch ${log_file} echo "6" fi为啥date_str=$(echo $latest_log | cut -d'/' -f5 | grep -oE '[0-9]{8}')这个获取的数据不会更新一直是一个值
时间: 2024-02-14 18:32:47 浏览: 89
这段代码是在查找指定目录下最新的日志文件,并判断它的日期是否与当前日期相同,如果不同则向日志文件写入新的时间戳。而date_str=$(echo $latest_log | cut -d'/' -f5 | grep -oE '[0-9]{8}')是用来提取日志文件名中的日期部分的,其中cut -d'/' -f5是用来取出文件名,grep -oE '[0-9]{8}'是用来提取8位数字的部分作为日期。
如果date_str的值一直不更新,那么可能是因为最新的日志文件名中的日期部分没有发生变化,所以提取出来的日期值也没有变化。你可以检查一下最新的日志文件名是否确实有日期部分,以及它是否随着时间的推移而变化。
相关问题
if [ $(find /var/log/program_monitor/ -maxdepth 1 -name "*.log" | wc -l) -gt 0 ]详细解释
好的,以下是对这个命令的详细解释:
1. `find /var/log/program_monitor/ -maxdepth 1 -name "*.log"`:这个命令会在`/var/log/program_monitor/`目录下查找以`.log`结尾的文件,并返回所有符合条件的文件名。具体参数的含义如下:
- `/var/log/program_monitor/`:要查找的目录。
- `-maxdepth 1`:只查找当前目录,不递归查找子目录。
- `-name "*.log"`:文件名以`.log`结尾。
2. `|`:这个符号是管道符,将`find`命令的输出传递给下一个命令。
3. `wc -l`:这个命令会计算输入的行数,并输出结果。`-l`参数表示只计算行数。
4. `$(...)`:这个语法是命令替换,将括号中的命令的输出作为整个语句的值。具体来说,这里将`find`和`wc`命令的输出通过管道传递给`wc -l`命令,然后将计算出的行数作为整个语句的值。
5. `-gt`:这个符号是比较符号,表示大于。在这个命令中,它用于比较行数是否大于0。
综上所述,这个命令的意思是:在`/var/log/program_monitor/`目录下查找以`.log`结尾的文件,如果找到了任何一个文件,就返回1;如果没找到,就返回0。这个返回值会被传递给`if`语句,用于判断是否执行`then`语句块中的命令。如果返回值为1,则表示找到了文件,会执行`then`语句块中的命令;如果返回值为0,则表示没找到文件,不会执行`then`语句块中的命令。
function monitor(){ #set -x #if [ -e `/var/log/program_monitor/*.log` ];then if [ $(find /var/log/program_monitor/ -maxdepth 1 -name "*.log" | wc -l) -gt 0 ]; then echo "1" latest_log=$(ls -t /var/log/program_monitor/*.log | head -1) echo "2" date_str=$(echo $latest_log | cut -d'/' -f5 | grep -oE '[0-9]{8}') echo "3" echo "$date_str" latest_time=$(date +%Y%m%d) echo "4" echo "$latest_time" if [ "date_str" == "latest_time" ]; then echo "5" echo ---------$(date)---------- >> $log_file else touch ${log_file} fi else touch ${log_file} echo "6" fi }为啥不打印5明明获得的字符串都是一样的
根据代码分析,问题可能出在判断语句中。在判断语句中,字符串 "date_str" 和 "latest_time" 被引号包含,被视为文本字符串,而不是变量。所以无论实际的值是什么,它们都是不相等的文本字符串。正确的写法应该是去掉引号,将变量的值直接作为字符串比较,即:
```if [ "$date_str" == "$latest_time" ]; then```
阅读全文