如何在类型为DeadLetterChannel的Camel的errorHandler中设置记录器名称?

时间:2019-12-28 14:32:58

标签: exception logging apache-camel apache-karaf

我尝试为类型为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>

1 个答案:

答案 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);
    }
}