How does RollingFileAppender work with log4j2? - java

I'm use to RollingFileAppender on normal log4j. Now I'm switching to log4j2, and cannot get the appender to work.
The File appender below works as expected. But the logging file for RollingFile is never created. Why?
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
<Appenders>
<File name="FILE" fileName="c:/logs.log">
<PatternLayout pattern="%d %p %c: %m%n" />
</File>
<RollingFile name="ROLLING" fileName="c:/logsroll.log">
<PatternLayout pattern="%d %p %c: %m%n"/>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="0.001 MB"/>
</Policies>
<DefaultRolloverStrategy max="10"/>
</RollingFile>
</Appenders>
<Loggers>
<Root level="info">
<AppenderRef ref="FILE" />
<AppenderRef ref="ROLLING" />
</Root>
</Loggers>
</Configuration>

The RollingFile tag is missing a filePattern attribute.
<RollingFile name="ROLLING"
fileName="c:/logsroll.log"
filePattern="c:/logsroll-%i.log">

I used log4j2 version 2.0, in some cases it throws error if you do not set any date in file pattern, in this case you can use some thing like below:
<RollingFile name="MyFile" fileName="d:/log/bsi/admin/total/totalLog.log"
filePattern="d:/log/totalLog-%d{MM-dd-yyyy}-%i.log">
<PatternLayout>
<Pattern>%d %p %c [%t] %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="1 MB"/>
</Policies>
<DefaultRolloverStrategy max="2000"/>
</RollingFile>

Related

migrating log4j.xml to log4j2.xml jdk8

