import java.util.HashMap; import java.util.Map; import com.rabbitmq.client.AMQP; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; public class Procuder { public static void main(String[] args) throws Exception { //1 创建一个ConnectionFactory, 并进行配置 ConnectionFactory connectionFactory = new ConnectionFactory(); connectionFactory.setHost("192.168.6.1"); connectionFactory.setPort(5672); connectionFactory.setVirtualHost("/"); connectionFactory.setUsername("longlong"); connectionFactory.setPassword(""); //2 通过连接工厂创建连接 Connection connection = connectionFactory.newConnection(); //3 通过connection创建一个Channel Channel channel = connection.createChannel(); // 4. 通过channel发送消息 String msg = "hello rabbitmq!"; AMQP.BasicProperties properties = new AMQP.BasicProperties(); Map<String,Object> headers = new HashMap<>(); headers.put("name", "七夜雪"); properties = properties.builder() // 设置编码为UTF8 .contentEncoding("UTF-8") // 设置自定义Header .headers(headers) // 设置消息失效时间 .expiration("3000").build(); // 设置了消息超时时间为5秒, 5秒后消息自动删除 channel.basicPublish("", "test_ttl_queue", properties, msg.getBytes()); // 没有设置消息存活时间,消息存活时间根据队列来决定 channel.basicPublish("", "test_ttl_queue", null, msg.getBytes()); //5 记得要关闭相关的连接 channel.close(); connection.close(); } }
import java.io.IOException; import java.util.HashMap; import java.util.Map; import com.rabbitmq.client.*; public class Consumer { public static void main(String[] args) throws Exception { //1 创建一个ConnectionFactory, 并进行配置 ConnectionFactory connectionFactory = new ConnectionFactory(); connectionFactory.setHost("192.168.6.1"); connectionFactory.setPort(5672); connectionFactory.setVirtualHost("/"); connectionFactory.setUsername("longlong"); connectionFactory.setPassword(""); //2 通过连接工厂创建连接 Connection connection = connectionFactory.newConnection(); //3 通过connection创建一个Channel Channel channel = connection.createChannel(); // 4. 声明(创建)一个队列 String queueName = "test_ttl_queue"; Map<String, Object> arguments = new HashMap<>(); // 设置队列超时时间为10秒 arguments.put("x-message-ttl", 10000); channel.queueDeclare(queueName,true, false, false, arguments); DefaultConsumer defaultConsumer = new DefaultConsumer(channel) { @Override public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException { String msg = new String(body); System.err.println("消费端: " + msg); } }; channel.basicConsume(queueName, true, defaultConsumer); } }