如何为正在传输到其他服务器的文件创建日志文件

如何为正在传输到其他服务器的文件创建日志文件

我有一个场景,我在一个目录中接收多个文件,并且我需要将 60 分钟内收到的这些文件传输到其他服务器。因此,我使用以下命令。

{ find -maxdepth 1 -type f -mmin -60| cut -d'/' -f2 | sed 's/^/put /' ; echo bye ; } | \
    /usr/local/bin/sshpass -p password sftp -oBatchMode=no [email protected]:/folder

现在,我需要修改命令并创建一个日志文件,我需要在其中打印正在传输的文件的文件名。我制作了下面的脚本,但不知何故不相信该脚本,因为日志文件也正在传输并正在运行寻找命令两次可能会导致一些数据差异,因为在生成日志文件时可能会收到并传输新文件。请建议如何解决这个问题。

#!/bin/bash

file=/root/test/file_$(date +%Y-%m-%d_%H%M%S)

find -maxdepth 1 -type f -mmin -60| cut -d'/' -f2 > $file

{ find -maxdepth 1 -type f -mmin -60| cut -d'/' -f2 | sed 's/^/put /' ; echo bye ; } | \
    /usr/local/bin/sshpass -p password sftp -oBatchMode=no [email protected]:/folder

答案1

您可以使用tee将文件名存储到文件中作为管道的一部分。

find -maxdepth 1 -type f -mmin -60| cut -d'/' -f2 | tee -a /path/to/log.file | sed 's/^/put /' 

-a如果文件已存在,则会追加。

相关内容