使用 MongoDB、Django、Celery 和 Sendgrid 构建批量通知
文章标签
批量
什么是批量通知?
批量通知将多个单独的通知合并为一条消息,并在指定的时间范围内发送。这种方法与传统系统不同,传统系统为每个事件发送单独的通知,有助于减少通知噪音并增强用户参与度。
例如,在文档协作应用程序中,批量通知系统不会为每条评论发送一封电子邮件,而是发送一封包含指定时间窗口内所有评论的电子邮件。
设计批量通知系统
方面 | 批量写入 | 批量读取 | 我们的方法 |
---|---|---|---|
方法 | 当事件发生时将通知累积到批次中,优化查找。 | 通过查询定期批量处理未发送的通知。 | 批量写入 |
表演 | 更高效、更好的性能和可扩展性。 | 随着数据量的增长,效率可能会降低。 | 需要更多的初始工作,但提供更好的可扩展性。 |
可扩展性 | 实时批处理带来更高的可扩展性。 | 可扩展性较低,可能会受到数据量的影响。 | 更高的可扩展性 |
使用 MongoDB 进行数据库设计
收藏 | 描述 |
---|---|
通知 | 跟踪个人通知。 |
通知批次 | 跟踪批量通知。 |
notification_batch_notifications | 将单个通知链接到批次。 |
您可以在此处找到代码和实现:
https://www.suprsend.com/post/building-a-batch-notification-system-with-mongodb-django-celery-and-sendgrid-for-developers
请考虑在 Hackernews 上分享这篇文章,或者在 Github 应用程序上给我们一个星星。