rabbitMQ 的交换器有四种类型:direct、fanout、topic、headers

 以下是具体的代码:

direct:路由键只能全部匹配,才能进入到指定队列中。

direct生产者

import com.rabbitmq.client.BuiltinExchangeType;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.util.Arrays;
import java.util.List;

/**
 * direct 生产者
 */
public class DirectPro {

    public final static String EXCHANGE_NAME = "direct_exchange";//direct交换器名称
    public final static Integer SEND_NUM = 10;//发送消息次数

    public static void main(String[] args) throws Exception {
        //创建连接工厂,连接RabbitMQ
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("IP");//端口号、用户名、密码可以使用默认的
        connectionFactory.setUsername("用户名");
        connectionFactory.setPassword("密码");
        connectionFactory.setPort(5672);
        //创建连接
        Connection connection = connectionFactory.newConnection();
        //创建信道
        Channel channel = connection.createChannel();
        //在信道中设置交换器
        channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);
        //交换器和队列绑定放到消费者进行
        //自定义路由键
        List<String> routeKey = Arrays.asList("key1","key2","key3");
        //发送消息
        for (int i=0;i<SEND_NUM;i++){
            String key = routeKey.get(i%routeKey.size());//发送的key
            String msg = "hello rabbitmq"+i;//发送的消息
            //消息进行发送
            channel.basicPublish(EXCHANGE_NAME,key,null,msg.getBytes());
            System.out.println("send:"+key+"==="+msg);
        }
        channel.close();
        connection.close();
    }

}

direct消费者

import com.rabbitmq.client.*;

import java.io.IOException;

/**
 * direct 消费者
 */
public class DirectCon {

    public final static String EXCHANGE_NAME = "direct_exchange";//direct交换器名称

    public final static String QUEUE_NAME = "queue_name";

    public static void main(String[] args) throws Exception {
        //创建连接工厂,连接RabbitMQ
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("IP");//端口号、用户名、密码可以使用默认的
        connectionFactory.setUsername("用户名");
        connectionFactory.setPassword("密码");
        connectionFactory.setPort(5672);
        //创建连接
        Connection connection = connectionFactory.newConnection();
        //创建信道
        Channel channel = connection.createChannel();
        //在信道中设置交换器
        channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);
        //声明队列
        channel.queueDeclare(QUEUE_NAME,false,false,false,null);
        //交换器和队列绑定
        channel.queueBind(QUEUE_NAME,EXCHANGE_NAME,"key1");
        System.out.println("waiting message.....");

        //声明消费者
        final 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("Received:"+envelope.getRoutingKey()+"========"+message);
            }
        };
        //消费者在指定的对队列上消费
        channel.basicConsume(QUEUE_NAME,true,consumer);

    }

}

3:执行结果:首先启动消费者,再启动发送者

生产者

消费者

fanout:消息能发送到所有队列上,跟路由键没有任何关系。

fanout生产者:重新定义一个交换器,只需将交换器设置成fanout就可以

  //在信道中设置交换器

  channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.FANOUT);

fanout消费者:重新定义一个交换器和队列,将交换器设置成fanout,绑定的key可以随便写。

  //在信道中设置交换器
  channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.FANOUT);
  //声明队列
  channel.queueDeclare(QUEUE_NAME,false,false,false,null);
  //交换器和队列绑定
  channel.queueBind(QUEUE_NAME,EXCHANGE_NAME,"abc");

结果

生产者都一样

 消费者

topic:按照*、#的匹配规则,进入到对应的队列

topic生产者:只需将交换器设置成topic,路由键的设置必须是用点. 进行分割("key1.k","key2.k","key3.k")

topic消费者:重新定义一个交换器和队列

//交换器和队列绑定
channel.queueBind(QUEUE_NAME,EXCHANGE_NAME,"key2.*");

这样子就只能匹配key2.开头的

 

结果:生产者都一样

消费者

headers:是根据头部的消息映射到队列的。特殊的值x-match:all(全部匹配)、any(任何一个)。

生产者

        //在信道中设置交换器
        channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.HEADERS);
        //设置要发送headers值
        Map<String, Object> heardersMap = new HashMap<String, Object>();
        heardersMap.put("api", "login");
        heardersMap.put("version", 1.0);
        heardersMap.put("radom", UUID.randomUUID().toString());
        //设置消息的属性
        AMQP.BasicProperties pro = new AMQP.BasicProperties.Builder()
                .headers(heardersMap)
                .build();

        //发送消息
        for (int i=0;i<SEND_NUM;i++){
            String msg = "hello rabbitmq"+i;//发送的消息
            //消息进行发送
            channel.basicPublish(EXCHANGE_NAME,"",pro,msg.getBytes());
            System.out.println("send:"+msg);
        }
消费者
        //在信道中设置交换器
        channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.HEADERS);

        Map<String, Object> arguments = new HashMap<String, Object>();
        arguments.put("x-match", "any");
        arguments.put("api", "login");
        arguments.put("version", 1.0);
        arguments.put("dataType", "json");

        //交换器和队列绑定
        String queueName = channel.queueDeclare().getQueue();
        channel.queueBind(queueName,EXCHANGE_NAME,"",arguments);
        System.out.println("waiting message.....");

        //声明消费者
        final 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(" [HeaderRecv] Received '" +
                        properties.getHeaders() + "':'" + message + "'");
            }
        };
结果:发送者一样
消费者

 以上就是Java对原生的RabbitMQ基本使用。

 

01-19 06:50