Description
On 2013/05/09, at 18:34, Tomek Kaczynski <tomek.kaczynski@gmail.com> wrote:
Hi All,
I'm using log4j2 since beta4, now beta5. In general it's a cute library, but there's some bug that I've found out recently :
When a client code genreates a huge message ( 64k ), the underlying DatagramOutputStream fails ( UDP socket throws exception).
After that all following flushes fail because data buffer is not cleared upon exception.
So in lines
DatagramOutputStream:91
----------------------------------------------------------------------
public synchronized void flush() throws IOException {
if (this.data != null && this.ds != null && this.address != null)
data = null;
}
--------------------------------------------------------------------------
data = null should be put in finally block or some simillar solution could be applied.
What do you think ?
Regards,
Tomek
Moreover DatagramOutputStream should check if message size is less then 64k .
Attachments
Issue Links
- is related to
-
LOG4J2-228 Log4j2 UDP socket configure error. Class not found org.apache.logging.log4j.core.impl.Log4jLogEvent$LogEventProxy
- Resolved