zoukankan      html  css  js  c++  java
  • beanstalkd

    yum 方式安装:yum -y install beanstalkd
     
    启动:/usr/bin/beanstalkd -l 0.0.0.0 -p 11300 -b /var/lib/beanstalkd/binlog -F

    -b 开启binlog,断电后重启会自动恢复任务。

    配置文件:/etc/sysconfig/beanstalkd

    对job
    5个状态
    ● READY - 需要立即处理的任务,当延时 (DELAYED) 任务到期后会自动成为当前任务;
    ● DELAYED - 延迟执行的任务, 当消费者处理任务后, 可以用将消息再次放回 DELAYED 队列延迟执行;
    ● RESERVED - 已经被消费者获取, 正在执行的任务。Beanstalkd 负责检查任务是否在 TTR(time-to-run) 内完成;
    ● BURIED - 保留的任务: 任务不会被执行,也不会消失,除非有人把它 "踢" 回队列;
    ● DELETED - 消息被彻底删除。Beanstalkd 不再维持这些消息。
    7种操作
    ● put- 放入任务
    ● reserve- 以阻塞方式监听管道,获取任务
    ● delete- 删除任务
    ● bury- 把任务预留
    ● realease- 把任务重新放回管道
    ● kick-批量把buried状态的任务设置成ready
    ● PEEK-把预留任务读取出来
    对tube
    4种操作
    ● watch - 监听管道,可以同时监听多个管道;
    ● userTobe - 指定使用的管道
    ● ignore - 不监听管道
    ● pause - 给管道设置延迟

    优点:

    优先级
    支持0到2**32的优先级,值越小,优先级越高,默认优先级为1024。
    持久化
    可以通过binlog将job及其状态记录到文件里面,在Beanstalkd下次启动时可以通过读取binlog来恢复之前的job及状态。
    延时处理
    执行put操作时,传入时间参数,可以在指定时间之后让consumer消费

    缺点:

    无主从复制、为解决宕机风险引入的代价较高

    注:如有不妥之处,欢迎指正

  • 相关阅读:
    Munge
    file upload custom form
    随笔摘要
    生成css 和 清缓存
    drupal commit 原则
    Git reset --hard
    www-data
    301/302的区别
    什么是request_uri
    in_array foreach array_search的性能比较
  • 原文地址:https://www.cnblogs.com/chinano1/p/9152697.html
Copyright © 2011-2022 走看看