From 80835bcc12f4788c1a88da61e623b362e57f1cb1 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期六, 24 八月 2024 09:31:43 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/mx_charging_pile

---
 ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/PingMessageListener.java |   30 ++++++++++++++++++++++--------
 1 files changed, 22 insertions(+), 8 deletions(-)

diff --git a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/EnhanceMemberMessageListener.java b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/PingMessageListener.java
similarity index 62%
copy from ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/EnhanceMemberMessageListener.java
copy to ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/PingMessageListener.java
index 537f867..068909f 100644
--- a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/EnhanceMemberMessageListener.java
+++ b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/rocket/listener/PingMessageListener.java
@@ -1,10 +1,16 @@
 package com.ruoyi.integration.rocket.listener;
 
-import com.ruoyi.integration.rocket.test.MemberMessage;
+import com.ruoyi.integration.mongodb.model.Online;
+import com.ruoyi.integration.mongodb.model.Ping;
+import com.ruoyi.integration.mongodb.service.OnlineService;
+import com.ruoyi.integration.mongodb.service.PingService;
+import com.ruoyi.integration.rocket.model.PingMessage;
 import com.ruoyi.integration.rocket.util.EnhanceMessageHandler;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
 import org.apache.rocketmq.spring.core.RocketMQListener;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
 @Slf4j
@@ -15,16 +21,24 @@
         selectorExpression = "*",
         consumeThreadMax = 5 //默认是64个线程并发消息,配置 consumeThreadMax 参数指定并发消费线程数,避免太大导致资源不够
 )
-public class EnhanceMemberMessageListener extends EnhanceMessageHandler<MemberMessage> implements RocketMQListener<MemberMessage> {
+public class PingMessageListener extends EnhanceMessageHandler<PingMessage> implements RocketMQListener<PingMessage> {
+
+    @Autowired
+    private PingService pingService;
 
     @Override
-    protected void handleMessage(MemberMessage message) throws Exception {
+    protected void handleMessage(PingMessage message) throws Exception {
         // 此时这里才是最终的业务处理,代码只需要处理资源类关闭异常,其他的可以交给父类重试
-        System.out.println("业务消息处理:"+message.getUserName());
+        log.info("充电桩心跳包-业务消息处理:{}",message);
+        // 持久化消息
+        Ping ping = new Ping();
+        BeanUtils.copyProperties(message,ping);
+        pingService.create(ping);
+        // 业务处理
     }
 
     @Override
-    protected void handleMaxRetriesExceeded(MemberMessage message) {
+    protected void handleMaxRetriesExceeded(PingMessage message) {
         // 当超过指定重试次数消息时此处方法会被调用
         // 生产中可以进行回退或其他业务操作
         log.error("消息消费失败,请执行后续处理");
@@ -51,7 +65,7 @@
      * @return true: 本次消息被过滤,false:不过滤
      */
     @Override
-    protected boolean filter(MemberMessage message) {
+    protected boolean filter(PingMessage message) {
         // 此处可做消息过滤
         return false;
     }
@@ -60,7 +74,7 @@
      * 监听消费消息,不需要执行业务处理,委派给父类做基础操作,父类做完基础操作后会调用子类的实际处理类型
      */
     @Override
-    public void onMessage(MemberMessage memberMessage) {
-        super.dispatchMessage(memberMessage);
+    public void onMessage(PingMessage message) {
+        super.dispatchMessage(message);
     }
 }
\ No newline at end of file

--
Gitblit v1.7.1