RabbitMQ 客户端开发向导

1.连接RabbitMQ

ConnectionFactory factory = new ConnectionFactory();

factory.setUsername(USERNAME);

factory.setPassword(PASSWORD);

factory.setVirtualHost(virtualHost) ;

factory.setHost(IP ADDRESS);

factory.setPort(PORT) ;

Connection conn = factory.newConnection();

 

Connection 接口被用来创建一个 Channel:

Channel channel = conn.createChannel();

2.使用交换器和队列

channel.exchangeDeclare(exchangeName , "direct" , true) ;

String queueName = channel . queueDeclare() .getQueue( );

channel . queueBind (queueName , exchangeName , routingKey);

上面创建了一个持久化的、非自动删除的、绑定类型为direct的交换器,同时也创建了一个非持久货损的、排他的、自动删除的队列。

3.发送消息

byte[] messageBodyBytes = "Hello , world! ". getBytes();

channel.basicPublish(exchangeName , routingKey , null , messageBodyBytes);

4.消费消息

1)推模式

boolean autoAck = false ;

channel . basicQos(64);

channel . basicConsume(queueName , autoAck, "myConsumerTag" ,

new DefaultConsumer(channel) {

@Override

public void handleDelivery(String consumerTag,

Envelope envelope ,

AMQP.BasicPropert es propert es

byte [l body)

throws IOException

String routingKey = envelope . getRoutingKey( );

String contentType = properties.getContentType() ;

long deliveryTag = envelope.getDeliveryTag() ;

// (process the message components here . .. )

channel . basicAck(deliveryTag, false );

}

, } ) ;

2)拉模式

GetResponse response = channel.basicGet(QUEUE NAME , false) ;

System.out.println(new String(response.getBody()));

channel .basicAck(response . getEnvelope() . getDeliveryTag() , false);

 

5.消费端的确认与拒绝

RabbitMQ提供了消息确认机制

消费者在订阅队列时,可以指定autoAck参数

False时:

RabbitMQ会等待消费者显式地回复确认信号后才从内存或磁盘中移去消息。

消费者有足够的时间处理消息任务,不用担心处理消息过程中消费者进程挂掉后消息丢失的问题,因为RabbitMQ会一直等待持有消息直到消费者显式调用 Basic.Ack命令为止。

True时:

RabbitMQ会自动把发送出去的消息置为确认, 然后从内存中删除,而不管消费者是否真正的消费到了这些消息。

6.关闭连接

channel.close();

conn.close() ;

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小蚂蚁_CrkRes

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值