MacOS installe RabbitMQ et utilise

installation

Installer en utilisant une infusion:

  1. mise à jour de la bière
  2. infusion installer rabbitmq

Après l'installation, exécutez rabbitmq
Insérez la description de l'image ici
3. Entrez dans la console: http: // localhost: 15672 /

Nom d'utilisateur et mot de passe: invité, invité
Insérez la description de l'image ici

  • 停止 les
    services de brassage arrêtent rabbitmq

Comment fonctionne RabbitMQ

  • La structure de base de RabbitMQ

Insérez la description de l'image ici

Description du composant:

  • Courtier: processus de service de file d'attente de messages, ce processus comprend deux parties: échange et file d'attente
  • Échange: l'échange de file d'attente de messages, qui achemine les messages vers une certaine file d'attente selon certaines règles, et filtre les messages.
  • File d'attente: file d'attente de messages, une file d'attente pour stocker les messages, les messages arrivent dans la file d'attente et sont transmis au producteur spécifié: producteur de messages, c'est-à-dire le client producteur, le client producteur envoie le message
  • Consommateur: le consommateur de message, c'est-à-dire le client consommateur, reçoit le message transféré par MQ.

Processus d'envoi de message par le producteur:

1. Le producteur établit une connexion TCP avec le courtier.

2. Le producteur établit un canal avec le courtier.

3. Le producteur envoie le message au courtier via le canal et le message est transféré par l'échange.

4. Exchange transmet le message à la file d'attente spécifiée (file d'attente)

Processus de réception du message du consommateur:

1. Le consommateur et le courtier établissent une connexion TCP

2. Les consommateurs et les courtiers établissent des canaux

3. Les consommateurs écoutent la file d'attente spécifiée (file d'attente)

4. Lorsqu'un message arrive dans la file d'attente, Broker le pousse par défaut vers le consommateur.

5. Le consommateur reçoit le message.

6, réponse d'ack.

Lien vers MQ

public class ConnectionUtil {
    
    
    /**
     * 建立与RabbitMQ的连接
     * @return
     * @throws Exception
     */
    public static Connection getConnection() throws Exception {
    
    
        //定义连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //设置服务地址,本机用127.0.0.1
        factory.setHost("127.0.0.1");
        //amp的协议端口
        factory.setPort(5672);
        //设置账号信息,用户名、密码、vhost
        factory.setVirtualHost("/");//设置虚拟机,一个mq服务可以设置多个虚拟机,每个虚拟机就相当于一个独立的mq,默认是添加的是 /
        factory.setUsername("guest"); //登录名
        factory.setPassword("guest"); //登录密码
        // 通过工厂获取连接
        Connection connection = factory.newConnection();
        return connection;
    }
}

expéditeur

public class Send {
    
    
 
    private final static String QUEUE_NAME = "simple_queue";
 
    public static void main(String[] argv) throws Exception {
    
    
        // 1、获取到连接
        Connection connection = ConnectionUtil.getConnection();
        // 2、从连接中创建通道,使用通道才能完成消息相关的操作
        Channel channel = connection.createChannel();
        // 3、声明(创建)队列
        //参数:String queue, boolean durable, boolean exclusive, boolean autoDelete, Map<String, Object> arguments
        /**
         * 参数明细
         * 1、queue 队列名称
         * 2、durable 是否持久化,如果持久化,mq重启后队列还在
         * 3、exclusive 是否独占连接,队列只允许在该连接中访问,如果connection连接关闭队列则自动删除,如果将此参数设置true可用于临时队列的创建
         * 4、autoDelete 自动删除,队列不再使用时是否自动删除此队列,如果将此参数和exclusive参数设置为true就可以实现临时队列(队列不用了就自动删除)
         * 5、arguments 参数,可以设置一个队列的扩展参数,比如:可设置存活时间
         */
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        // 4、消息内容
        String message = "Hello World!";
        // 向指定的队列中发送消息
        //参数:String exchange, String routingKey, BasicProperties props, byte[] body
        /**
         * 参数明细:
         * 1、exchange,交换机,如果不指定将使用mq的默认交换机(设置为"")
         * 2、routingKey,路由key,交换机根据路由key来将消息转发到指定的队列,如果使用默认交换机,routingKey设置为队列的名称
         * 3、props,消息的属性
         * 4、body,消息内容
         */
        channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
        System.out.println(" [x] Sent '" + message + "'");
        
        //关闭通道和连接(资源关闭最好用try-catch-finally语句处理)
        channel.close();
        connection.close();
    }
}

Le destinataire reçoit le message

public class Recv {
    
    
    private final static String QUEUE_NAME = "simple_queue";
 
    public static void main(String[] argv) throws Exception {
    
    
        // 获取到连接
        Connection connection = ConnectionUtil.getConnection();
        //创建会话通道,生产者和mq服务所有通信都在channel通道中完成
        Channel channel = connection.createChannel();
        // 声明队列
        //参数:String queue, boolean durable, boolean exclusive, boolean autoDelete, Map<String, Object> arguments
        /**
         * 参数明细
         * 1、queue 队列名称
         * 2、durable 是否持久化,如果持久化,mq重启后队列还在
         * 3、exclusive 是否独占连接,队列只允许在该连接中访问,如果connection连接关闭队列则自动删除,如果将此参数设置true可用于临时队列的创建
         * 4、autoDelete 自动删除,队列不再使用时是否自动删除此队列,如果将此参数和exclusive参数设置为true就可以实现临时队列(队列不用了就自动删除)
         * 5、arguments 参数,可以设置一个队列的扩展参数,比如:可设置存活时间
         */
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        //实现消费方法
        DefaultConsumer consumer = new DefaultConsumer(channel){
    
    
            // 获取消息,并且处理,这个方法类似事件监听,如果有消息的时候,会被自动调用
            /**
             * 当接收到消息后此方法将被调用
             * @param consumerTag  消费者标签,用来标识消费者的,在监听队列时设置channel.basicConsume
             * @param envelope 信封,通过envelope
             * @param properties 消息属性
             * @param body 消息内容
             * @throws IOException
             */
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
    
    
                //交换机
                String exchange = envelope.getExchange();
                //消息id,mq在channel中用来标识消息的id,可用于确认消息已接收
                long deliveryTag = envelope.getDeliveryTag();
                // body 即消息体
                String msg = new String(body,"utf-8");
                System.out.println(" [x] received : " + msg + "!");
            }
        };
        
        // 监听队列,第二个参数:是否自动进行消息确认。
        //参数:String queue, boolean autoAck, Consumer callback
        /**
         * 参数明细:
         * 1、queue 队列名称
         * 2、autoAck 自动回复,当消费者接收到消息后要告诉mq消息已接收,如果将此参数设置为tru表示会自动回复mq,如果设置为false要通过编程实现回复
         * 3、callback,消费方法,当消费者接收到消息要执行的方法
         */
        channel.basicConsume(QUEUE_NAME, true, consumer);
    }
}

Précautions

S'il y a une erreur dans le fonctionnement du consommateur, les données de consommation seront toujours réussies. À ce stade, l'accusé de réception de réponse automatique doit être remplacé par un accusé de réception de réponse manuelle. Enregistrez le consommateur sans erreur.

Je suppose que tu aimes

Origine blog.csdn.net/shuai_ge_feng/article/details/108662128
conseillé
Classement