mule用流量定制记录器

时间:2015-03-05 20:27:55

标签: mule

我有四个流程,每个流程都有http终点:

<flow1 >
<http:myhosts:port path="test1">
</flow1>
<flow2>
<http:myhosts:port path="test2">
</flow2>
<flow3>
<http:myhosts:port path="test3">
</flow3>
<flow4>
<http:myhosts:port path="test4">
</flow1>

我正在使用mule 3.5,已将log4j.properties定义为

log = /tmp
log4j.rootLogger=INFO, file
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File=${log}/mylogs.log
log4j.appender.file.DatePattern='.'ddMMyyyy
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
log4j.appender.console=org.apache.log4j.ConsoleAppender    
log4j.appender.console.Threshold=ERROR
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

它使用单个文件名在tmp目录中打印记录器。

我需要做的是,对于每个流或网址,mule必须创建日志文件,如test1-12:20:00(当前时间).log 所以如果我运行4个流程,那么我需要创建4个记录器文件作为

test1-12:20:00(present-time).log
test1-13:20:00(present-time).log
test1-14:20:00(present-time).log
test1-15:20:00(present-time).log

我该怎么做?这可以在Mule配置中做到吗?

2 个答案:

答案 0 :(得分:0)

如果没有大量的工作,你将无法使用log4j。但是,您可以使用#[flow.name]

添加记录器消息

答案 1 :(得分:0)

我认为你可以使用类别完成此任务。

首先,在log4j中创建四个单独的appender。对于Mule 3.5,您可以继续使用属性配置,但请记住,由于迁移到log4j2,您必须转到Mule 3.6中的XML配置。

log4j.appender.thing1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.thing1.File=/var/log/integration/Thing1/mylogs.log
# etc...
log4j.appender.thing2=org.apache.log4j.DailyRollingFileAppender
log4j.appender.thing2.File=/var/log/integration/Thing2/mylogs.log
# etc...

然后,为特定类别定义记录器,如下所示:

log4j.logger.com.mycompany.Thing1=DEBUG,thing1
log4j.logger.com.mycompany.Thing2=DEBUG,thing2
# etc...

最后,在流程中添加使用相应类别的记录器:

<flow name="Thing1">
    <!-- your flow logic goes here -->
    <logger category="com.mycompany.Thing1" message="Something happened" level="INFO" />
    <!-- more flow logic goes here -->
</flow>

<flow name="Thing2">
    <!-- your other flow logic goes here -->
    <logger category="com.mycompany.Thing2" message="Something happened in flow 2" level="INFO" />
    <!-- more flow logic goes here -->
</flow>

请注意,当您移至3.6并开始使用log4j2时,您将能够利用更灵活的RollingFileAppender并更好地控制何时进行滚动以及如何生成文件名。