我正在使用DSL在spring集成中开发一个API,它是这样工作的。
JDBC Polling Adapter初始化流,并从表中获取一些数据并将其发送到DefaultRequestChannel,从这里消息通过不同的通道进行处理/流动。
现在我正试着
如果在我的错误通道中发生/检测到任何错误(例如,连接问题、轮询数据时发现错误记录),
我试着创建一个sendEmailChannel (我的errorChannel的接收者),它对我不起作用。因此,我创建了一个如下所示的转换器方法
这段代码运行得很好,但这是一种好的做法吗?
@Transformer(inputChannel="errorChannel", outputChannel="suspendChannel")
public Message<?> errorChannelHandler(ErrorMessage errorMessage) throws RuntimeException, MessagingException, InterruptedException {
Exception exception = (Exception) errorMessage.getPayload();
String errorMsg = errorMessage.toString();
String subject = "API issue";
if (exception instanceof RuntimeException) {
errorMsg = "Run time exception";
subject = "Critical Alert";
}
if (exception instanceof JsonParseException) {
errorMsg = ....;
subject = .....;
}
MimeMessage message = sender.createMimeMessage();
MimeMessageHelper helper = new MimeMessageHelper(message);
helper.setFrom(senderEmail);
helper.setTo(receiverEmail);
helper.setText(errorMsg);
helper.setSubject(subject);
sender.send(message);
kafkaProducerSwitch.isKafkaDown());
return MessageBuilder.withPayload(exception.getMessage())
.build();
}
我正在寻找一些更好的方法来处理上述逻辑。还有任何建议,暂停我的流量几分钟。
https://stackoverflow.com/questions/56412332
复制相似问题