赞
踩
- 声明交换器:
- Exchange.DeclareOk exchangeDeclare(String exchange, String type, boolean durable, boolean autoDelete,
- Map<String, Object> arguments) throws IOException;
exchange:交换器名称
type:交换器类型:direct、fanout、topic
durable:true:服务器重启会保留下来交换器。注意:仅设置此选项,不代表消息持久化。既不保证重启后消息还在。
autoDelete: true:当已经没有消费者时,服务器是否可以删除该交换器。
void basicQos(int prefetchSize, int prefetchCount, boolean global) throws IOException;
prefetchSize:0
prefetchCount:会告诉RabbitMQ不要同时给一个消费者推送多于N个消息,即一旦有N个消息还没有ack,则该consumer将block掉,直到有消息ack
global:true\false 是否将上面设置应用于channel,简单点说,就是上面限制是channel级别的还是consumer级别
备注:据说prefetchSize 和global这两项,rabbitmq没有实现,暂且不研究
- void basicPublish(String exchange, String routingKey, boolean mandatory, boolean immediate, BasicProperties props, byte[] body)
- throws IOException;
routingKey:路由键,#匹配0个或多个单词,*匹配一个单词,在topic exchange做消息转发用
mandatory(托管):true如果exchange根据自身类型和消息routkey无法找到一个符合条件的queue,那么调用basic.return方法将消息返还给生产者。false:出现上述情形broker会直接将消息扔掉
immediate(立即的):如果exchange在将消息route到queue时发现对应的queue上没有消费者,那么这条消息不会放入队列中。当与消息routekey关联的所有queue(一个或多个)都没有消费者时,该消息会通过basic.return方法返还给生产者。
BasicProperties:需要注意的是BasicProperties.deliveryMode,0:不持久化,1:持久化 这里指的是消息的持久化,配合channel(durable=true),queue(durable)可以实现,及时服务器宕机,消息仍保留。
简单来说:mandatory标志告诉服务器至少将该消息route到一个队列中,否则将消息返还给生产者immediate标志告诉服务器如果消息关联的queue上有消费者,则马上将消息投递给它,如果所有queue都没有消费者,直接把消息返还给生产者,不用将消息如队列等待消费者了。
void basicAck(long deliveryTag, boolean multiple) throws IOException;
deliveryTag:该消息的index
multiple:是否批量。true:将一次性ack所有小于deliveryTag的消息
- void basicNack(long deliveryTag, boolean multiple, boolean requeue)
- throws IOException;
deliveryTag:该消息index
multiple:是否批量。true将一次性拒绝所有小于deliveryTag的消息
requeue:被拒绝的是否重新如队列。
void basicReject(long deliveryTag, boolean requeue) throws IOException;
requeue:被拒绝的是否重新入队列
channel.basicNack与channel.basicReject的区别在于前者可以拒绝多条消息,而后者一次只能拒绝一条消息。
String basicConsume(String queue, boolean autoAck, Consumer callback) throws IOException;
autoAck:是否自动ack,如果不自动ack,需要使用channel.ack、channel.nack、channel.basicReject进行消息应答
Exchange.BindOk exchangeBind(String destination, String source, String routingKey) throws IOException;
destination:队列名
source:交换器名
routingKey:路由键
- Queue.DeclareOk queueDeclare(String queue, boolean durable, boolean exclusive, boolean autoDelete,
- Map<String, Object> arguments) throws IOException;
durable(持久化):true在服务器重启时,能够存活
exclusive:是否为当前连接的专用队列,在连接断开后,会自动删除该队列。
autodelete:当没有任何消费者使用时,自动删除队列。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。