Hello i am migrating to latest log4j version and migrated from 1.x to 2.x log4j. So here is my log4j2 config file. I am stuck with debug and error logs, maybe someone could see that if there should be something different.
<?xml version="1.0" encoding="UTF-8" ?>
<Configuration status="debug" packages="">
<Appenders>
<!-- System.out log -->
<Console name="console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
</Console>
<!-- debug log -->
<RollingFile name="debug" fileName="/var/logs/debug.log"
filePattern="/var/logs/%d{ddMMyyyy}_debug.log.gz">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
<LevelRangeFilter minLevel="debug" maxLevel="info" onMatch="accept"/>
</RollingFile>
<!-- error log -->
<RollingFile name="error" fileName="/var/logs/error.log"
filePattern="/var/logs/%d{ddMMyyyy}_error.log.gz">>
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
<LevelRangeFilter minLevel="warn" maxLevel="fatal" onMatch="accept"/>
</RollingFile>
<!-- info log -->
<RollingFile name="info" fileName="/var/logs/info.log"
filePattern="/var/logs/%d{ddMMyyyy}_info.log.gz">>
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
<LevelRangeFilter minLevel="info" maxLevel="info" onMatch="accept"/>
</RollingFile>
<!-- Special daily time log. Logib kui palju aega iga Request vytab -->
<RollingFile name="timelog" fileName="/var/logs/input_timing.log"
filePattern="'.'yyyy-MM-dd'.log'">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- accesslog log appender -->
<RollingFile name="accesslog" fileName="/var/logs/access_log.log"
filePattern="'_'yy_ww'.txt'">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<RollingFile name="todolog" fileName="/var/logs/todo.log"
filePattern="'.'yyyy-MM-dd'.log'" ignoreExceptions="false">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- Special redirections servlet log. Logib online_report servlet'i teated -->
<RollingFile name="redirectlog" fileName="/var/logs/redirect.log"
filePattern="'.'yyyy-MM-dd'.log'" ignoreExceptions="false">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- Asynchronous appender. Writes the log, when it has the time. -->
<Async name="asyncRoot" bufferSize="10" includeLocation="true">
<AppenderRef ref="info"/>
<AppenderRef ref="error" level="error" />
<AppenderRef ref="debug" level="debug" />
</Async>
</Appenders>
<Loggers>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="TIMING" additivity="false" level="info">
<AppenderRef ref="timelog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="TODO" additivity="false" level="info">
<AppenderRef ref="todolog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="ACCESS" additivity="false" level="info">
<AppenderRef ref="accesslog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="REDIRECT" additivity="false" level="info">
<AppenderRef ref="redirectlog"/>
</Logger>
<!-- root logger -->
<Root level="debug">
<AppenderRef ref="asyncRoot"/>
</Root>
</Loggers>
</Configuration>
public class EffencyTests {
private static final Logger log = LogManager.getLogger(EffencyTests.class);
#Before
public void cos() {
log.info("hey");
log.debug("czesc");
log.error("smth");
}
#Test
public void cosata() {
log.info("hey");
log.info("hey");
log.info("hey");
log.info("hey");
log.info("hey");
log.info("hey");
log.debug("hey");
}
#Test
public void cosatae() {
int numberOne = 1;
int numberTwo = 2;
log.info("test");
try {
if(numberOne != numberTwo) {
throw new IllegalArgumentException();
}
}catch (Exception e){
log.error("error");
}
}
here is some output on info log :
error.log and debug.log are empty, i am really stuck for a long time can anyone help me with that ? I am struggling for over month and i feel like there is single letter in config is missing. Looking for any ideas and help thanks
if anyone would struggle it helped at my case :
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="debug">
<Appenders>
<!-- System.out log -->
<Console name="console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
</Console>
<!-- error log -->
<RollingFile name="error" fileName="./logs/errors.log"
filePattern="./logs/${date:yyyy-MM}/errors-%d{yyyy-MM-dd}-%i.log.gz"
filePermissions="rw-rw-r--">
<PatternLayout>
<Pattern>%d{ISO8601} [%t] %-5p %c{1} - %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true"/>
<SizeBasedTriggeringPolicy size="10 MB"/>
</Policies>
</RollingFile>
<!-- info log -->
<RollingFile name="info" fileName="./logs/info.log"
filePattern="./logs/${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log.gz"
filePermissions="rw-rw-r--">
<PatternLayout>
<Pattern>%d{ISO8601} [%t] %-5p %c{1} - %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true"/>
<SizeBasedTriggeringPolicy size="10 MB"/>
</Policies>
<LevelRangeFilter minLevel="info" maxLevel="info" onMatch="accept"/>
</RollingFile>
<!-- debug log -->
<RollingFile name="debug" fileName="./logs/debug.log"
filePattern="./logs/${date:yyyy-MM}/debug-%d{yyyy-MM-dd}-%i.log.gz"
filePermissions="rw-rw-r--">
<PatternLayout>
<Pattern>%d{ISO8601} [%t] %-5p %c{1} - %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true"/>
<SizeBasedTriggeringPolicy size="10 MB"/>
</Policies>
<LevelRangeFilter minLevel="debug" maxLevel="debug" onMatch="accept"/>
</RollingFile>
<!-- Special daily time log. Logib kui palju aega iga Request vytab -->
<RollingFile name="timelog" fileName="./logs/input_timing.log"
filePattern="'.'yyyy-MM-dd'.log'"
filePermissions="rw-rw-r--">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- accesslog log appender -->
<RollingFile name="accesslog" fileName="./logs/access_log.log"
filePattern="'_'yy_ww'.txt'"
filePermissions="rw-rw-r--">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- Special todo jobs log. Logib kõik genereeritud todo sõnumid -->
<RollingFile name="todolog" fileName="./logs/todo.log"
filePattern="'.'yyyy-MM-dd'.log'" ignoreExceptions="false"
filePermissions="rw-rw-r--">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- Special redirections servlet log. Logib online_report servlet'i teated -->
<RollingFile name="redirectlog" fileName="./logs/redirect.log"
filePattern="'.'yyyy-MM-dd'.log'" ignoreExceptions="false"
filePermissions="rw-rw-r--">
<PatternLayout pattern="%d{ISO8601} [%t] %-5p %c{1} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>
<!-- Asynchronous appender. Writes the log, when it has the time. -->
<Async name="asyncRoot" bufferSize="10" includeLocation="true">
<AppenderRef ref="info"/>
<AppenderRef ref="error" level="error"/>
</Async>
</Appenders>
<Loggers>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="TIMING" additivity="false" level="info">
<AppenderRef ref="timelog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="TODO" additivity="false" level="info">
<AppenderRef ref="todolog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="ACCESS" additivity="false" level="info">
<AppenderRef ref="accesslog"/>
</Logger>
<!-- additivity false - do not log to other appenders as defined here -->
<Logger name="REDIRECT" additivity="false" level="info">
<AppenderRef ref="redirectlog"/>
</Logger>
<!-- Level order (low to high): TRACE < DEBUG < INFO < WARN < ERROR < FATAL -->
<Root level="DEBUG" includeLocation="true">
<!--AppenderRef Medium ref Values must be defined earlier appenders-->
<AppenderRef ref="asyncRoot"/>
<!-- <AppenderRef ref="debug" level="debug"/>-->
</Root>
</Loggers>
</Configuration>

Logs are added in old rotated file instead of new file

Below is my log4j2.xml file:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration xmln="http //logging.apache.org/log4j/2.0/config">
<Appenders>
<RollingFile name="File" fileName="${path}/server.log"
filePattern="${path}/server.log.%d{yyyy-MM-dd-HH}-%i">
<PatternLayout>
<Pattern>%d %p %c [%t] %m%n</Pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="1 MB"/>
</Policies>
<DefaultRolloverStrategy fileIndex="nomax" />
</RollingFile>
</Appenders>
<RollingFile name="ExceptionLogs" fileName="${path}/ExceptionLogs.log"
filePattern="${path}/ExceptionLogs.log.%d{yyyy-MM-dd-HH}-%i">
<PatternLayout>
<Pattern>%d %p %c [%t] %m%n</Pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="1 MB"/>
</Policies>
<DefaultRolloverStrategy fileIndex="nomax" />
</RollingFile>
</Appenders>
<Loggers>
<Logger name="com.x.aop.exception">
<AppenderRef ref="ExceptionLogs"/>
</Logger>
<Root level="ERROR">
<AppenderRef ref="File"/>
</Root>
</Loggers>
</Configuration>
Let's say my server started at 3:00 PM and I have 5 log files
server.log
server.log.2022-01-19-15-1 (1 MB)
server.log.2022-01-19-15-2 (1 MB)
server.log.2022-01-19-15-3 (1 MB)
server.log.2022-01-19-15-4 (1 MB)
server.log.2022-01-19-15-5 (1 MB)
Some time it will add in older file created (like server.log.2022-01-19-15-2, server.log.2022-01-19-15-1) instead of latest file
Why logs are added in already rotated file instead of latest highest number log file?

ImmediateFlush not working in Log4j2

I am getting this error:
ERROR asyncRoot contains an invalid element or attribute "immediateFlush"
When I use immediateFlush attribute in appender in log4j2.xml.
<Appenders>
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout pattern="%d{dd-MM-yy HH:mm:ss} [$${ctx:instId} - $${ctx:userId}] %c.%M(%L)- %m%n" />
</Console>
<RollingFile name="csroot"
fileName="${cslogs}/cslog.log" filePattern="${cslogs}/$${date:yyyy-MM}/cslog-%d{yyyy-MM-dd}-%i.log">
<PatternLayout pattern="%d{dd-MM-yy HH:mm:ss} [$${ctx:instId} - $${ctx:userId}] %c.%M(%L)- %m%n" immediateFlush="false"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB" />
</Policies>
<DefaultRolloverStrategy max="1000">
</DefaultRolloverStrategy>
</RollingFile>
</Appenders>
Try with this modification:
<RollingFile name="csroot"
fileName="${cslogs}/cslog.log" filePattern="${cslogs}/$${date:yyyy-MM}/cslog-%d{yyyy-MM-dd}-%i.log" immediateFlush="false">
<PatternLayout pattern="%d{dd-MM-yy HH:mm:ss} [$${ctx:instId} - $${ctx:userId}] %c.%M(%L)- %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB" />
</Policies>
<DefaultRolloverStrategy max="1000">
</DefaultRolloverStrategy>
</RollingFile>
immediateFlush is not an attribute of PatternLayout.
I know its quite an old question but might help somebody.
RollingFile Appender Parameters points out the immediateFlush is the property of the appender. But you have it declared as an attribute for PatternLayout which is what is causing the error.
Sample RollingFile appender configuration:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages="">
<Appenders>
<RollingFile name="RollingFile" fileName="logs/app.log"
filePattern="logs/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz"
immediateFlush="false">
<PatternLayout>
<Pattern>%d %p %c{1.} [%t] %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="250 MB"/>
</Policies>
</RollingFile>
</Appenders>
<Loggers>
<Root level="error">
<AppenderRef ref="RollingFile"/>
</Root>
</Loggers>
</Configuration>

Log4j2 using multiple appender and logger

I need to implement multiple loggers and multiple appenders. My log4j2.xml looks like below:
<Appenders>
<RollingFile name="SYSTEM_LOGGER"
fileName="${logging.folder}System.log"
filePattern="${ARCHIVE}System.log.%d{dd MMM yyyy HH:mm:ss.SSS}.gz">
<PatternLayout>
<Pattern>${PATTERN}</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="10" modulate="true"/>
<SizeBasedTriggeringPolicy size="4 MB" />
<DefaultRolloverStrategy max="50"/>
</Policies>
</RollingFile>
<Appenders>
<RollingFile name="COMMONREQ_LOGGER"
fileName="${logging.folder}/CommonReq.log"
filePattern="${ARCHIVE}/CommonReq.log.%d{dd MMM yyyy HH:mm:ss.SSS}.gz">
<PatternLayout>
<Pattern>${PATTERN}</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="10" modulate="true"/>
<SizeBasedTriggeringPolicy size="4 MB" />
<DefaultRolloverStrategy max="50"/>
</Policies>
</RollingFile>
<Appenders>
<RollingFile name="COMMONRES_LOGGER"
fileName="${logging.folder}/CommonRes.log"
filePattern="${ARCHIVE}/CommonRes.log.%d{dd MMM yyyy HH:mm:ss.SSS}.gz">
<PatternLayout>
<Pattern>${PATTERN}</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="10" modulate="true"/>
<SizeBasedTriggeringPolicy size="4 MB" />
<DefaultRolloverStrategy max="50"/>
</Policies>
</RollingFile>
<Loggers>
<Root level="INFO">
<AppenderRef ref="SYSTEM_LOGGER"/>
<AppenderRef ref="COMMONREQ_LOGGER"/>
<AppenderRef ref="COMMONRES_LOGGER"/>
</Root>
</Loggers>
Now, when I execute the code using this xml, the log is written to the last log file CommonRes.log. I'm new to log4j. How can I write only to the desired log file?
EDIT:
This is what I have done so far in log4j2.xml:
<Routing name="Routing">
<Routes pattern="$${ctx:ROUTINGKEY}">
<Route key="$${ctx:ROUTINGKEY}" >
<RollingFile name="SYSTEM_LOGGER"
fileName="${logging.folder}/$${ctx:ROUTINGKEY}.log"
filePattern="${ARCHIVE}/$${ctx:ROUTINGKEY}.log.%d{dd MMM yyyy HH:mm:ss.SSS}.gz">
<PatternLayout>
<Pattern>${PATTERN}</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="10" modulate="true"/>
<SizeBasedTriggeringPolicy size="4 MB"/>
<DefaultRolloverStrategy max="50"/>
</Policies>
</RollingFile>
</Route>
</Routes>
</Routing>
<Loggers>
<Root level="INFO">
<AppenderRef ref="Routing" />
</Root>
And in my java code:
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
logger = LogManager.getLogger(request.getPathInfo().replace("/", ""));
...
if(logger.getLevel() != null){
ThreadContext.put("ROUTINGKEY", request.getPathInfo().replace("/", ""));
logger.info(contents);
}
}
When I run the above code, it doesn't write to any file, instead gives the following error:
ERROR Unknown object "Routing" of type org.apache.logging.log4j.core.appender.routing.RoutingAppender is ignored.
ERROR Unable to locate appender Routing for logger
Please help.
You can define multiple routes in the configuration, and put values in the ThreadContext map that determine which log file subsequent events in this thread get logged to. THIS LINK is where you can start from.
The basic concept is depending upon values in your threadcontext map, you can route your logs to different files. For example:
<Routing name="Routing">
<Routes pattern="$${ctx:variable}">
<!-- This route is chosen if thread context has no value for key 'variable' -->
<Route key="$${ctx:variable}">
<RollingFile name="Rolling-default" fileName="default.log"
filePattern="./logs/${date:yyyy-MM}/default-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout>
<pattern>%d{ISO8601} [%t] %p %c{3} - %m%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true" />
<SizeBasedTriggeringPolicy size="10 MB" />
</Policies>
</RollingFile>
</Route>
<!-- This route is chosen if thread context has some value for key 'variable' -->
<Route>
<File name="variable-${ctx:variable}" fileName="other.log">
</File>
</Route>
</Routes>
</Routing>
fileName="default.log" and fileName="other.log" is your file path for your respective routes
EDIT: Add one appender only. Depending upon thread context variable it will write to different file
<Loggers>
<Root level="info">
<AppenderRef ref="Routing" />
</Root>
</Loggers>

