RabbitMQ快速入门

RabbitMQ快速⼊⻔

引入依赖

复制代码
				<dependency>
            <groupId>com.rabbitmq</groupId>
            <artifactId>amqp-client</artifactId>
            <version>5.22.0</version>
        </dependency>

编写生产者代码

具体步骤:

  1. 建立连接

  2. 开启信道

  3. 声明交换机

  4. 声明队列

  5. 发送消息

  6. 释放资源

    public static void main(String[] args) throws IOException, TimeoutException {
    //1.建立连接
    ConnectionFactory connectionFactory = new ConnectionFactory();
    connectionFactory.setHost(ip地址,填自己的);
    connectionFactory.setPort(5672); //需提前开放端口号
    connectionFactory.setUsername("admin");//账号
    connectionFactory.setPassword("admin");//密码
    connectionFactory.setVirtualHost("study");//虚拟主机
    Connection connection = connectionFactory.newConnection();
    //2.开启信道
    Channel channel = connection.createChannel();
    //3.声明交换机 使用内置的交换机
    //4.声明队列
    /**
    * Queue.DeclareOk queueDeclare(String queue, boolean durable, boolean exclusive, boolean autoDelete,
    * Map<String, Object> arguments) throws IOException;
    *
    * 参数说明:
    * queue:队列名称
    * durable:可持久化
    * exclusive:是否独占
    * autoDelete:是否自动删除
    * arguments:额外参数
    /
    channel.queueDeclare("hello",true,false,false,null);
    //5.发消息
    /
    *
    * void basicPublish(String exchange, String routingKey, BasicProperties props, byte[] body) throws IOException;
    *
    * 参数声明:
    * exchange:交换机名称,不写代表使用内置交换机
    * routingKey:路由名称, routingKey = 队列名称 (使用内置交换机,routingKey与队列名称保持一致)
    * props:属性配置
    * body:消息
    */
    for (int i = 0; i < 10; i++) {
    String msg = "hello rabbitmq ~" + i;
    channel.basicPublish("","hello",null,msg.getBytes());
    }
    System.out.println("消息发送成功~");

    复制代码
         //6.资源释放
         channel.close();
         connection.close();
     }

编写消费者代码

具体步骤:

  1. 建立连接

  2. 创建信道

  3. 声明队列

  4. 消费消息

  5. 释放资源

    public static void main(String[] args) throws IOException, TimeoutException, InterruptedException {
    //1.建立连接
    ConnectionFactory connectionFactory = new ConnectionFactory();
    connectionFactory.setHost(ip地址);
    connectionFactory.setPort(5672);
    connectionFactory.setUsername("admin");
    connectionFactory.setPassword("admin");
    connectionFactory.setVirtualHost("study");

    复制代码
         Connection connection = connectionFactory.newConnection();
         //2.创建Channel
         Channel channel = connection.createChannel();
         //3.声明队列(可以省略)
         channel.queueDeclare("hello",true,false,false,null);
         //4.消费消息
         DefaultConsumer consumer = new DefaultConsumer(channel){
             //从队列中收到消息,就会执行的方法
             @Override
             public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                 System.out.println("接收到消息: " + new String(body));
             }
         };
         /**
          * String basicConsume(String queue, boolean autoAck, Consumer callback) throws IOException;
          * 参数说明:
          *  queue:队列名称
          *  autoAck:是否自动确认
          *  callback:接收到消息后,执行的逻辑
          */
         channel.basicConsume("hello",true,consumer);
         //等待程序完成
         Thread.sleep(5000);
    
         //5.释放资源
         channel.close();
         connection.close();
    
     }
相关推荐
AC赳赳老秦19 小时前
外文文献精读:DeepSeek翻译并解析顶会论文核心技术要点
前端·flutter·zookeeper·自动化·rabbitmq·prometheus·deepseek
invicinble2 天前
关于Rabbitmq在逻辑主体层面的配置
spring boot·rabbitmq·java-rabbitmq
I_Jln.2 天前
RabbitMQ+SpringAMQP 从入门到精通
分布式·rabbitmq
编程彩机3 天前
互联网大厂Java面试:从Spring Boot到消息队列的技术场景解析
java·spring boot·分布式·面试·kafka·消息队列·rabbitmq
洛阳纸贵3 天前
JAVA高级工程师--RabbitMQ消费者消息限流、超时、死信队列以及若依集成升级
java·rabbitmq·java-rabbitmq
福赖3 天前
《微服务即使通讯中RabbitMQ的作用》
c++·微服务·架构·rabbitmq
h7ml4 天前
基于 RabbitMQ 构建异步化淘客订单处理流水线:解耦、削峰与失败重试
分布式·rabbitmq·ruby
小北方城市网5 天前
Spring Boot Actuator+Prometheus+Grafana 生产级监控体系搭建
java·spring boot·python·rabbitmq·java-rabbitmq·grafana·prometheus
不想写bug呀5 天前
RabbitMQ集群和仲裁队列
rabbitmq·集群·仲裁队列
信创天地6 天前
国产化数据库深度运维:性能调优与故障排查实战指南
运维·数据库·安全·elk·自动化·rabbitmq