骡子用流定制记录器
mule customizing the logger with flows
我有四个流程,每个流程都有 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 目录中打印记录器。
我需要做的是,对于每个流或 url,mule 必须创建日志文件作为 test1-12:20:00(present-time).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 配置中执行吗?
如果不进行大量工作,仅使用 log4j 将无法做到这一点。但是,您可以在记录器消息前加上 #[flow.name]
.
我认为您可以使用类别来完成此操作。
首先,在 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 并更好地控制滚动发生的时间以及文件名的生成方式。
我有四个流程,每个流程都有 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 目录中打印记录器。
我需要做的是,对于每个流或 url,mule 必须创建日志文件作为 test1-12:20:00(present-time).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 配置中执行吗?
如果不进行大量工作,仅使用 log4j 将无法做到这一点。但是,您可以在记录器消息前加上 #[flow.name]
.
我认为您可以使用类别来完成此操作。
首先,在 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 并更好地控制滚动发生的时间以及文件名的生成方式。