我正在尝试编写一个使用find和xargs将旧文件归档在大目录中的脚本。这是一行:
find /tmp/messages/ -mtime +9 -print0 | xargs -x -t -0 -n 1000 sh -c 'tar rPf /tmp/backup.tar "$@" && rm -f "$@"; sleep 1 && echo Finished one loop: $(date +"%T")'
该脚本大多数情况下都有效,但是每次命令运行1000个文件时,它都会跳过第一个文件,我似乎无法弄清楚为什么。
这是另一个示例(我尝试使用更简单的命令来查看会发生什么:
如果仅使用echo和xargs,则可以有效地运行一个命令:
$ echo a b c d e f| xargs -n 2 echo "$@"
a b
c d
e f
$ echo a b c d e f| xargs -n 3 echo "$@"
a b c
d e f
另一方面,如果每次打印每套打印机时都想睡觉,则添加sh -c以添加一串命令:
$ echo a b c d e f| xargs -n 2 sh -c 'echo "$@"; sleep 1;'
b
d
f
$ echo a b c d e f| xargs -n 3 sh -c 'echo "$@"; sleep 1;'
b c
e f
看看如何跳过第一项?
关于这里可能会发生什么的任何想法?
提前致谢!并让我知道您是否需要其他信息,我们很乐意提供。
sh -c
或的第一个参数bash -c
是脚本的名称,即$0
在使用时不打印$@
:
例子:
echo a b c d e f| xargs -n 3 bash -c 'echo "$0 $@"'
a b c
d e f
要解决此问题,您可以传递_
脚本的虚拟名称,然后它应该可以工作:
echo a b c d e f| xargs -n 3 bash -c 'echo "$@"' _
a b c
d e f
即使您的sleep
示例也可以正常工作:
echo a b c d e f| xargs -n 3 bash -c 'echo "$@"; sleep 1' _
a b c
d e f
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句