文件名加1

时间:2019-03-11 14:42:32

标签: bash sed mv

我的任务是日志轮换,我找不到任何可以从文件名中添加1的命令。

例如,我有一些文件名为:wrapper.log.1wrapper.log.2。 我需要重命名该文件并将其移动到其他目录,并获得wrapper_1.logwrapper_2.log。文件移动后,应将其从原始目录中删除。

有可能在新文件夹中有相同名称的文件。 因此,我应该获取最后一个文件,并在文件名中加上1,例如wrapper_(2+1).log

整个任务中,我发现类似

find . -name "wrapper.log.*"
mkdir $(date '+ %d.%m.%y')
find . -name "wrapper.log.*" |sort -r |head -n1 | sed -E 's/(.log)(.[0-9])/_$(2+1)\1/'

但是,当然,它在第二行之后不起作用。

而且,将来它需要进行重击。

P.S:另外,我认为,可以在新文件夹中以时间戳或类似方式将新文件创建为后缀。 例如:

folder        file
01.01.19    wrapper_00_00_01
            wrapper_00_01_07
            wrapper_01_10_53
            wrapper_13_07_11

02.01.19
            wrapper_01_00_01
            wrapper_03_01_07
            wrapper_05_10_53
            wrapper_13_07_11

3 个答案:

答案 0 :(得分:2)

要查找数量最多的wrapper_日志文件:

find . -type f -name "*.log" -exec basename {} \; | ggrep -Po '(?<=wrapper_)[0-9]' | sort -rn | head -n 1

我正在使用grep的Pearl开关对“ wrapper_”进行后视,然后对找到的数字进行反向排序并取第一个。如果您想生成一个新的文件名,则可以使用awk,例如:

find . -type f -name "*.log" -exec basename {} \; | ggrep -Po '(?<=wrapper_)[0-9]' | sort -rn | head -n 1 | awk '{print "wrapper_"$1 + 1".log" }'

这将产生一个文件名,该文件名带有序列中的下一个数字。

答案 1 :(得分:0)

我无法完全理解您的问题,但是我知道使用美元符号和双括号可以执行计算:

@makestyle
@makestyle('i')
def hello(who):
    return "hello %s" % who

assert hello('world') == '<b><i>hello world</i></b>'    

答案 2 :(得分:0)

最后,我找到了两种解决方案。 首先,它的重击,像这样

#!/bin/bash

#DECLARE

FILENAME=$1
DATE=$(date '+%d.%m.%y')
SRC_DIR="/usr/local/apache-servicemix-6.1.0/data/log"
DEST_DIR="/mnt/smxlog/$HOSTNAME"

#START

mkdir -m 777 "$DEST_DIR/$DATE"

if [ -d "$DEST_DIR/$DATE" ]
then

for f in $(find "$SRC_DIR/" -name "$FILENAME.log.*") 

do

TIME=$(date '+%H_%M_%S.%3N')
NEW_FILENAME="$FILENAME-$TIME.log"
NEW_DEST_WITH_FILE="$DEST_DIR/$DATE/$NEW_FILENAME"

mv $f $NEW_DEST_WITH_FILE
gzip "$NEW_DEST_WITH_FILE"

done

else 
exit 1
fi

#END

第二个变体使用的是log4j记录器属性,但应将其上载到servicemix系统文件夹log4j-1.2.17_fragment.jar和apache-log4j-extras-1.2.17_fragment。可能有可能将它们作为捆绑包上传,我没有尝试。 两个jar使用不同的API。有 https://logging.apache.org/log4j/1.2/apidocs/index.html?overview-summary.htmlhttp://logging.apache.org/log4j/companions/apidocs/index.html?overview-summary.html 属性将是

log4j.logger.wrapper.log=DEBUG, wrapper
log4j.additivity.logger.wrapper.log=false
log4j.appender.wrapper=org.apache.log4j.rolling.RollingFileAppender  
log4j.appender.wrapper.rollingPolicy=org.apache.log4j.rolling.TimeBasedRollingPolicy  
#This setting should be used with commented line log4j.appender.wrapper.File=... if it needs to zip to target directory immediately
#log4j.appender.wrapper.rollingPolicy.FileNamePattern=/mnt/smxlog/${env:HOSTNAME}/wrapper.%d{HH:mm:ss}.log.gz
#Or it is possible to log and zip in the same folder, and after that with cron replace zipped files to required folder 
log4j.appender.wrapper.rollingPolicy.FileNamePattern=${karaf.data}/log/wrapper.%d{HH:mm:ss}.log.gz
log4j.appender.wrapper.File=${karaf.data}/log/wrapper.log
log4j.appender.wrapper.triggeringPolicy=org.apache.log4j.rolling.SizeBasedTriggeringPolicy  
#Size in bytes
log4j.appender.wrapper.triggeringPolicy.MaxFileSize=1000000
log4j.appender.wrapper.layout=org.apache.log4j.PatternLayout  
log4j.appender.wrapper.layout.ConversionPattern=%d{dd-MM-yyyy_HH:mm:ss} %-5p [%t] - %m%n
log4j.appender.wrapper.Threshold=DEBUG
log4j.appender.wrapper.append=true