SpringBoot整合RabbitMQ(一):简单使用

我所用的Springboot 的版本是1.5.13

先来看pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.dai</groupId>
	<artifactId>rabbitmq-mycsdn</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>rabbitmq-mycsdn</name>
	<description>Demo project for Spring Boot</description>
        <!-- 我的springboot的版本  -->
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.13.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		<dependency><!-- springboot支持amqp和JMS规范 这边RabbitMQ是amqp的实现 读者可以尝试使用JMS规范的ActiveMQ -->
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-amqp</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>


</project>

Pom文件很简单。使用IDEA能够在创建springboot的时候自行选择需要添加的模块,非常的方便!

在需要添加一些自己想要的依赖时(比如来个数据库或者缓存等)可以参考springboot的官方文档,里面都有相应的依赖。

https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-starter


好了。看一下我们需要配置些什么吧?

按照SpringBoot的“尿性”,关于RabbitMQ基本上都在下面这个类里面了

@Configuration
@ConditionalOnClass({ RabbitTemplate.class, Channel.class })
@EnableConfigurationProperties(RabbitProperties.class)
@Import(RabbitAnnotationDrivenConfiguration.class)
public class RabbitAutoConfiguration {
@ConfigurationProperties(prefix = "spring.rabbitmq")
public class RabbitProperties {

下面这个是RabbitMQ的配置,基本上每个属性都有注释。下面我们来配置简单的属性配置吧。

server:
  port: 8080

spring:
  rabbitmq:
    host: 192.168.11.18
    username: guest
    password: guest
这是我的yml文件,配置很简单。先是配置Rabbiymq 的地址,然后是用户名和密码,这里都用的是guest,上一个文章有讲过RabbitMQ默认就是guest,这个可以在运行的时候手动指定。这边不展开说

简单的配置完成了,来尝试收发简单的消息。

@RunWith(SpringRunner.class)
@SpringBootTest
public class RabbitmqMycsdnApplicationTests {

	@Autowired
	RabbitTemplate rabbitTemplate;

	@Test
	public void contextLoads1() {
		rabbitTemplate.convertAndSend("dai.topic","dai.test.idea","Hello,my frist Springboot integrate RabbitMQ");
		Object o =  rabbitTemplate.receiveAndConvert("dai.topic-queue");
		System.out.println(o.toString());
	}
}

这边我使用了RabbitTemplate来收发消息。

@Override
	public void convertAndSend(String exchange, String routingKey, final Object object) throws AmqpException {
		convertAndSend(exchange, routingKey, object, (CorrelationData) null);
	}

第一个参数是交换器的名称,我用的是下面这个


第二个参数是路由键


第三个参数就是你要发送的消息了。


@Override
	public Object receiveAndConvert(String queueName) throws AmqpException {
		return receiveAndConvert(queueName, this.receiveTimeout);
	}

这是根据队列的名称来接收消息。返回值是Object类型。

好了大致上了解了这两个方法的使用,来看一下能否正常的收发消息吧。

发送消息:

运行程序后来看一下:


队列中已经有一条消息了,看一下消息的内容是否跟我们发送的消息是一致的


消息的内容是跟我们发送的一致,注意的点是content-type,这里让大家注意一下是默认的消息类型是text/plain的,看一下我们程序收到的消息是否也是一样的



好了,简单的收发消息已经完成了。下一篇文章再来实现发送实体类,JSON类型的数据;就是定制MessageConverter。而且我们现在这样子来接收消息,在开发中是很蛋疼的,我们还需要一个监听器来监听队列中的新消息呢。


SpringBoot整合RabbitMQ(二):定制MessageConverter

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot框架可以很容易地与RabbitMQ进行集成。为了实现这个目标,你需要在项目的依赖项中添加两个关键的依赖项。首先,你需要添加spring-boot-starter-amqp依赖项,它提供了与RabbitMQ进行通信的必要类和方法。其次,你还需要添加spring-boot-starter-web依赖项,以便在项目中使用Web功能。 在你的项目中创建两个Spring Boot应用程序,一个是RabbitMQ的生产者,另一个是消费者。通过这两个应用程序,你可以实现消息的发送和接收。生产者应用程序负责将消息发送到RabbitMQ的消息队列,而消费者应用程序则负责从队列中接收并处理消息。这样,你就可以实现基于RabbitMQ的消息传递系统。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot整合RabbitMQ](https://blog.csdn.net/K_kzj_K/article/details/106642250)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Springboot 整合RabbitMq ,用心看完这一篇就够了](https://blog.csdn.net/qq_35387940/article/details/100514134)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [undefined](undefined)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值