生产者和消费者、队列、交换机、路由键、绑定
生产者发送消息过程:
消费者接收消息的过程:
即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议
Map<String, Object> args = new HashMap<String , Object>();
args.put("a1ternate-exchange" , "myAe");
channe1.exchangeDec1are( "norma1Exchange" , "direct" , true , fa1se , args);
channe1 . exchangeDec1are( "myAe " , "fanout" , true , fa1se , nu11) ;
channe1 .queueDec1are( "norma1Queue " , true , fa1se , fa1se , nu11);
channe1 .queueB nd( norma1Queue "norma1Exchange" , " norma1Key");
channe1 .queueDec1are( "unroutedQueue " , true , fa1se , fa1se , nu11);
channel .queueBind( "unroutedQueue " , "myAe " , "");
Map<String, Object> argss = new HashMap<String , Object>();
argss.put("x-message-ttl " , 6000);
channel . queueDeclare(queueName , durable , exclusive , autoDelete , argss) ;
AMQP.BasicProperties properties = new AMQP.BasicProperties() ;
properties.setExpiration("60000");
channel . basicPublish (exchangeName, routingKey, mandatory, propertes, "ttlTestMessage".getBytes());
DLX ,全称为 Dead-Letter-Exchange ,可以称之为死信交换器,也有人称之为死信邮箱。当
消息在一个队列中变成死信 (dea message) 之后,它能被重新被发送到另一个交换器中,这个
交换器就是 DLX ,绑定 DLX 的队列就称之为死信队列。
消息变成死信 般是由于以下几种情况:
1、消息被拒绝 (Basic.Reject/Basic .Na ck) ,井且设置 requeue 参数为 alse;
2、消息过期;
3、令队列达到最大长度。
channel . exchangeDeclare("dlx_exchange " , "dir ect "); // 创建 DLX: dlx_exchange
Map<String, Object> args = new HashMap<String, Object>();
args . put("x-dead-letter-exchange" , " dlx exchange ");
//为队列 myqueue 添加 DLX
channel . queueDeclare("myqueue" , false , false , false , args);
也可以为这个 DLX 指定路由键,如果没有特殊指定,则使用原队列的路由键:
args.put("x-dead-letter-routing-key" , "dlx-routing-key");
通过DLX死信队列和TTL时间过期模拟出延迟队列的功能。
优先级高的消息具备优先被消费的特权,默认最低为0。如果消费速度大于生产速度,则没有意义
Map<String, Object> args =new HashMap<String, Object>() ;
args . put( "x-rnax-priority" , 10) ;
channel.queueDeclare( " queue . priority" , true , fa1se , false , args) ;
参考书籍:
《RabbitMQ 实战指南》朱忠华 著
原文:https://www.cnblogs.com/linyufeng/p/11867654.html