我正在运行一个简单的rsync
脚本,在其中将stdout
和记录stderr
到两个不同的文件,rsync_stdout.log
并且rsync_stderr.log
.
当我尝试使用以下命令通过电子邮件发送 rsync_stderr.log 的内容时:
echo $(cat rsync_stderr.log) | ssmtp [email protected]
我收到一封空白的电子邮件正文,但是当我这样做时:
echo $(cat rsync_stdout.log) | ssmtp [email protected]
然后我就可以在电子邮件正文中毫无问题地记录我的标准输出。
rsync
与输出文件有关吗stderr
?
我以详细方式运行 ssmtp:
[<-] 250 2.1.5 OK b48smxxx70wrb.1 - gsmtp
[->] DATA
[<-] 354 Go ahead b48smxxxxxx70wrb.1 - gsmtp
[->] Received: by XXXNAS (sSMTP sendmail emulation); Tue, 19 Dec 2017 01:14:47 +0100
[->] From:"XXXNAS" <XXXNAS>>
[->] Date: Tue, 19 Dec 2017 01:14:47 +0100
[->] rsync: delete_file: unlink(.AppleDB/log.0000000001) failed: Permission denied (13)
[->] rsync: delete_file: unlink(.AppleDB/lock) failed: Permission denied (13)
[->] rsync: delete_file: unlink(.AppleDB/db_errlog) failed: Permission denied (13)
[->] rsync: delete_file: unlink(.AppleDB/cnid2.db) failed: Permission denied (13)
[->] rsync error: some files/attrs were not transferred (see previous errors) (code 23) at main.c(1178)
[->] [sender=3.1.2]
[->]
[->] .
[<-] 250 2.0.0 OK 1513642487 b48sxxxxxxrb.1 - gsmtp
[->] QUIT
[<-] 221 2.0.0 closing connection b4xxxxxwrb.1 - gsmtp
所以我可以看到正在发送的文本,但电子邮件正文只是空白。
我也尝试过,但也不起作用。ssmtp [email protected] < rsync_stderr.log
答案1
用户 almendrico 将我置于路径上后,我使用了:
sed 's/[\:]//g'
删除该:
字符。
不是很优雅但很有效。