暂时理解为一个小BUG,目前不知道如何处理。
在配置完数据库邮件服务后,提升相应代理权限,能正常发送邮件,包括后备的邮件服务器队列都正常。
主要问题处在:当使用一个无效的邮件地址(拼错应该是正常现象),由于我使用了重试机制(50次,每5分种一次),因此会出现,抄送名单中其他所有人都会不停的接收邮件,而服务器认为此邮件未执行成功,其实是部分成功,因其中一个出现错误。
在此情况下,我不知道如何来解决,当时唯一能做的就是,修改重试次数为1.
后来想了下,在网上找了一段代码,主要是清除邮件队列里的内容,不过我i当时未能尝试成功,因当时msdb报事务日志错,同时为了快速解决问题。
- EXEC msdb.dbo.sysmail_delete_mailitems_sp --删除队列容,需要指定参数,时间等
- EXEC msdb.dbo.sysmail_delete_log_sp --删除日志
- DELETE FROM msdb.dbo.sysmail_attachments --删除邮件附件。
msdb事务日志出错致上面语句执行不能功,后来只能小批量删 msdb.dbo.sysmail_attachments where 每次100,该表全删除后,可以收缩数据库,同时上述语句再执行时不报错误 。
上述修补机制还需进一步验证。