当前位置:   article > 正文

RabbitMQ 常用使用方式_rabbitmq和robbitmq

rabbitmq和robbitmq

目录

 第一步:导入依赖

 第一步:实现

1、原生方式

2、RabbitTemplate工具

 2.1 导入spring-boot-starter-amqp依赖

 2.2 RabbitTemplate的使用步骤


 

第一步:导入依赖

普通项目导入依赖

<!--指定 jdk 编译版本-->
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>8</source>
                <target>8</target>
            </configuration>
        </plugin>
    </plugins>
</build>
<dependencies>
    <!--rabbitmq 依赖客户端-->
    <dependency>
        <groupId>com.rabbitmq</groupId>
        <artifactId>amqp-client</artifactId>
        <version>5.8.0</version>
    </dependency>
    <!--操作文件流的一个依赖-->
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.6</version>
    </dependency>
</dependencies>

 springboot工程导入依赖

        <!--SpringBoot整合AMQP-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>

 第一步:实现

1、原生方式

        

  1. public class Producer {
  2. public static final String QUEUE_NAME = "queue1";
  3. public static void main(String[] args) {
  4. // 建立连接工厂,但是没连接
  5. ConnectionFactory connectionFactory = new ConnectionFactory();
  6. connectionFactory.setHost("192.168.35.132");
  7. connectionFactory.setUsername("itcast");
  8. connectionFactory.setPassword("123321");
  9. try {
  10. // 创建一个连接
  11. Connection connection = connectionFactory.newConnection();
  12. // 创建一个信道
  13. Channel channel = connection.createChannel();
  14. // 创建一个队列
  15. /**
  16. * 生成一个队列
  17. * 1.队列名称
  18. * 2.队列里面的消息是否持久化 默认消息存储在内存中
  19. * 3.该队列是否只供一个消费者进行消费 是否进行共享 true 可以多个消费者消费
  20. * 4.是否自动删除 最后一个消费者端开连接以后 该队列是否自动删除 true 自动删除
  21. * 5.其他参数
  22. */
  23. channel.queueDeclare(QUEUE_NAME,false,false,false,null);
  24. // 发送消息
  25. /**
  26. * 发送一个消息
  27. * 1.发送到那个交换机
  28. * 2.路由的 key 是哪个
  29. * 3.其他的参数信息
  30. * 4.发送消息的消息体
  31. */
  32. channel.basicPublish("",QUEUE_NAME,null,"你好".getBytes());
  33. System.out.println("消息发送成功");
  34. } catch (Exception e) {
  35. e.printStackTrace();
  36. }
  37. }
  38. }
  1. public class Consumer {
  2. public static final String QUEUE_NAME = "queue1";
  3. public static void main(String[] args) {
  4. // 建立连接工厂,但是没连接
  5. ConnectionFactory connectionFactory = new ConnectionFactory();
  6. connectionFactory.setHost("192.168.35.132");
  7. connectionFactory.setUsername("itcast");
  8. connectionFactory.setPassword("123321");
  9. try {
  10. Connection connection = connectionFactory.newConnection();
  11. Channel channel = connection.createChannel();
  12. //推送的消息如何进行消费的接口回调
  13. DeliverCallback deliverCallback=(consumerTag,delivery)-> {
  14. String message= new String(delivery.getBody());
  15. System.out.println(message);
  16. };
  17. //取消消费的一个回调接口 如在消费的时候队列被删除掉了
  18. CancelCallback cancelCallback=(consumerTag)->{
  19. System.out.println("消息消费被中断");
  20. };
  21. /**
  22. * 1、消费哪个队列
  23. * 2、消费成功后是否自动应答
  24. * 3、消费未成功回调
  25. * 4、消费成功回调
  26. */
  27. String s = channel.basicConsume(QUEUE_NAME, true,deliverCallback,cancelCallback);
  28. } catch (Exception e) {
  29. e.printStackTrace();
  30. }
  31. }
  32. }

2、RabbitTemplate工具

SpringAMQP是基于RabbitMQ封装的一套模板,并且还利用SpringBoot对其实现了自动装配,使用起来非常方便。

2.1 导入spring-boot-starter-amqp依赖

<!--AMQP依赖,包含RabbitMQ-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

 2.2 RabbitTemplate的使用步骤

1、声明交换机和队列

  1. @Configuration
  2. public class FanoutConfig {
  3. /**
  4. * 声明交换机
  5. * @return Fanout类型交换机
  6. */
  7. @Bean
  8. public FanoutExchange fanoutExchange(){
  9. return new FanoutExchange("itcast.fanout");
  10. }
  11. /**
  12. * 第1个队列
  13. */
  14. @Bean
  15. public Queue fanoutQueue1(){
  16. return new Queue("fanout.queue1");
  17. }
  18. /**
  19. * 绑定队列和交换机
  20. */
  21. @Bean
  22. public Binding bindingQueue1(Queue fanoutQueue1, FanoutExchange fanoutExchange){
  23. return BindingBuilder.bind(fanoutQueue1).to(fanoutExchange);
  24. }
  25. /**
  26. * 第2个队列
  27. */
  28. @Bean
  29. public Queue fanoutQueue2(){
  30. return new Queue("fanout.queue2");
  31. }
  32. /**
  33. * 绑定队列和交换机
  34. */
  35. @Bean
  36. public Binding bindingQueue2(Queue fanoutQueue2, FanoutExchange fanoutExchange){
  37. return BindingBuilder.bind(fanoutQueue2).to(fanoutExchange);
  38. }
  39. }

2、生产者

  1. spring:
  2. rabbitmq:
  3. host: 192.168.150.101 # 主机名
  4. port: 5672 # 端口
  5. virtual-host: / # 虚拟主机
  6. username: itcast # 用户名
  7. password: 123321 # 密码
  1. @Autowired
  2. private RabbitTemplate rabbitTemplate;
  3. @Test
  4. public void testSimpleQueue() {
  5. // 队列名称
  6. String queueName = "simple.queue";
  7. // 消息
  8. String message = "hello, spring amqp!";
  9. // 发送消息
  10. rabbitTemplate.convertAndSend(queueName, message);
  11. }

 3、消费者

  1. spring:
  2. rabbitmq:
  3. host: 192.168.150.101 # 主机名
  4. port: 5672 # 端口
  5. virtual-host: / # 虚拟主机
  6. username: itcast # 用户名
  7. password: 123321 # 密码

  1. @RabbitListener(queues = "fanout.queue1")
  2. public void listenFanoutQueue1(String msg) {
  3. System.out.println("消费者1接收到Fanout消息:【" + msg + "】");
  4. }
  5. @RabbitListener(queues = "fanout.queue2")
  6. public void listenFanoutQueue2(String msg) {
  7. System.out.println("消费者2接收到Fanout消息:【" + msg + "】");
  8. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/543496
推荐阅读
相关标签
  

闽ICP备14008679号