创建链接
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("ip地址");
factory.setPort(5672);
factory.setVirtualHost("mawendb");
factory.setUsername("mawen");
factory.setPassword("123");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();
//申明队列参数
queue 申明队列名称,如果没有则自动创建
duravle 是否持久化,如果持久化,mq重启后队列还在
exclusive 是否独占连接,队列只允许在该连接中访问,如果连接关闭队列自动删除,如果将此参数设置
为true,可用于临时队列的创建 connection关闭队列消失
autoDelete 自动删除,对俄不再使用时是否自动删除此队列,如果将此参数和exclusive参数设置为true就可以设置为
临时队列。
arguments 参数,可以设置毅哥队列的扩展参数 设置存货时间 null
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
//发送消息参数
exchange,交换机如果不指定将使用mq默认的交换机 ""
routingkey 路由key ,交换机根据路由key来将消息转发到指定的队列,如果使用默认交换机,routingkey设置为对应的队列名称“”
props 消息属性
body 消息内容 string.getbytes()
channel.basicPublish("", "QUEUE_NAME", null, message.getBytes());
消费者申明队列
queue 队列名称
autoAck 自动回复,当消费者接收到消息后告诉mq我已收到消息,设置为true自动回复mq以收到
consumer 返回处理值
channel.basicConsume("", true, consumer);
consumer 返回处理值-----|
Consumer consumer = new DefaultConsumer(channel) {
@Override
public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
String message = new String(body, "UTF-8");
System.out.println("Customer Received '" + message + "'");
String name=message.split("--")[0];
sendMess(name);
}
};