定时消息推送系统如何设计?

2014-11-25 16:21:12 +08:00
 zhangxiao
功能是,能让用户选择在某个时间点推送给他一条消息。用户能取消或是修改推送的时间和内容。

问题是怎么触发比较好?最基本的办法就是算出要推送的时间,存数据库里。一个进程不停地刷数据库,假设五分钟一次,找到需要发送的发出去。

感觉上面这个做法有点笨,有没有更好的办法?
5727 次点击
所在节点    问与答
11 条回复
abelyao
2014-11-25 16:30:14 +08:00
没实践过的,随便说一个思路,楼主看看是否可行。
像你说的,有个定时器,每隔一段时间刷一次,但不用刷得太频繁,比如 30 分钟一次就好,拿到所有要推送的内容之后,用倒计时的那种定时器,每一条要推送的内容,分别设定 XX 分钟后触发推送的事件。
582033
2014-11-25 16:39:45 +08:00
简单点的话,数据库存用户的设置,定时任务触发后扔到发送消息的队列里
Mac
2014-11-25 16:48:12 +08:00
WINDOWS计划任务。。。
tangzx
2014-11-25 16:52:00 +08:00
笨,但是扩展性是挺好的,即使有一千个用户,系统负载量还是那么点儿(一个线程)
66beta
2014-11-25 18:14:44 +08:00
windows计划任务、Linux cron job ?
如果是PHP,可以每隔一段时间用以上跑一个PHP文件~

如果不是很紧急的话,可以参考Wordpress的WP-Cron,网站被访问就会触发,如果没人访问的话......
evlos
2014-11-25 18:24:02 +08:00
你也可以不一直刷数据库,做个索引放内存里,不过其实也没改变多少
greatdk
2014-11-25 18:26:59 +08:00
定时消息队列,SAE,BAE这些里面都有的
lupino
2014-11-25 20:52:11 +08:00
可以试一试 https://github.com/Lupino/periodic 定时任务系统,把任务发送到定时任务系统上面,由 worker 来执行任务
lupino
2014-11-25 20:57:33 +08:00
可以提交定时任务,修改触发时间,并删除任务,刚好满足你的需求
ijse
2014-11-25 21:01:15 +08:00
消息队列,用ActiveMQ什么的,可以消息通知程序处理。。
otakustay
2014-11-26 17:48:07 +08:00
直接转成crontab……或者用quartz这种成熟的第三方

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/149182

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX