设为首页 收藏本站
查看: 1613|回复: 0

[经验分享] celery 、rabbitmq的exchange三种方式的实现

[复制链接]

尚未签到

发表于 2018-7-2 08:12:25 | 显示全部楼层 |阅读模式
  exchange的使用BROKER_URL只能是rabbitmq,redis使用exchange和未使用效果一样,只能为direct
  1、fanout 广播式,它不需要指定路由就会把所有发送到该Exchange的消息路由到所有与它绑定的Queue中
  配置文件如下,可以套用我的celery queue文章,来测试
  CELERY_QUEUES = (
  Queue('for_adds',Exchange('for_adds',type='fanout')),
  Queue('for_send_emails', Exchange('for_adds',type='fanout')),
  Queue('add', Exchange('for_adds',type='fanout')),
  )
  CELERY_ROUTES = {
  'celery_test.tasks.add': {'exchange':'for_adds'},
  'celery_test.tasks.send_mail': {'exchange':'for_adds',},
  'celery_test.tasks.adds': {'exchange':'for_adds',},
  }
  2、direct
  direct类型的Exchange路由规则也很简单,它会把消息路由到那些binding key与routing key完全匹配的Queue中
  CELERY_QUEUES = (
  Queue('for_adds',Exchange('for_adds',type='direct'), routing_key='adds'),
  Queue('for_send_emails', Exchange('for_adds',type='direct'), routing_key='email'),
  Queue('add', Exchange('for_adds',type='direct'), routing_key='add'),
  )
  CELERY_ROUTES = {
  'celery_test.tasks.add': {'exchange':'for_adds','routing_key':'add'},
  'celery_test.tasks.send_mail': {'exchange':'for_adds','routing_key':'email'},
  'celery_test.tasks.adds': {'exchange':'for_adds','routing_key':'add'},
  }
  3、topic
  topic类型的Exchange在匹配规则上进行了扩展,它与direct类型的Exchage相似,也是将消息路由到binding key与routing key相匹配的Queue中,但这里的匹配规则有些不同,它约定

  •   routing key为一个句点号“. ”分隔的字符串(我们将被句点号“. ”分隔开的每一段独立的字符串称为一个单词),如“*.task.*”、"*.*.email"、“*.add”
  •   binding key与routing key一样也是句点号“. ”分隔的字符串
  •   binding key中可以存在两种特殊字符“*”与“#”,用于做模糊匹配,其中“*”用于匹配一个单词,“#”用于匹配多个单词(可以是零个)
  配置文件如下
  CELERY_QUEUES = (
  Queue('for_adds',Exchange('for_adds',type='topic'), routing_key='*.task.*'),
  Queue('for_send_emails', Exchange('for_adds',type='topic'), routing_key='*.*.email'),
  Queue('add', Exchange('for_adds',type='topic'), routing_key='*.add'),
  )
  CELERY_ROUTES = {
  'celery_test.tasks.add': {'exchange':'for_adds','routing_key':'q.task.email'},
  'celery_test.tasks.send_mail': {'exchange':'for_adds','routing_key':'a.task.e'},
  'celery_test.tasks.adds': {'exchange':'for_adds','routing_key':'b.add'},
  }
  该路由的设置,adds会到add队列,send_mail会到for_adds队列,add会到for_adds和for_send_emails队列

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-532785-1-1.html 上篇帖子: Exchange MMC and powershell initiation issue-Microsoft 下篇帖子: Microsoft Exchange Information Store服务无法启动
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表