如果你打算使用带有SMTP认证的方式来发送邮件,可以考虑使用msmtp
这样的工具。首先,你需要安装msmtp
并且配置它以便能够通过SMTP服务器发送邮件。下面是如何配置和使用msmtp
以及修改脚本的步骤。
安装和配置 msmtp
-
安装:在Ubuntu或Debian上,你可以使用以下命令安装
msmtp
:sudo apt-get install msmtp msmtp-mta ca-certificates bsd-mailx
-
配置 msmtp:创建或编辑你的
~/.msmtprc
文件,添加SMTP服务器的相关信息。请替换your_email@example.com
、your_password
、smtp.example.com
和相应的端口号(通常是587或465):account default host smtp.example.com port 587 protocol smtp auth on tls on tls_starttls on from your_email@example.com user your_email@example.com password your_password logfile ~/.msmtp.log
注意:出于安全考虑,不要直接在配置文件中明文存储密码。你可以使用
msmtp --passwordeval
特性或者外部的密码管理器来处理密码。 -
测试邮件发送:
echo "Test email body" | msmtp -a default recipient@example.com
修改Shell脚本以使用 msmtp 发送邮件
接下来,修改你的generate_report.sh
脚本,使用msmtp
发送邮件。由于我们已经在~/.msmtprc
中配置了账户,所以可以直接使用msmtp
命令,无需在脚本中再次输入用户名和密码。
#!/bin/bash
# ... 之前的脚本内容保持不变 ...
# 发送邮件配置
TO_EMAIL="recipient@example.com"
FROM_EMAIL="your_email@example.com" # 这里应该是你在msmtprc中配置的发件邮箱
SUBJECT="Daily Report from $TABLE_NAME"
# 使用msmtp发送邮件,注意这里使用html模式发送
echo -e "$EMAIL_BODY" | msmtp --account=default -a default --html "$TO_EMAIL" -s "$SUBJECT"
# ... 脚本其余部分保持不变 ...
确保你已经正确配置了msmtp
,并且在脚本中使用了与之匹配的发件邮箱地址。这样,你的脚本就能在计划的时间自动运行,并通过SMTP服务器发送含有数据库查询结果的HTML格式邮件了。