RabbitMQ的任务分发

direct分发机制会根据分发关键字(routing_key),将task分发到指定的queue,work只需要监听相应的queue即可,在代码中,需要设置相应的routing_key

fanout机制相反,他会将task分发给所有的queue

fanout模式:

emit_log.py

# -*- coding: UTF-8 -*-
import pika

if __name__ == '__main__':

    connection = pika.BlockingConnection(pika.ConnectionParameters("localhost"))
    channel = connection.channel()
    channel.exchange_declare(exchange="logs2",type="direct")
    message = "You are awsome!"
    for i in range(0, 100):  # 循环100次发送消息
        if i%2==0:
            channel.basic_publish(exchange="logs2", routing_key='even', body=message + " " + str(i),)
        else:
            channel.basic_publish(exchange="logs2", routing_key='old', body=message + " " + str(i),)

    print "sending ", message

    #两个receive_log 都将接收到task

receive_log.py

pika

__author__ = callback(, , , body):
    body


__name__ == :
    connection=pika.BlockingConnection(pika.ConnectionParameters())
    channel=connection.channel()
    channel.exchange_declare(=,=)
    result=channel.queue_declare(=)
    queue_name=result..queue
    ,queue_name
    channel.queue_bind(=,=queue_name)
    channel.basic_consume(callback,=queue_name,=)
    channel.start_consuming()

receive_log2.py

pika

__author__ = callback(, , , body):
    body


__name__ == :
    connection=pika.BlockingConnection(pika.ConnectionParameters())
    channel=connection.channel()
    channel.exchange_declare(=,=)
    result=channel.queue_declare(=)
    queue_name=result.method.queue
    ,queue_name
    channel.queue_bind(=,=queue_name)
    channel.basic_consume(callback,=queue_name,=)
    channel.start_consuming()

可以看出两个work均接受到所有的消息

010443_fld4_2494265.png

010443_imYo_2494265.png

direct模式:

work的代码只需要将上述代码中的type改为type="direct",并绑定不同的exchange即可,


pika

__author__ = __name__ == :

    connection = pika.BlockingConnection(pika.ConnectionParameters())
    channel = connection.channel()
    channel.exchange_declare(=,=)
    message = i (, ):  i%==:
            channel.basic_publish(=, =, =message + + (i),)
        :
            channel.basic_publish(=, =, =message + + (i),)

    , message

receive_even_log.py

pika

__author__ = callback(, , , body):
    body


__name__ == :
    connection=pika.BlockingConnection(pika.ConnectionParameters())
    channel=connection.channel()
    channel.exchange_declare(=,=)
    result=channel.queue_declare(=)
    queue_name=result..queue
    ,queue_name
    channel.queue_bind(=,=queue_name,=)
    channel.basic_consume(callback,=queue_name,=)
    channel.start_consuming()

receive_old_log.py

pika

__author__ = callback(, , , body):
    body


__name__ == :
    connection=pika.BlockingConnection(pika.ConnectionParameters())
    channel=connection.channel()
    channel.exchange_declare(=,=)
    result=channel.queue_declare(=)
    queue_name=result.method.queue
    ,queue_name
    channel.queue_bind(=,=queue_name,=)
    channel.basic_consume(callback,=queue_name,=)
    channel.start_consuming()

从结果中看出:task只分发给了相应的queue

010903_9rrp_2494265.png

010903_XWYJ_2494265.png











转载于:https://my.oschina.net/u/2494265/blog/521941

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值