我正在尝试在log4j中创建自定义布局,如article中所述。
我在下面创建了一个简单的CustomLayout
-
public class CustomLayout extends PatternLayout {
public String format(LoggingEvent event)
{
return "Custom Layout";
}
}
一个简单的自定义appender如下所示
public class DummyAppender extends AppenderSkeleton {
private int port;
private String apiKey;
public int getPort() {
return port;
}
public void setPort(int port) {
this.port = port;
}
public String getApiKey() {
return apiKey;
}
public void setApiKey(String apiKey) {
this.apiKey = apiKey;
}
public void close() {
}
public boolean requiresLayout() {
return false;
}
@Override
protected void append(LoggingEvent arg0) {
System.out.println("Logging from Appender " + arg0.getMessage() + " stack");
ThrowableInformation t = arg0.getThrowableInformation();
if(t != null) {
System.out.println("Logging from Appender " + Arrays.asList(t.getThrowableStrRep()).size());
}
}
}
log4j.xml
如下所示
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="dummyAppender" class="com.log.DummyAppender">
<param name="Port" value="1234" />
<param name="ApiKey" value="ABCDEGH" />
<layout class="com.log.CustomLayout">
</layout>
</appender>
<root>
<priority value="error" />
<appender-ref ref="dummyAppender" />
</root>
</log4j:configuration>
主要类如下
public class HelloLogger {
private static final Logger logger = LoggerFactory.getLogger(HelloLogger.class);
public static void main(String[] args) {
logger.info("Hello World");
logger.error("Hello {}. Are u in {}", "Woo", "huhu", new Exception("huhuh876"));
}
}
在运行主类时,似乎没有使用CustomLayout。
输出
Logging from Appender Hello Woo. Are u in huhu stack
Logging from Appender 2
有人能让我知道我做错了什么吗?
答案 0 :(得分:-1)
您需要更改正在使用的Logger以获取appender实例。
请参阅以下代码。
import org.apache.log4j.Logger;
/**
* Hello world!
*
*/
public class HelloLogger {
private static final Logger logger = Logger.getLogger(HelloLogger.class);
public static void main( String[] args )
{
String s = "Woo";
String s1 = "huhu";
logger.error("Hello "+s+". Are u in "+s1+" ");
}
}
输出如下。
从Appender Hello Woo登录。你在胡胡堆栈吗
我建议使用log4j2而不是Log4j,因为你可以将它用于异步日志记录,这有助于提高性能。