zhangxiao
V2EX  ›  问与答

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

  •  
  •   zhangxiao · Nov 25, 2014 via Android · 6581 views
    This topic created in 4217 days ago, the information mentioned may be changed or developed.
    功能是,能让用户选择在某个时间点推送给他一条消息。用户能取消或是修改推送的时间和内容。

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

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

    如果不是很紧急的话,可以参考Wordpress的WP-Cron,网站被访问就会触发,如果没人访问的话......
    evlos
        6
    evlos  
       Nov 25, 2014 via iPhone
    你也可以不一直刷数据库,做个索引放内存里,不过其实也没改变多少
    greatdk
        7
    greatdk  
       Nov 25, 2014
    定时消息队列,SAE,BAE这些里面都有的
    lupino
        8
    lupino  
       Nov 25, 2014   ❤️ 1
    可以试一试 https://github.com/Lupino/periodic 定时任务系统,把任务发送到定时任务系统上面,由 worker 来执行任务
    lupino
        9
    lupino  
       Nov 25, 2014
    可以提交定时任务,修改触发时间,并删除任务,刚好满足你的需求
    ijse
        10
    ijse  
       Nov 25, 2014
    消息队列,用ActiveMQ什么的,可以消息通知程序处理。。
    otakustay
        11
    otakustay  
       Nov 26, 2014
    直接转成crontab……或者用quartz这种成熟的第三方
    wendaomuxin
        12
    wendaomuxin  
       May 15, 2025
    环形队列 定时触发
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3049 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 75ms · UTC 06:26 · PVG 14:26 · LAX 23:26 · JFK 02:26
    ♥ Do have faith in what you're doing.