// 声明一个队列 -// queue 队列名称
// durable 为true时server重启队列不会消失 (是否持久化)
// exclusive 队列是否是独占的,如果为true只能被一个connection使用,其他连接建立时会抛出异常
// autoDelete 当没有任何消费者使用时,自动删除该队列
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
/*
* 向server发布一条消息
* 参数1:exchange名字,若为空则使用默认的exchange
* 参数2:routing key
* 参数3:其他的属性
* 参数4:消息体
* RabbitMQ默认有一个exchange,叫default exchange,它用一个空字符串表示,它是direct exchange类型,
* 任何发往这个exchange的消息都会被路由到routing key的名字对应的队列上,如果没有对应的队列,则消息会被丢弃
*/
channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));
// 同一时刻服务器只会发一条消息给消费者(能者多劳模式)
channel.basicQos(1);
/*消息消费完成确认
* autoAck 是否自动确认 true自动确认 false手动确认
* 模式1