我尝试为类型为DeadLetterChannel的errorHandler指定记录器名称,并且出现有关无法为此使用logName的错误。
是否可以指定记录器名称?
还是不好的做法,将自己的记录器名称用于dlc?
我的配置
<errorHandler id="myDeadLetterChannel" type="DeadLetterChannel" deadLetterUri="direct:deadLetterChannel" logName="MYLOGGERNAME">
<redeliveryPolicy maximumRedeliveries="5" retryAttemptedLogLevel="INFO" backOffMultiplier="2" useExponentialBackOff="true" />
</errorHandler>
实际日志消息:
13:31:46,947 | INFO | evMasterDbEvent] | DeadLetterChannel 176 | 144 - org.apache.camel.camel-core - 2.12.0.redhat-610379 | Failed delivery for (MessageId: ID:tetra-backend-43331-1577539405267-13:6:2:1:1 on ExchangeId: ID-tetra-backend-38269-1577539416633-5-5). On delivery attempt: 0 caught: com.x.exception.BusinessLogicException: Unexpected event type ZZZ
预期的日志消息:
13:31:46,947 | INFO | evMasterDbEvent] | MYLOGGERNAME 176 | 144 - org.apache.camel.camel-core - 2.12.0.redhat-610379 | Failed delivery for (MessageId: ID:tetra-backend-43331-1577539405267-13:6:2:1:1 on ExchangeId: ID-tetra-backend-38269-1577539416633-5-5). On delivery attempt: 0 caught: com.x.exception.BusinessLogicException: Unexpected event type ZZZ
我还尝试添加CamelLogEipName,这样我就不会更改记录器名称...
<camelContext xmlns="http://camel.apache.org/schema/spring">
<properties>
<property key="CamelLogEipName" value="MYLOGGERNAME"/>
</properties>
答案 0 :(得分:1)
我提出/找到了一些解决方案,但也许Apache Camel支持更好的解决方案?
配置:
<bean id="myRedeliveryPolicyConfig" class="org.apache.camel.processor.RedeliveryPolicy">
<property name="maximumRedeliveries" value="3" />
<property name="backOffMultiplier" value="2" />
<property name="useExponentialBackOff" value="true" />
<property name="retryAttemptedLogLevel" value="WARN" />
</bean>
<bean id="myDeadLetterChannel" class="com.x.MyDeadLetterChannelBuilder">
<property name="deadLetterUri" value="direct:deadLetterChannel"/>
<property name="redeliveryPolicy" ref="myRedeliveryPolicyConfig"/>
<property name="loggerName" value="MYLOGGERNAME"/>
</bean>
<camelContext xmlns="http://camel.apache.org/schema/spring">
<route id="myEventTriggerRoute" errorHandlerRef="zDeadLetterChannel">
<from uri="{{my.jmsVirtualTopic.myEventConsumer}}" />
<process ref="myDbEventProcessor" />
</route>
<route>
<from uri="direct:deadLetterChannel" />
<log loggingLevel="INFO" message="Message added to dead letter queue" />
<to uri="{{my.jms.myEventDeadLetterQueueIn}}" />
</route>
</camelContext>
自定义DeadLetterChannelBuilder
import org.apache.camel.LoggingLevel;
import org.apache.camel.builder.DeadLetterChannelBuilder;
import org.apache.camel.util.CamelLogger;
import org.slf4j.LoggerFactory;
import lombok.Getter;
import lombok.Setter;
@Getter
@Setter
public class MyDeadLetterChannelBuilder extends DeadLetterChannelBuilder {
private String loggerName;
@Override
protected CamelLogger createLogger() {
return new CamelLogger(LoggerFactory.getLogger(loggerName), LoggingLevel.ERROR);
}
}