package com.ruoyi.integration.rocket.listener;
|
|
import com.ruoyi.chargingPile.api.feignClient.AccountingStrategyDetailClient;
|
import com.ruoyi.chargingPile.api.model.TAccountingStrategyDetail;
|
import com.ruoyi.integration.api.model.Online;
|
import com.ruoyi.integration.api.model.UploadRealTimeMonitoringData;
|
import com.ruoyi.integration.mongodb.service.UploadRealTimeMonitoringDataService;
|
import com.ruoyi.integration.rocket.model.UploadRealTimeMonitoringDataMessage;
|
import com.ruoyi.integration.rocket.util.EnhanceMessageHandler;
|
import com.ruoyi.order.api.feignClient.ChargingOrderClient;
|
import com.ruoyi.order.api.model.TChargingOrder;
|
import com.ruoyi.order.api.query.UploadRealTimeMonitoringDataQuery;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.rocketmq.spring.annotation.MessageModel;
|
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;
|
|
import javax.annotation.Resource;
|
import java.math.BigDecimal;
|
import java.math.RoundingMode;
|
import java.util.Objects;
|
|
@Slf4j
|
@Component
|
@RocketMQMessageListener(
|
messageModel = MessageModel.CLUSTERING,
|
consumerGroup = "charge_upload_real_time_monitoring_data",
|
topic = "charge_upload_real_time_monitoring_data",
|
selectorExpression = "upload_real_time_monitoring_data",
|
consumeThreadMax = 5 //默认是64个线程并发消息,配置 consumeThreadMax 参数指定并发消费线程数,避免太大导致资源不够
|
)
|
public class UploadRealTimeMonitoringDataMessageListener extends EnhanceMessageHandler<UploadRealTimeMonitoringDataMessage> implements RocketMQListener<UploadRealTimeMonitoringDataMessage> {
|
|
@Autowired
|
private UploadRealTimeMonitoringDataService uploadRealTimeMonitoringDataService;
|
|
@Resource
|
private ChargingOrderClient chargingOrderClient;
|
@Resource
|
private AccountingStrategyDetailClient accountingStrategyDetailClient;
|
|
|
@Override
|
protected void handleMessage(UploadRealTimeMonitoringDataMessage message) throws Exception {
|
// 此时这里才是最终的业务处理,代码只需要处理资源类关闭异常,其他的可以交给父类重试
|
log.info("上传实时监测数据-业务消息处理:{}",message);
|
// 持久化消息
|
UploadRealTimeMonitoringData uploadRealTimeMonitoringData = new UploadRealTimeMonitoringData();
|
BeanUtils.copyProperties(message,uploadRealTimeMonitoringData);
|
// 查询mogondb上一条数据
|
UploadRealTimeMonitoringData data = uploadRealTimeMonitoringDataService.getLastDataById(message.getTransaction_serial_number());
|
// 查询订单
|
TChargingOrder chargingOrder = chargingOrderClient.getOrderByCode(message.getTransaction_serial_number()).getData();
|
// 查询当前时间段的计费策略
|
TAccountingStrategyDetail accountingStrategyDetail = accountingStrategyDetailClient.getDetailBySiteId(chargingOrder.getSiteId()).getData();
|
uploadRealTimeMonitoringData.setElectrovalence_all(accountingStrategyDetail.getElectrovalence());
|
uploadRealTimeMonitoringData.setService_charge(accountingStrategyDetail.getServiceCharge());
|
if (Objects.nonNull(data)) {
|
uploadRealTimeMonitoringData.setLast_time(data.getLast_time());
|
uploadRealTimeMonitoringData.setPeriod_electric_price(message.getPaid_amount().divide(data.getPaid_amount()));
|
uploadRealTimeMonitoringData.setPeriod_charging_degree(message.getCharging_degree().divide(data.getCharging_degree()));
|
uploadRealTimeMonitoringData.setPeriod_service_price(message.getCharging_degree().multiply(accountingStrategyDetail.getServiceCharge()).setScale(4, RoundingMode.HALF_UP));
|
}else {
|
log.info("首次上传实时监测数据");
|
uploadRealTimeMonitoringData.setPeriod_electric_price(message.getPaid_amount());
|
uploadRealTimeMonitoringData.setPeriod_charging_degree(message.getCharging_degree());
|
uploadRealTimeMonitoringData.setPeriod_service_price(message.getCharging_degree().multiply(accountingStrategyDetail.getServiceCharge()).setScale(4, RoundingMode.HALF_UP));
|
}
|
uploadRealTimeMonitoringDataService.create(uploadRealTimeMonitoringData);
|
// 业务处理
|
UploadRealTimeMonitoringDataQuery query = new UploadRealTimeMonitoringDataQuery();
|
BeanUtils.copyProperties(uploadRealTimeMonitoringData, query);
|
chargingOrderClient.chargeMonitoring(query);
|
|
// 存储状态信息
|
|
|
}
|
|
@Override
|
protected void handleMaxRetriesExceeded(UploadRealTimeMonitoringDataMessage message) {
|
// 当超过指定重试次数消息时此处方法会被调用
|
// 生产中可以进行回退或其他业务操作
|
log.error("消息消费失败,请执行后续处理");
|
}
|
|
|
/**
|
* 是否执行重试机制
|
*/
|
@Override
|
protected boolean isRetry() {
|
return true;
|
}
|
|
@Override
|
protected boolean throwException() {
|
// 是否抛出异常,false搭配retry自行处理异常
|
return false;
|
}
|
|
/**
|
* 若需要处理消息过滤,在父级中进行统一处理,或者在此处实现之后,自行处理
|
* @param message 待处理消息
|
* @return true: 本次消息被过滤,false:不过滤
|
*/
|
@Override
|
protected boolean filter(UploadRealTimeMonitoringDataMessage message) {
|
// 此处可做消息过滤
|
return false;
|
}
|
|
/**
|
* 监听消费消息,不需要执行业务处理,委派给父类做基础操作,父类做完基础操作后会调用子类的实际处理类型
|
*/
|
@Override
|
public void onMessage(UploadRealTimeMonitoringDataMessage message) {
|
super.dispatchMessage(message);
|
}
|
}
|