【发布时间】:2015-11-05 21:36:24
【问题描述】:
我在 Windows Server 下设置了以下(简化的)批处理电子邮件流程:
- 用户执行需要发送电子邮件的操作;
- 创建电子邮件所需的数据被插入到 SQL Server 表中;
- 每 6 小时一次,Task Scheduler 调用一个 PHP 文件,该文件遍历表,创建并发送每封未处理的电子邮件。
这很有效,但是应用程序所有者希望更定期地发送某些类型的电子邮件,在这种情况下,每 20 分钟发送一次。
我的第一个想法是设置另一个任务计划程序条目,但这引发了每 6 小时发生一次的问题,此时两个任务将同时运行。它还需要创建另一个 PHP 文件,这不是问题,但很烦人。
我考虑的另一种选择是将调度程序设置为每 20 分钟一次,并将“我发送什么以及何时发送”逻辑合并到批处理文件本身中 - 如果是上午 12 点、上午 6 点、下午 12 点或下午 6 点,则执行两组电子邮件,否则只需执行 20 分钟。但是,这确实需要在那些时候进行硬编码,而且似乎不应该是第一选择。
有没有更好的方法来做到这一点?
【问题讨论】:
-
我建议在 sql 表中为您的消息引入某种严重性。基本上,您可以每 5 分钟左右运行一次调度程序,然后根据要发送的电子邮件的严重程度来决定。此外,您可以引入另一个表,其中存储每个严重性的时间,例如 20 分钟或 6 小时。
-
@RaphaelMüller 这基本上就是我想做的,是的。问题在于“刚刚决定”的部分。我是否坚持必须输入“如果是下午 6 点交付这些”,“如果是 X:20/X:40/X:00 交付这些”?还是有其他方法可以告诉程序何时发送某些电子邮件组?
标签: php email scheduled-tasks batch-processing