【开发篇】二十、SpringBoot整合RocketMQ

文章目录

1、整合

首先导入起步依赖,RocketMQ的starter不是Spring维护的,这一点从starter的命名可以看出来(不是spring-boot-starter-xxx,而是xxx-spring-boot-starter,和MyBatisPlus、Druid一样),因此version值得自己加:

xml 复制代码
<dependency>   
	<groupId>org.apache.rocketmq</groupId>    
	<artifactId>rocketmq-spring-boot-starter</artifactId> 
	<version>2.2.1</version>
</dependency>

添加相关配置:

yaml 复制代码
rocketmq:  
  name-server: localhost:9876  
  producer:    
    group: group_rocketmq  # 设置一个自定义的生产者默认组名,省掉这个启动会报错

在需要的地方注入RocketMQTemplate操作对象:

java 复制代码
@Autowired    
private RocketMQTemplate rocketMQTemplate;

2、消息的生产

发送消息继续convertAndSend方法,接着上篇在Service层来演示:

java 复制代码
@Service
@Slf4j
public class MessageServiceRocketmqImpl implements MessageService {    

	@Autowired    
	private RocketMQTemplate rocketMQTemplate;    

	@Override    
	public void sendMessage(String id) {        
		
		rocketMQTemplate.convertAndSend("order_sm_id",id);      
		
		log.info("使用Rabbitmq将待发送短信的订单纳入处理队列,id:"+id);    
	}
}

convertAndSend方法依旧重载,可以直接传一个Object,也可以先传一个destination参数,即发到哪儿,再传要发的message

3、消费

这里不演示手动receive方法拿消息,直接用监听器自动拿来消费:实现RocketMQListener接口,泛型为Message类型,重写onMessage方法,加@RocketMQMessageListener注解,两个属性为主题名称和消费者组

java 复制代码
@Component
@Slf4j
@RocketMQMessageListener(topic="order_sm_id",consumerGroup = "group_rocketmq")
public class RocketmqMessageListener implements RocketMQListener<String> {  
  
	@Override    
	public void onMessage(String id) {        
		log.info("已完成短信发送业务,id:"+id);    
	}
}

4、发送异步消息

java 复制代码
@Service
@Slf4j
public class MessageServiceRocketmqImpl implements MessageService {   

	@Autowired    
	private RocketMQTemplate rocketMQTemplate;    

	@Override   
	public void sendMessage(String id) {        
		
		//回调逻辑
		SendCallback callback = new SendCallback() {            
			@Override            
			public void onSuccess(SendResult sendResult) {                
				//消息发送成功后你要做的业务
				//...
				log.info("消息发送成功");            
			}     
			       
			@Override            
			public void onException(Throwable throwable) {               
				log.info("消息发送失败!!!!!!!!!!!");            
			}        
		};     
				
		//异步发送
		rocketMQTemplate.asyncSend("order_sm_id",id,callback);  
		log.info("使用Rabbitmq将待发送短信的订单纳入处理队列,id:"+id);      
	}
}

asyncSend异步发消息,有个参数是callback回调方法,类型是一个接口,创建这个对象的时候重写onSuccess和OnException方法,即消息发送成功以后的逻辑和消息发送失败以后的逻辑(异步的体现,不用等,来个回调)。

5、补充:安装RocketMQ

建议以Docker方式启动,下面备份下在Windows的安装(安装为一个系统服务):

  • 下载
java 复制代码
下载地址:https://rocketmq.apache.org/
  • 安装:解压缩即可
java 复制代码
默认服务端口:9876
  • 环境变量配置
java 复制代码
ROCKETMQ_HOME
PATH
NAMESRV_ADDR (建议): 127.0.0.1:9876
  • 启动命名服务器:
java 复制代码
mqnamesrv
  • 启动Broker
java 复制代码
mqbroker
  • 服务器功能测试:生产数据
java 复制代码
tools org.apache.rocketmq.example.quickstart.Producer
  • 服务器功能测试:消费数据
java 复制代码
tools org.apache.rocketmq.example.quickstart.Consumer
相关推荐
MC丶科4 分钟前
【SpringBoot常见报错与解决方案】端口被占用?Spring Boot 修改端口号的 3 种方法,第 3 种 90% 的人不知道!
java·linux·spring boot
计算机学长felix29 分钟前
基于SpringBoot的“中学信息技术课程教学网站”的设计与实现(源码+数据库+文档+PPT)_2025-10-17
数据库·spring boot·后端
Luffe船长1 小时前
前端vue2+js+springboot实现excle导入优化
前端·javascript·spring boot
周杰伦_Jay1 小时前
【Spring Boot从入门到精通】原理、实战与最佳实践
java·spring boot·后端
呼哧呼哧.1 小时前
SpringBoot 的入门开发
java·spring boot·后端
武昌库里写JAVA2 小时前
C语言 函数指针和指针函数区别 - C语言零基础入门教程
vue.js·spring boot·sql·layui·课程设计
小学鸡!3 小时前
spring boot实现接口数据脱敏,整合jackson实现敏感信息隐藏脱敏
java·spring boot
左灯右行的爱情4 小时前
ImportCandidates 类详细解析
java·spring boot
J_bean4 小时前
Spring Boot 集成 WebSocket 的实战案例
spring boot·websocket
摇滚侠4 小时前
Spring Boot 3零基础教程,WEB 开发 默认的自动配置,笔记25
前端·spring boot·笔记