[
https://issues.apache.org/jira/browse/LOG4J2-295?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Remko Popma updated LOG4J2-295:
-------------------------------
Fix Version/s: 2.0-beta8
> BufferOverflowException in FastFileManager when logging huge messages
> ---------------------------------------------------------------------
>
> Key: LOG4J2-295
> URL: https://issues.apache.org/jira/browse/LOG4J2-295
> Project: Log4j 2
> Issue Type: Bug
> Components: Appenders
> Affects Versions: 2.0-beta7
> Reporter: Tom Wieczorek
> Assignee: Remko Popma
> Fix For: 2.0-beta8
>
>
> When logging messages larger than {{FastFileManager.DEFAULT_BUFFER_SIZE}}
> with appenders using {{FastFileManager}}, the logging fails internally with a
> {{BufferOverflowException}} and no log output is produced by these appenders.
> ----
> *Test case*
> {noformat}
> import java.util.Arrays;
> import org.apache.logging.log4j.LogManager;
> public class TestBufferOverflow {
> public static void main(String[] args) {
> final String longMessage;
> {
> char[] chars = new char[384 * 1024];
> Arrays.fill(chars, 'x');
> longMessage = new String(chars);
> }
> LogManager.getLogger("TestBufferOverflow").info(longMessage);
> }
> }
> {noformat}
> ----
> *log4j2.xml*
> {noformat}
> <?xml version="1.0" encoding="UTF-8"?>
> <configuration>
> <appenders>
> <FastFile name="file" fileName="test.log" suppressExceptions="false">
> <PatternLayout>
> <pattern>%m%n</pattern>
> </PatternLayout>
> </FastFile>
> </appenders>
> <loggers>
> <root level="info">
> <appender-ref ref="file" />
> </root>
> </loggers>
> </configuration>
> {noformat}
> ----
> *Exception thrown*
> {noformat}
> Exception in thread "main"
> org.apache.logging.log4j.core.appender.AppenderRuntimeException: An exception
> occurred processing Appender file
> at
> org.apache.logging.log4j.core.appender.DefaultErrorHandler.error(DefaultErrorHandler.java:73)
> at
> org.apache.logging.log4j.core.config.AppenderControl.callAppender(AppenderControl.java:104)
> at
> org.apache.logging.log4j.core.config.LoggerConfig.callAppenders(LoggerConfig.java:424)
> at
> org.apache.logging.log4j.core.config.LoggerConfig.log(LoggerConfig.java:405)
> at
> org.apache.logging.log4j.core.config.LoggerConfig.log(LoggerConfig.java:366)
> at org.apache.logging.log4j.core.Logger.log(Logger.java:110)
> at
> org.apache.logging.log4j.spi.AbstractLogger.info(AbstractLogger.java:1010)
> at TestBufferOverflow.main(TestBufferOverflow.java:16)
> Caused by: java.nio.BufferOverflowException
> at java.nio.HeapByteBuffer.put(HeapByteBuffer.java:165)
> at
> org.apache.logging.log4j.core.appender.FastFileManager.write(FastFileManager.java:89)
> at
> org.apache.logging.log4j.core.appender.OutputStreamManager.write(OutputStreamManager.java:129)
> at
> org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender.append(AbstractOutputStreamAppender.java:113)
> at
> org.apache.logging.log4j.core.appender.FastFileAppender.append(FastFileAppender.java:84)
> at
> org.apache.logging.log4j.core.config.AppenderControl.callAppender(AppenderControl.java:102)
> ... 6 more
> {noformat}
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]