Docker部署RabbitMQ及整合Spring Boot示例

在docker中安装RabbitMQ,一行搞定

docker run -d --name myactivemq -p 61616:61616 -p 8161:8161 webcenter/activemq

安装完成后,打开RabbitMQ管理系统

http://ip:15672

创建示例程序

打开idea,使用spring initialzr快速创建Spring boot项目,并打开pom,集成RabbitMQ

<!--rabbitMq-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

修改application.properties 添加以下配置

spring.rabbitmq.host=ip
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
spring.rabbitmq.listener.concurrency=10
spring.rabbitmq.listener.max-concurrency=20
spring.rabbitmq.listener.prefetch=5

创建SenderConf类

import org.springframework.amqp.core.*;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * Created by ccwant on 2019-04-04.
 */
@Configuration
public class SenderConf {

    @Bean(name="Amessage")
    public Queue AMessage() {
        return new Queue("fanout.A",true);//true表示持久化该队列
    }


    @Bean(name="Bmessage")
    public Queue BMessage() {
        return new Queue("fanout.B",true);
    }

    @Bean(name="Cmessage")
    public Queue CMessage() {
        return new Queue("fanout.C",true);
    }


    @Bean
    public TopicExchange topicExchange() {
        return new TopicExchange("topicExchange");//配置广播路由器
    }

    @Bean
    public Binding bindingExchangeA(@Qualifier("Amessage") Queue AMessage,TopicExchange topicExchange) {
        return BindingBuilder.bind(AMessage).to(topicExchange).with("123");
    }

    @Bean
    public Binding bindingExchangeB(@Qualifier("Bmessage") Queue BMessage, TopicExchange topicExchange) {
        return BindingBuilder.bind(BMessage).to(topicExchange).with("456");
    }

    @Bean
    public Binding bindingExchangeC(@Qualifier("Cmessage") Queue CMessage, TopicExchange topicExchange) {
        return BindingBuilder.bind(CMessage).to(topicExchange).with("789");
    }
}

创建HelloReceive类

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

/**
 * Created by ccwant on 2019-04-04.
 */
@Component
public class HelloReceive {


    @RabbitListener(queues="fanout.A")
    public void processA(String str1) {
        System.out.println("ReceiveA:"+str1);
    }
    @RabbitListener(queues="fanout.B")
    public void processB(String str) {
        System.out.println("ReceiveB:"+str);
    }
    @RabbitListener(queues="fanout.C")
    public void processC(String str) {
        System.out.println("ReceiveC:"+str);
    }
}

创建HelloSender类

import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

/**
 * Created by ccwant on 2019-04-04.
 */
@Component
public class HelloSender {
    @Autowired
    private AmqpTemplate template;

    public void send() {
        System.out.println("发送消息");
        template.convertAndSend("topicExchange","123","hello,rabbit~  你好");
    }
}

最后写一个单元测试

@RunWith(SpringRunner.class)
@SpringBootTest(classes = RabbitMqDemoApplication.class)
public class RabbitMqDemoApplicationTests {

	@Test
	public void contextLoads() {
	}
	@Autowired
	private HelloSender helloSender;

	@Test
	public void testRabbit() {
		helloSender.send();
	}
}

先运行Application,然后再运行单元测试发送消息

到此RabbitMQ已经跑通了

 

### 回答1: Spring Boot 配置 RabbitMQ 的步骤如下: 1. 安装 RabbitMQ 服务器,可以在官网下载安装,也可以使用 Docker 容器来运行 RabbitMQ。 2. 在项目中添加依赖,可以在 pom.xml 中添加以下内容: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 3. 在 application.properties 或者 application.yml 文件中配置 RabbitMQ 相关的参数,例如: ``` spring.rabbitmq.host=127.0.0.1 spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 4. 创建一个消息生产者类,实现向 RabbitMQ 发送消息。 5. 创建一个消息消费者类,实现从 RabbitMQ 接收消息。 6. 在 Spring Boot 启动类中添加 @EnableRabbit 注解,以启用 RabbitMQ 的相关配置。 7. 运行项目,检查 RabbitMQ 是否能够正常收发消息。 以上是 Spring Boot 配置 RabbitMQ 的大致步骤,详细内容可以参考官方文档或者相关教程。 ### 回答2: Spring Boot是一个开源的Java开发框架,它简化了基于Spring框架的应用程序的开发和配置。RabbitMQ是一个可靠的消息队列服务,用于异步通信和解耦应用程序的组件。 要在Spring Boot中配置RabbitMQ,首先需要添加相应的依赖。在pom.xml文件中,引入以下依赖项: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 完成依赖配置后,我们可以在Spring Boot应用程序的配置文件(application.properties或application.yml)中添加RabbitMQ的相关配置。下面是一些常见的配置示例: ``` spring.rabbitmq.host=localhost # RabbitMQ服务器的主机地址 spring.rabbitmq.port=5672 # RabbitMQ服务器的端口号 spring.rabbitmq.username=guest # RabbitMQ登录用户名 spring.rabbitmq.password=guest # RabbitMQ登录密码 ``` 除了上面的配置,还有其他一些可选的配置项,如虚拟主机(virtual host)、路由键(routing key)等。根据具体需求,可以按需进行配置。 在应用程序中使用RabbitMQ时,可以使用Spring Boot提供的注解来简化代码。例如,使用`@RabbitListener`注解来声明一个接收消息的方法,使用`@EnableRabbit`注解来启用RabbitMQ功能。 以下是一个简单的示例: ```java @Component @RabbitListener(queues = "myQueue") public class MyMessageListener { @RabbitHandler public void handleMessage(String message) { System.out.println("Received: " + message); } } ``` 上述代码将声明一个名为`myQueue`的队列,并使用`handleMessage`方法来处理接收到的消息。当有消息发送到`myQueue`队列时,`handleMessage`方法将被调用。 这就是使用Spring Boot配置RabbitMQ的基本步骤。通过添加相关依赖,配置RabbitMQ的主机、端口、用户名和密码等信息,然后使用相应注解来处理消息的接收和处理逻辑。这样可以简化我们在Spring Boot应用程序中使用RabbitMQ的流程。 ### 回答3: Spring Boot配置RabbitMQ可以通过以下步骤完成: 1. 添加RabbitMQ依赖:首先,在项目的pom.xml文件中,添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 这样可以使用Spring Boot提供的自动配置来集成RabbitMQ。 2. 配置RabbitMQ连接信息:在项目的application.properties或application.yml文件中,添加RabbitMQ连接信息,如下所示: ```yaml spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 这里设置了RabbitMQ服务器的主机名、端口号、用户名和密码。你可以根据实际情况进行修改。 3. 创建RabbitMQ消息队列:在需要使用RabbitMQ的地方,使用`@RabbitListener`和`@RabbitHandler`注解来创建消息队列,如下所示: ```java @Component @RabbitListener(queues = "myQueue") public class MyMessageListener { @RabbitHandler public void handleMessage(String message) { // 处理收到的消息 } } ``` 这个示例创建了一个名为"myQueue"的消息队列,并使用`MyMessageListener`类来监听该队列,并在收到消息时调用`handleMessage`方法进行处理。 4. 发送消息:在需要发送消息的地方,通过注入`AmqpTemplate`对象来发送消息,如下所示: ```java @Autowired private AmqpTemplate amqpTemplate; public void send(String message) { amqpTemplate.convertAndSend("myQueue", message); } ``` 这里使用`convertAndSend`方法将消息发送到名为"myQueue"的消息队列中。 这样,你就完成了Spring Boot配置RabbitMQ的过程。可以通过监听和发送消息来实现你的业务逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值