how to configure log4j2 webapplication

Am little new to web applications, recently I was in need to employ a logging mechanism and for that I choose Log4J2, I went through there guide, and downloaded required libraries. This is what so far I did.
1. Added following jars to web-inf/lib
-- log4j-core2.1.jar
-- log4j-api-2.1.jar
-- log4j-web-2.1.jar
2. Added below xml as, log4j2.xml in java/src directory
<?xml version="1.0" encoding="UTF-8"?>
<configuration name="NONPROD" status="OFF">
<Properties>
<Property name="log-path">logs</Property>
</Properties>
<Appenders>
<Console name="console-log" target="SYSTEM_OUT">
<!-- <pattern>[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n -->
<!-- </pattern> -->
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
</Console>
<RollingFile name="info-log" fileName="${log-path}/web-info.log"
filePattern="${log-path}/web-info-%d{yyyy-MM-dd}.log">
<PatternLayout>
<pattern>[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<OnStartupTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20 MB" />
</Policies>
</RollingFile>
<RollingFile name="error-log" fileName="${log-path}/web-error.log"
filePattern="${log-path}/web-error-%d{yyyy-MM-dd}.log">
<PatternLayout>
<pattern>[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<OnStartupTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20 MB" />
</Policies>
</RollingFile>
<RollingFile name="debug-log" fileName="${log-path}/web-debug.log"
filePattern="${log-path}/web-debug-%d{yyyy-MM-dd}.log">
<PatternLayout>
<pattern>[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<OnStartupTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20 MB" />
</Policies>
</RollingFile>
<RollingFile name="trace-log" fileName="${log-path}/web-trace.log"
filePattern="${log-path}/web-trace-%d{yyyy-MM-dd}.log">
<PatternLayout>
<pattern>[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<OnStartupTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20 MB" />
</Policies>
</RollingFile>
</Appenders>
<Loggers>
<Logger name="com.demo.web.log4j2.file" level="debug"
additivity="false">
<appender-ref ref="trace-log" level="trace" />
<appender-ref ref="error-log" level="error" />
<appender-ref ref="debug-log" level="debug" />
<appender-ref ref="info-log" level="info" />
</Logger>
<Logger name="com.demo.web.log4j2.console" level="all"
additivity="false">
<AppenderRef ref="console-log" />
</Logger>
<Root level="info" additivity="true">
<AppenderRef ref="console-log" />
</Root>
</Loggers>
</configuration>
3. third and last i wrote an small web service to test logging
#Path("/register")
public class Register {
private DataManager mManager;
private static final Logger LOG = LogManager.getLogger(Register.class);
public Register(){
mManager = DataManager.getInstance();
}
#GET
#Path("/{param}")
public Response getMsg(#PathParam("param") String msg) {
LOG.error("Not supported operations");
return Response.status(Response.Status.BAD_REQUEST)
.entity("Not supported").build();
}
But in console, upon trigger get request this is all i got printed.
INFO: Server startup in 35959 ms
Not supported operations // this is not in pattern i supplied in log4j2.xml
// this is my pattern
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
I figure out this is probably due to some thing gone wrong, and am struggling to find the actual cause, being totally new to web programming, please help me out to configure my logger.
Thanks,
Techfist
Your servlet container is using some other logging framework which logs to console. Figure out which logging framework that is and use one of log4j2's bridge libraries to redirect output to your log4j2 setup.
Alright, I found the cause behind this, Issue was primarily happening due to two reasons.
First I was suppose to exclude log4j* pattern from jarsToSkip attribute in catilina property
Second, i had kept two log4j2.xml one inside web-inf other inside java/src, it was supposed to be only present at java/src. two files were not required.
Third, but not mandatory, before deployment just check if log4j2.xml is included inside web-inf/classes or not, if not then simply add it.
that's it, after following this issue was resolved now am getting proper logs.

Categories