Changes
Release History
Version |
Date |
Description |
2.8.2 |
2017-04-02 |
GA Release 2.8.2 |
2.8.1 |
2017-02-26 |
GA Release 2.8.1 |
2.8 |
2017-01-21 |
GA Release 2.8 |
2.7 |
2016-10-02 |
GA Release 2.7 |
2.6.2 |
2016-07-05 |
GA Release 2.6.2 |
2.6.1 |
2016-06-05 |
GA Release 2.6.1 |
2.6 |
2016-05-25 |
GA Release 2.6 |
2.5 |
2015-12-06 |
GA Release 2.5 |
2.4.1 |
2015-10-08 |
GA Release 2.4.1 |
2.4 |
2015-09-20 |
GA Release 2.4 |
2.3 |
2015-05-09 |
GA Release 2.3 |
2.2 |
2015-02-22 |
GA Release 2.2 |
2.1 |
2014-10-19 |
GA Release 2.1 |
2.0.2 |
2014-08-16 |
Bug fixes and enhancements |
2.0.1 |
2014-07-29 |
Bug fixes |
2.0 |
2014-07-12 |
GA Release |
2.0-rc2 |
2014-06-21 |
Bug fixes and enhancements |
2.0-rc1 |
2014-02-16 |
Bug fixes and enhancements |
2.0-beta9 |
2013-09-14 |
Bug fixes and enhancements |
2.0-beta8 |
2013-07-10 |
Bug fixes and enhancements |
2.0-beta7 |
2013-06-01 |
Bug fixes and enhancements |
2.0-beta6 |
2013-05-05 |
Bug fixes and enhancements |
2.0-beta5 |
2013-04-20 |
Bug fixes and enhancements |
2.0-beta4 |
2013-01-28 |
Bug fixes and enhancements |
2.0-beta3 |
2012-11-11 |
Bug fixes and enhancements |
2.0-beta2 |
2012-10-07 |
Bug fixes and enhancements |
2.0-beta1 |
2012-09-18 |
Bug fixes and enhancements |
2.0-alpha2 |
2012-08-24 |
Bug fixes and minor enhancements |
2.0-alpha1 |
2012-07-29 |
Rewrite of Log4j |
Release 2.8.2 – 2017-04-02
Type |
Changes |
By |
|
Fix JavaDoc on org.apache.logging.log4j.ThreadContext about inheritance. Fixes LOG4J2-1861. |
mattsicker |
|
Fix JavaDoc about @Order and OrderComparator ordering. Fixes LOG4J2-1862. Thanks to wangyuntao. |
mattsicker |
|
Fixed daylight savings time issue with FixedDateFormat. Fixes LOG4J2-1849. |
rpopma |
|
Fix CassandraRule and unit tests on Windows. Fixes LOG4J2-1850. Thanks to Ludovic Hochet. |
mattsicker |
|
Fix typo in %replace converter documentation. Fixes LOG4J2-1840. Thanks to Pradeep Balasundaram. |
mattsicker |
|
Handle when LogEvent.getLoggerName() returns null in LoggerNameLevelRewritePolicy. Fixes LOG4J2-1846. |
mikes |
|
Handle when LogEvent.getLoggerName() returns null in KafkaAppender. Fixes LOG4J2-1845. |
mikes |
|
The default value of RandomAccessFileAppender.Builder append field is wrong. Fixes LOG4J2-1853. Thanks to wangyuntao. |
ggregory |
|
Add support for filtering input in TcpSocketServer and UdpSocketServer. Fixes LOG4J2-1863. |
mattsicker |
|
Add JSON encoding support to EncodingPatternConverter %encode{}. Fixes LOG4J2-1848. |
mattsicker |
|
Add support for appending common suffix to each line of throwable stack trace. Fixes LOG4J2-1843. Thanks to Zilong Song. |
mattsicker |
|
Add support for appending common suffix to each line of extended and root throwable stack trace. Fixes LOG4J2-1838. Thanks to Zilong Song. |
mattsicker |
|
Move integration tests to their own module to speed up build. Fixes LOG4J2-1827. |
rgoers |
|
Fix documentation about the licensing for JeroMQ. Fixes LOG4J2-1835. |
mattsicker |
|
Update the API version to 2.6.0. Fixes LOG4J2-1836. |
rgoers |
|
NullPointerException in HtmlLayout. Fixes LOG4J2-1831. Thanks to Edward Serebrinskiy. |
ggregory |
|
Log4j 2.8 can lose exceptions when a security manager is present. Fixes LOG4J2-1820. Thanks to Jason Tedor. |
ggregory |
|
Update Jackson from 2.8.6 to 2.8.7. Fixes LOG4J2-1856. |
ggregory |
Release 2.8.1 – 2017-02-26
Type |
Changes |
By |
|
Allow %i in file pattern to be preceded with characters other than just '-'. Fixes LOG4J2-1804. Thanks to Pierrick Hymbert. |
rgoers |
|
Update SLF4J to 1.7.24. Fixes LOG4J2-1822. |
rgoers |
|
Improved error message when log4j 2 configuration file not found. Fixes LOG4J2-1812. |
rpopma |
|
Update to use Logback 1.1.10 and then Logback 1.2 for tests. Fixes LOG4J2-1810. |
rgoers |
|
Update Jackson from 2.8.5 to 2.8.6. Fixes LOG4J2-1819. |
ggregory |
|
Fix ClassNotFoundException org.apache.logging.log4j.core.util.ExecutorServices in OSGi tests. Fixes LOG4J2-1753. Thanks to Ludovic Hochet. |
ggregory |
|
Change minOccur to minOccurs in Log4j-config.xsd. Fixes LOG4J2-1816. Thanks to shubhankar1100. |
rpopma |
|
Fix Maven POM to ensure JMH generated classes in log4j-perf are included in benchmarks jar. Fixes LOG4J2-1803. |
rgoers |
|
Report errors when sending to Kafka when using syncSend=false. Fixes LOG4J2-1800. Thanks to Vincent Tieleman. |
mikes |
|
Fixed rare race condition in FixedDateFormat, made FixedDateFormat::millisSinceMidnight method public. Fixes LOG4J2-1805. |
rpopma |
|
Fixed bug in PropertiesUtil::getCharsetProperty that caused UnsupportedCharsetException for ConsoleAppender. Fixes LOG4J2-1799. Thanks to Eduard Gizatullin. |
rpopma |
|
Fix Javadoc for DefaultRolloverStrategy::purgeAscending. Fixes LOG4J2-1806. Thanks to challarao. |
rpopma |
|
Fix rollover to work when filePattern contains no directory components. Fixes LOG4J2-1818. Thanks to xkr47. |
ggregory |
|
Remove deprecation on MessageSupplier lambda functions in Logger API. Fixes LOG4J2-1823. |
mattsicker |
|
[core] Add and implement LogEvent.toImmutable(). Fixes LOG4J2-1807. |
ggregory |
Release 2.8 – 2017-01-21
Type |
Changes |
By |
|
Eliminate the use of the ExecutorServices in the LoggerContext. Fixes LOG4J2-1780. |
mikes |
|
Make DefaultRolloverStrategy more efficient when renaming files. Add nomax option to the fileIndex attribute. Fixes LOG4J2-1032. |
rgoers |
|
RollingFileAppender now supports omitting the file name and writing directly to the archive files. Fixes LOG4J2-1101. |
rgoers |
|
ConfigurationScheduler now preserves interrupt flag during stop. Fixes LOG4J2-1786. |
rpopma |
|
Allow default value in property to be a Lookup. Fixes LOG4J2-1243. |
rgoers |
|
Fixed bug where AsyncLogger did not resolve configuration properties. Fixes LOG4J2-1779. |
rpopma |
|
Fixed concurrency issue affecting all layouts except PatternLayout and GelfLayout, which caused scrambled output and exceptions when logging synchronously from multiple threads. Fixes LOG4J2-1769. Thanks to Brandon Goodin. |
rpopma |
|
Using variables in GelfLayout's additional fields at runtime. Fixes LOG4J2-1724. Thanks to Alexander Krasnostavsky. |
mikes |
|
Add Builder to GelfLayout. Fixes LOG4J2-1762. |
mikes |
|
Insure the ConfigurationScheduler shuts down without blocking. Fixes LOG4J2-1649. Thanks to Georg Friedrich. |
rgoers |
|
CronTriggeringPolicy would use the wrong date/time when rolling over and create multiple triggering policies on reconfiguration. Fixes LOG4J2-1653. Thanks to Georg Friedrich. |
rgoers |
|
Do not use non-daemon thread pool for rollover tasks. Fixes LOG4J2-1748. |
mikes |
|
Fixed file locking regression in FileAppender introduced in 2.6. Fixes LOG4J2-1628. |
rpopma |
|
The custom logger Generate tool no longer requires the log4j-api module on the classpath. Fixes LOG4J2-1744. |
rpopma |
|
SslSocketManager now respects connectTimeoutMillis. Fixes LOG4J2-1731. Thanks to Chris Ribble. |
rpopma |
|
Logger using LocalizedMessageFactory prints key instead of message. Fixes LOG4J2-1682. Thanks to Markus Waidhofer. |
ggregory |
|
Make GelfLayout independent of Jackson. Fixes LOG4J2-1720. |
mikes |
|
Fixed race condition in ObjectMessage and SimpleMessage, ensuring that the log message contains the value the object has during the logging call. Fixes LOG4J2-1719. |
rpopma |
|
Fixed bug where elements of a log message parameter array were nulled out in garbage-free mode. Fixes LOG4J2-1688. |
rpopma |
|
Add putAll() method to CloseableThreadContext. Fixes LOG4J2-1692. Thanks to Greg Thomas. |
mikes |
|
Add CleanableThreadContextMap interface supporting method removeAll(Iterable<String>). Fixes LOG4J2-1689. |
mikes |
|
Option 'disableAnsi' in PatternLayout to unconditionally disable ANSI escape codes. Fixes LOG4J2-1685. Thanks to Raman Gupta. |
mikes |
|
Make TimeFilter usable as global filter and as logger filter. Fixes LOG4J2-1706. |
rpopma |
|
(GC) Avoid allocating temporary objects in VariablesNotEmptyReplacementConverter. Fixes LOG4J2-1722. |
rpopma |
|
(GC) Avoid allocating temporary objects in EncodingPatternConverter. Fixes LOG4J2-1717. |
rpopma |
|
(GC) Avoid allocating temporary objects in MapPatternConverter. (Note that constructing a MapMessage is not garbage-free.). Fixes LOG4J2-1716. |
rpopma |
|
(GC) Avoid allocating temporary objects in MapMessage. Fixes LOG4J2-1683. |
rpopma |
|
(GC) Avoid allocating temporary objects in NdcPatternConverter. (Note that use of the ThreadContext stack is not garbage-free.). Fixes LOG4J2-1715. |
rpopma |
|
(GC) Avoid allocating temporary objects in AbstractStyleNameConverter. Fixes LOG4J2-1714. |
rpopma |
|
(GC) Avoid allocating temporary objects in TimeFilter. Fixes LOG4J2-1680. |
rpopma |
|
(GC) Avoid allocating temporary objects in StructuredDataFilter. Fixes LOG4J2-1679. |
rpopma |
|
(GC) Avoid allocating temporary objects in ThreadContextMapFilter. Fixes LOG4J2-1678. |
rpopma |
|
(GC) Avoid allocating temporary objects in MapFilter. Fixes LOG4J2-1677. |
rpopma |
|
(GC) Avoid allocating temporary objects in ThresholdFilter. Fixes LOG4J2-1674. |
rpopma |
|
(GC) Avoid allocating temporary objects in MarkerFilter. Fixes LOG4J2-1673. |
rpopma |
|
(GC) Avoid allocating temporary objects in LevelRangeFilter. Fixes LOG4J2-1672. |
rpopma |
|
(GC) Avoid allocating temporary objects in EqualsIgnoreCaseReplacementConverter. Fixes LOG4J2-1671. |
rpopma |
|
(GC) Avoid allocating temporary objects in EqualsReplacementConverter. Fixes LOG4J2-1670. |
rpopma |
|
(GC) Avoid allocating temporary objects in MaxLengthConverter. Fixes LOG4J2-1669. |
rpopma |
|
(GC) Avoid allocating temporary objects in MarkerPatternConverter. Fixes LOG4J2-1668. |
rpopma |
|
(GC) Avoid allocating temporary objects in SequenceNumberPatternConverter. Fixes LOG4J2-1667. |
rpopma |
|
(GC) Avoid allocating temporary objects in RelativeTimePatternConverter. Fixes LOG4J2-1666. |
rpopma |
|
(GC) Avoid allocating temporary objects in IntegerPatternConverter. Fixes LOG4J2-1665. |
rpopma |
|
Fixed problems when used in OSGi containers (IllegalAccessError, NoClassDefFoundError). Fixes LOG4J2-1637. |
rpopma |
|
Improve LogEvent serialization to handle non-serializable Messages and deserializing when required classes are missing. Fixes LOG4J2-1226. |
rpopma |
|
Ensure SortedArrayStringMap can be serialized and deserialized without errors regardless of content. Fixes LOG4J2-1663. |
rpopma |
|
Prevent NPE in ThreadContextMapFactory::createThreadContextMap when initializing Log4j with Configurator::initialize and the BasicContextSelector is used. Fixes LOG4J2-1658. |
rpopma |
|
Immutable empty StringMap. Fixes LOG4J2-1645. |
mikes |
|
Configurable JVM shutdown hook timeout. Fixes LOG4J2-1623. |
mikes |
|
Pick up bug fixes from Apache Commons Lang's org.apache.commons.lang3.time package. Fixes LOG4J2-1712. |
ggregory |
|
Console Appender does not pick up Oracle Java 8's sun.stdout.encoding and sun.stderr.encoding. Fixes LOG4J2-1636. Thanks to Eldar Gabdullin. |
ggregory |
|
Fix MemoryMappedFileAppender.createAppender() Javadoc for immediateFlush. Fixes LOG4J2-1639. Thanks to Sridhar Gopinath. |
ggregory |
|
Some LogEvents may not carry a Throwable (Use Message.getThrowable() in log(Message) methods.). Fixes LOG4J2-1676. Thanks to Joern Huxhorn. |
ggregory |
|
Unwanted transitive dependency on geronimo-jms_1.1_spec causes OSGi tests to fail. Fixes LOG4J2-1723. Thanks to Ludovic HOCHET. |
ggregory |
|
Improve OSGi unit tests. Fixes LOG4J2-1664. Thanks to Ludovic HOCHET. |
ggregory |
|
NPE in ThrowableProxy when resolving stack in Java EE/OSGi environment. Fixes LOG4J2-1687. Thanks to Robert Christiansen. |
ggregory |
|
DefaultShutdownCallbackRegistry can throw a NoClassDefFoundError. Fixes LOG4J2-1642. Thanks to Johno Crawford. |
ggregory |
|
CronTriggeringPolicy raise exception and fail to rollover log file when evaluateOnStartup is true. Fixes LOG4J2-1474. Thanks to yin mingjun, Neon. |
ggregory |
|
SslSocketManagerFactory might leak Sockets when certain startup errors occur. Fixes LOG4J2-1734. |
ggregory |
|
TcpSocketManagerFactory might leak Sockets when certain startup errors occur. Fixes LOG4J2-1736. |
ggregory |
|
Add CronTriggeringPolicy programmatically leads to NPE. Fixes LOG4J2-1740. |
ggregory |
|
CompositeConfiguration does not add filters to appenderRefs. Fixes LOG4J2-1743. Thanks to Toby Shepheard. |
ggregory |
|
Adds xmlns in schema and some other tags. Fixes LOG4J2-1756. Thanks to shubhankar1100. |
ggregory |
|
Update Conversant Disruptor from 1.2.7 to 1.2.10. Fixes LOG4J2-1781. |
mattsicker |
|
Replace MockEJB dependency in unit tests with Spring Test and Mockito. Fixes LOG4J2-1774. |
mattsicker |
|
Inefficient locking in AbstractLoggerAdapter. Fixes LOG4J2-1644. Thanks to Tim Gokcen, Pavel Sivolobtchik. |
ggregory |
|
Update JeroMQ from 0.3.5 to 0.3.6. Fixes LOG4J2-1641. |
ggregory |
|
Update Commons Lang from 3.4 to 3.5. Fixes LOG4J2-1647. |
mattsicker |
|
Migrate to Mockito 2.x in unit tests. Fixes LOG4J2-1646. |
mattsicker |
|
Update Jackson from 2.8.3 to 2.8.4. Fixes LOG4J2-1655. |
ggregory |
|
Update Jackson from 2.8.4 to 2.8.5. Fixes LOG4J2-1735. |
ggregory |
|
Update Apache Flume from 1.6.0 to 1.7.0. Fixes LOG4J2-1656. |
ggregory |
|
Update LMAX Disruptor from 3.3.5 to 3.3.6. Fixes LOG4J2-1698. |
ggregory |
|
Update Jansi from 1.13 to 1.14. Fixes LOG4J2-1700. |
ggregory |
|
Update Kafka from 0.10.0.1 to 0.10.1.1. Fixes LOG4J2-1750. |
ggregory |
|
Update liquibase-core from 3.5.1 to 3.5.3. Fixes LOG4J2-1751. |
ggregory |
|
The log4j-slf4j-impl module now declares a runtime dependency on log4j-core. While not technically required, this makes the log4j-slf4j-impl module behave similarly to slf4j-log4j12, and facilitates migration to Log4j 2. Fixes LOG4J2-1302. |
rpopma |
|
Document how to exclude transitive conflicting dependencies in Maven and Gradle. Fixes LOG4J2-1787. |
mattsicker |
|
Add StatusLoggerRule to allow unit tests to set a status level. Fixes LOG4J2-1773. |
mattsicker |
|
Add non-string data type support to JdbcAppender via new ColumnMapping plugin. Fixes LOG4J2-424. |
mattsicker |
|
Add a Builder to ColumnConfig and deprecate ColumnConfig.createColumnConfig(). Fixes LOG4J2-1771. |
mattsicker |
|
Add a Builder to JdbcAppender and deprecate JdbcAppender.createAppender(). Fixes LOG4J2-1770. |
mattsicker |
|
Use MethodHandle in ContextDataFactory cached constructor. Fixes LOG4J2-1764. |
mattsicker |
|
Add Apache Cassandra appender and ColumnMapping plugin. Fixes LOG4J2-1730. |
mattsicker |
|
Add TypeConverter for java.util.UUID. Fixes LOG4J2-1759. |
mattsicker |
|
Add TypeConverter for java.nio.file.Path. Fixes LOG4J2-1758. |
mattsicker |
|
Add TypeConverter and constraint validators for java.net.InetAddress and port numbers. Fixes LOG4J2-1755. |
mattsicker |
|
Refactor SyslogAppender so that Layout is a Plugin element. Fixes LOG4J2-969. |
ggregory |
|
Added public method ThreadContext::getThreadContextMap; removed class ThreadContextAccess. Fixes LOG4J2-1660. |
rpopma |
|
Add documentation regarding YAML configuration format. Fixes LOG4J2-1379. |
mattsicker |
|
Introduce marker interface AsynchronouslyFormattable. Fixes LOG4J2-1718. |
rpopma |
|
Introduce interfaces IndexedStringMap and IndexedReadOnlyStringMap, supporting garbage-free iteration over sorted map. Fixes LOG4J2-1681. |
rpopma |
|
Add a Builder to ScriptPatternSelector and deprecate ScriptPatternSelector.createSelector(). Fixes LOG4J2-1695. |
ggregory |
|
Add a Builder to MarkerPatternSelector and deprecate MarkerPatternSelector.createSelector(). Fixes LOG4J2-1696. |
ggregory |
|
Add a SerializerBuilder to PatternLayout and deprecate PatternLayout.createSerializer(). Fixes LOG4J2-1697. |
ggregory |
|
Add a Builder to RandomAccessFileAppender and deprecate RandomAccessFileAppender.createAppender(). Fixes LOG4J2-1701. |
ggregory |
|
Add a Builder to MemoryMappedFileAppender and deprecate MemoryMappedFileAppender.createAppender(). Fixes LOG4J2-1703. |
ggregory |
|
Add a Builder to RollingRandomAccessFileAppender and deprecate RollingRandomAccessFileAppender.createAppender(). Fixes LOG4J2-1704. |
ggregory |
|
Add a Builder to SyslogAppender and deprecate SyslogAppender.createAppender(). Fixes LOG4J2-1709. |
ggregory |
|
Allow TCP Socket Appender to set socket options. Fixes LOG4J2-1707. |
ggregory |
|
Allow Secure Socket Appender to set socket options. Fixes LOG4J2-1708. |
ggregory |
|
Add a Builder to SyslogLayout and deprecate SyslogLayout.createLayout(Facility, boolean, String, Charset). Fixes LOG4J2-1737. |
ggregory |
|
Add a Builder to JsonLayout and deprecate org.apache.logging.log4j.core.layout.JsonLayout.createLayout(Configuration, boolean, boolean, boolean, boolean, boolean, boolean, String, String, Charset, boolean). Fixes LOG4J2-1738. |
ggregory |
|
Add Builder to KafkaAppender and deprecate KafkaAppender.createAppender(Layout, Filter, String, boolean, String, Property[], Configuration). Fixes LOG4J2-1739. |
ggregory |
|
Add SyncSend attribute to KafkaAppender (as in KafkaLog4jAppender). Fixes LOG4J2-1733. Thanks to Vincent Tieleman. |
ggregory |
Release 2.7 – 2016-10-02
Type |
Changes |
By |
|
Fixed ClassCastException when using JUL logging during shutdown. Fixes LOG4J2-1618. Thanks to Raman Gupta. |
rpopma |
|
2.7-rc1: RollingFileAppender immediateFlush default value should be true, not false. Fixes LOG4J2-1620. Thanks to Sascha Scholz. |
ggregory |
|
Improved performance of context data injector for web applications to be on par with standalone applications. Fixes LOG4J2-1611. |
rpopma |
|
Introduced new interface LifeCycle2 with stop(long,TimeUnit) method to avoid breaking backwards compatibility with new Configurator.shutdown(LoggerContext, long, TimeUnit) API. Fixes LOG4J2-1591. |
rpopma |
|
Fixed issue with filters extending AbstractFilter that did not override methods with unrolled varargs. Fixes LOG4J2-1590. |
rpopma |
|
Fixed scrambled log messages triggered by nested logging from toString() method of a logging parameter object. Fixes LOG4J2-1583. Thanks to Larry West. |
rpopma |
|
Log4j threads are no longer leaking on Tomcat shutdown. Fixes LOG4J2-1259. Thanks to Misagh Moayyed, Steffen Offermann. |
ggregory |
|
When starting on Google App Engine, Interpolator now suppresses the NoClassDefFoundError stack trace for the jvmrunargs lookup. Fixes LOG4J2-1051. Thanks to Lukasz Lenart. |
rpopma |
|
When initializing on platforms where JMX is not available, Interpolator component no longer prints stack trace for warning messages. Fixes LOG4J2-1582. |
rpopma |
|
Unregistering JMX components no longer prints a stack trace when the MBean has already been unregistered. Fixes LOG4J2-1581. |
rpopma |
|
Support Property values to be specified in configuration as a value attribute as well as an element. Fixes LOG4J2-1313. Thanks to Philipp Knobel, Leon Finker. |
rpopma |
|
(GC) LoggerConfig now stores configuration properties in a List, not a Map to prevent creating temporary Iterator objects. Added method LoggerConfig#getPropertyList(), deprecated method #getProperties(). Fixes LOG4J2-1575. |
rpopma |
|
Fixed class loader deadlock when using async logging and extended stack trace pattern. Fixes LOG4J2-1457. Thanks to Leon Finker. |
mattsicker |
|
Fix to prevent Log4j 2.6.2 and higher from losing exceptions when a security manager is present. Fixes LOG4J2-1563. Thanks to Jason Tedor. |
ggregory |
|
Fixed issue where LogEvent.getContextStack() returned null. Fixes LOG4J2-1530. |
mikes |
|
Prevent deadlock in Async Loggers when queue is full and logged Object's toString() logs another message. Fixes LOG4J2-1518. Thanks to Leon Finker. |
rpopma |
|
Prevent ArrayIndexOutOfBoundsException in ParameterizedMessage.formatTo for single-char or empty messages. Fixes LOG4J2-1542. Thanks to Rogério Lecarião Leite. |
rpopma |
|
Fixed issue where AsyncLoggerContextSelector+PropertiesConfigurationBuilder defaulted to includeLocation=true. Fixes LOG4J2-1549. Thanks to Jason Bedard. |
mikes |
|
Prevent SocketAppender memory usage from growing unbounded if it cannot connect to a server. Fixes LOG4J2-1562. |
ggregory |
|
Prevent NPE in Level.isInRange. Fixes LOG4J2-1559. Thanks to Andrey Plotkin. |
ggregory |
|
DynamicThresholdFilter filtered incorrectly when params were passed as individual arguments instead of varargs. Fixes LOG4J2-1511. Thanks to Srikanth Surukuntu. |
ggregory |
|
[CronTriggeringPolicy] ConfigurationScheduler scheduled the task infinitely after first fire. Fixes LOG4J2-1548. |
ggregory |
|
Log4j should not unregister JMX MBeans when log4j2.disable.jmx property is true. Fixes LOG4J2-1506. Thanks to Johannes Schleger. |
ggregory |
|
Log4j2 should postpone creating log file until the appender actually receives an event. Fixes LOG4J2-1490. Thanks to Krzysztof Taborski. |
ggregory |
|
Support loading custom plugins from jar files and directories whose classpath entries use the "vfs" URL protocol. Fixes LOG4J2-1320. Thanks to Paresh Varke, Pierrick Hymbert. |
ggregory |
|
Fix file handle resource leak in XmlConfiguration.XmlConfiguration(ConfigurationSource). Fixes LOG4J2-1541. |
ggregory |
|
Prevent NPE when dynamically removing filters. Fixes LOG4J2-1538. Thanks to Igor Karpov. |
ggregory |
|
Attributes were not merged properly in composite configurations. Fixes LOG4J2-1532. |
ggregory |
|
Attributes were not merged properly in composite configurations. Fixes LOG4J2-1529. Thanks to Sridevi Narra. |
mattsicker |
|
Prevent NPE in RingBufferLogEvent.getFormattedMessage() when used in web applications. Fixes LOG4J2-1527. Thanks to Jose Leon. |
rpopma |
|
Added ability to disable (date) lookup completely for compatibility with other libraries like Camel. Fixes LOG4J2-905. Thanks to Moritz Löser. |
ggregory |
|
Added support for setting StatusLogger destination in ConfigurationBuilder. Fixes LOG4J2-1526. |
mikes |
|
Allow comma separated agents, host list to be passed to FlumeAppender. Fixes LOG4J2-1448. Thanks to Keith Laban. |
rpopma |
|
Merging configurations failed with an NPE when comparing Nodes with different attributes. Fixes LOG4J2-1500. Thanks to Jose Leon. |
ggregory |
|
Fixed improper header in CsvParameterLayout. Fixes LOG4J2-1482. Thanks to Sumit Singhal. |
ggregory |
|
Documented that JVM Input Arguments Lookup (JMX) is not available on Google App Engine. Fixes LOG4J2-1199. |
rpopma |
|
(GC) Added method getParameter() to ObjectMessage (and ReusableObjectMessage). Fixes LOG4J2-1438. |
rpopma |
|
(GC) Fixed ISO8601 %date conversion pattern with a period '.' separator for milliseconds is now garbage free. Fixes LOG4J2-1488. Thanks to Richard Zschech. |
rpopma |
|
(GC) Fixed %date conversion patterns with a timezone parameter are now garbage free. Fixes LOG4J2-1489. Thanks to Richard Zschech. |
rpopma |
|
Prevent NullPointerException in FastDateParser$TimeZoneStrategy. Fixes LOG4J2-1279. Thanks to Tony Baines. |
rpopma |
|
(GC) HighlightConverter and StyleConverter are now GC-free. Fixes LOG4J2-1341. Thanks to Richard Zschech. |
rpopma |
|
[OSGi] Fixed missing import package. Fixes LOG4J2-1467. Thanks to Ralf, Gary Gregory. |
rpopma, ggregory |
|
[OSGi] Fixed wrong Fragment-Host in manifest files. Fixes LOG4J2-351. Thanks to Roland Weiglhofer. |
rpopma, ggregory |
|
Properties declared in configuration can now have their value either in the element body or in an attribute named "value". Fixes LOG4J2-1313. Thanks to Philipp Knobel. |
rpopma |
|
org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy was not working correctly. Fixes LOG4J2-1235. Thanks to Niranjan Rao, Sascha Scholz, Aleksey Zvolinsky. |
ggregory |
|
Fixed issue where CsvParameterLayout and CsvLogEventLayout inserted NUL characters if data starts with {, (, [ or ". Fixes LOG4J2-1502. Thanks to Sumit Singhal. |
ggregory |
|
Layout is no longer optional. Fixes LOG4J2-1573. Thanks to Steffen Offermann. |
ggregory |
|
ServletAppender does not provide throwable object to ServletContext. Fixes LOG4J2-1608. |
ggregory |
|
Prevent potential NPE in org.apache.logging.log4j.message.ParameterFormatter.formatMessage3(StringBuilder, char[], int, Object[], int, int[]). Fixes LOG4J2-1599. |
ggregory |
|
Prevent potential NPE due to org.apache.logging.log4j.core.layout.MarkerPatternSelector.createSelector(PatternMatch[], String, boolean, boolean, Configuration). Fixes LOG4J2-1600. |
ggregory |
|
Prevent potential NPE due to org.apache.logging.log4j.core.layout.ScriptPatternSelector.createSelector(AbstractScript, PatternMatch[], String, boolean, boolean, Configuration). Fixes LOG4J2-1601. |
ggregory |
|
Prevent potential NPE in org.apache.logging.log4j.core.util.datetime.FormatCache.MultipartKey.equals(Object) when object is null. Fixes LOG4J2-1602. |
ggregory |
|
Redo hashCode() and equals() methods in org.apache.logging.log4j.core.net.ssl classes. Fixes LOG4J2-1603. |
ggregory |
|
Add targetNamespace to log4j-config.xsd. GitHub #43. Fixes LOG4J2-1610. Thanks to Shubhankar. |
ggregory |
|
new Log4jLogEvent().toString() throws an NPE. Fixes LOG4J2-1619. |
ggregory |
|
RoutingAppender can be configured with scripts. Add Script in a Routes element. Fixes LOG4J2-1578. |
ggregory |
|
Add a ScriptAppenderSelector to create an Appender specified by a Script. Fixes LOG4J2-1597. |
ggregory |
|
(GC) Added support for garbage-free ThreadContext map. Disabled by default, users need to enable this explicitly. Fixes LOG4J2-1349. |
rpopma |
|
(GC) Changed LogEvent's internal data structure for context data to be garbage-free. Added method LogEvent#getContextData(), deprecated method #getContextMap(). Fixes LOG4J2-1447. |
rpopma |
|
Users can now inject context data from other sources than ThreadContext. Values can be any Object, not just Strings. Fixes LOG4J2-1010. Thanks to Mikael Ståldal. |
rpopma |
|
Added support for java.util.concurrent.LinkedTransferQueue to AsyncAppender. Fixes LOG4J2-1568. |
mattsicker |
|
Added optional support for Conversant DisruptorBlockingQueue in AsyncAppender. Fixes LOG4J2-1430. Thanks to John Cairns. |
mattsicker |
|
Added optional support for JCTools MPSC bounded lock-free queue in AsyncAppender. Fixes LOG4J2-1439. Thanks to Anthony Maire. |
mattsicker |
|
SocketAppender now supports IO buffering. Fixes LOG4J2-1558. |
ggregory |
|
Add a Builder for the SocketAppender (deprecates factory method). Fixes LOG4J2-1557. |
ggregory |
|
Add a Builder to ServletAppender and deprecate factory method. Fixes LOG4J2-1609. |
ggregory |
|
AbstractManager now implements AutoCloseable. Fixes LOG4J2-1553. |
ggregory |
|
Added ability to generate Log4j 2-style XML configuration file from ConfigurationBuilder. Fixes LOG4J2-1528. |
mikes |
|
Added Logging API for Scala 2.10 and 2.11. Fixes LOG4J2-1181. |
mikes |
|
Added options to exclude stack trace from JSON, XML and YAML layouts. Fixes LOG4J2-1512. |
mikes |
|
Added Core API Configurator.shutdown(LoggerContext, long, TimeUnit). Fixes LOG4J2-1539. |
ggregory |
|
FileAppender is now able to create files on-demand. Fixes LOG4J2-1501. |
ggregory |
|
RollingFileAppender is now able to create files on-demand. Fixes LOG4J2-1504. |
ggregory |
|
[PatternLayout] Add an ANSI option to %xThrowable. Fixes LOG4J2-1471. |
ggregory |
|
org.apache.logging.log4j.core.LoggerContext now implements Closeable. Fixes LOG4J2-1472. |
ggregory |
|
[PatternLayout] Add an ANSI option to %message. Fixes LOG4J2-1458. |
ggregory |
|
Create a Builder for the FileAppender plugin to facilitate adding attributes in the future. Fixes LOG4J2-1505. |
ggregory |
|
Allow Builders to be completely generic. Fixes LOG4J2-1507. |
ggregory |
|
Allow a Builder to subclass another Builder. Fixes LOG4J2-1508. |
ggregory |
|
Add ThreadContextMap2 interface supporting method putAll(Map<String, String>). Fixes LOG4J2-1516. Thanks to Gary Gregory. |
rpopma |
|
Add ThreadContext.putAll(Map<String, String>). Fixes LOG4J2-1519. |
ggregory |
|
Add JUnit Rule implementations to manage the thread context. Fixes LOG4J2-1520. |
ggregory |
|
The Core AbstractConfiguration now tracks its LoggerContext and add Configuration.getLoggerContext(). Fixes LOG4J2-1547. |
ggregory |
|
The Core AbstractManager now tracks its LoggerContext. Fixes LOG4J2-1540. |
ggregory |
|
Add a Builder to the RoutingAppender and deprecate factory method. Fixes LOG4J2-1577. |
ggregory |
|
Log4j2 TcpSocketServer in background. Fixes LOG4J2-1604. Thanks to Colin Hillman. |
ggregory |
|
Allow the RollingFileAppender to use default pattern layout. Fixes LOG4J2-1574. |
ggregory |
|
Custom Log4j threads now extend Log4jThread. Fixes LOG4J2-1556. |
ggregory |
|
Improve error messages for TcpSocketServer and UdpSocketServer. Fixes LOG4J2-1605. |
ggregory |
|
Updated Jackson from 2.7.5 to 2.8.0. Fixes LOG4J2-1458. |
ggregory |
|
Updated Jackson from 2.8.0 to 2.8.1. Fixes LOG4J2-1494. |
ggregory |
|
Updated Jackson from 2.8.1 to 2.8.2. Fixes LOG4J2-1569. |
ggregory |
|
Updated Jackson from 2.8.2 to 2.8.3. Fixes LOG4J2-1598. |
ggregory |
|
Updated LMAX Disruptor from 3.3.4 to 3.3.5. Fixes LOG4J2-1495. |
ggregory |
|
Updated Kafka client from 0.9.1.0 to 0.10.0.0. Fixes LOG4J2-1496. |
ggregory |
|
Updated Kafka client from 0.10.0.0 to 0.10.0.1. Fixes LOG4J2-1533. |
ggregory |
|
Updated JMS test from ActiveMQ 5.13.3 to 5.13.4. Fixes LOG4J2-1487. |
ggregory |
|
Updated JMS test from ActiveMQ 5.13.4 to 5.14.0. Fixes LOG4J2-1551. |
ggregory |
|
Update Apache Commons Compress from 1.12 to 1.13. Fixes LOG4J2-1757. |
ggregory |
|
Removed deprecated Core API org.apache.logging.log4j.core.util.Constants.UTF_8. Fixes LOG4J2-1543. |
ggregory |
|
Removed deprecated Core API org.apache.logging.log4j.core.util.Assert.requireNonNull(T, String). Fixes LOG4J2-1544. |
ggregory |
|
Removed deprecated Web API org.apache.logging.log4j.web.WebLookup.getServletContext(). Fixes LOG4J2-1545. |
ggregory |
Release 2.6.2 – 2016-07-05
Type |
Changes |
By |
|
If copy and delete fails in rename action then resort to truncating the source file after copying it. Fixes LOG4J2-904. Thanks to Bernhard Mähr. |
rgoers |
|
CronTriggeringPolicy was not properly setting the prevFileTime value for the PatternProcessor so
file dates and times on rolled files were incorrect. Fixes LOG4J2-1250. |
rgoers |
|
Fixed issue where reusable messages broke flow tracing logic. Fixes LOG4J2-1452. Thanks to Mikael Ståldal. |
rpopma |
|
Fix bug in OnStartupTriggeringPolicy that allowed it to roll over on every reconfiguration. Added
minSize attribute. Fixes LOG4J2-1440. |
rgoers |
|
Fixed minor issues with the 2.6.1 web site. Fixes LOG4J2-1414. Thanks to Ralph Goers. |
rpopma |
|
Ensure that the thread-local StringBuilders used by Layouts to format log events to text will not
retain excessive memory after a large message was logged. Fixes LOG4J2-1434. Thanks to Luke Butters. |
rpopma |
|
Add "direct" option to ConsoleAppender for increased performance. Fixes LOG4J2-1395. |
mikes |
|
Provide MessageFactory2 to custom Logger implementations. Fixes LOG4J2-1418. |
mikes |
|
RollingRandomAccessFileManager was not properly rolling over on startup and was getting a NullPointerException. Fixes LOG4J2-1420. |
rgoers |
|
Fixed issue where Unbox utility ignored the value Constants.ENABLE_THREADLOCALS and always stored non-JDK classes in ThreadLocals. Fixes LOG4J2-1417. |
rpopma |
|
Fixed issue where AsyncAppenderQueueFullPolicyTest sometimes hangs. Fixes LOG4J2-1422. |
rpopma |
|
OnStartupTriggeringPolicyTest fails on Windows saying the file is used by another process. Fixes LOG4J2-1445. Thanks to Ludovic HOCHET. |
ggregory |
|
(GC) ObjectMessage and ReusableObjectMessage now avoid calling toString() on auto-boxed primitive parameters. Fixes LOG4J2-1437. |
rpopma |
|
(GC) ParameterFormatter now avoids calling toString() on auto-boxed primitive message parameters. Fixes LOG4J2-1415. |
rpopma |
|
Unbox utility's ringbuffer of StringBuilders is now configurable. Fixes LOG4J2-1412. |
rpopma |
|
Update Jackson from 2.7.4 to 2.7.5. Fixes LOG4J2-1432. |
ggregory |
|
Update Jansi from 1.11 to 1.13. Fixes LOG4J2-1433. |
ggregory |
|
Update Apache Commons Compress from 1.11 to 1.12. Fixes LOG4J2-1444. |
ggregory |
Release 2.6.1 – 2016-06-05
Type |
Changes |
By |
|
OnStartupTriggeringPolicy was forcing a rollover of empty files at startup and would append a second footer that was added by the prior shutdown. Fixes LOG4J2-1405. |
rgoers |
|
Fixed bug in ReusableParameterizedMessage where Throwable was never updated so first error was logged over and over again and subsequent errors were not logged. Fixes LOG4J2-1406. Thanks to Trask Stalnaker. |
rpopma |
|
Fixed ArrayIndexOutOfBoundsException that may occur in ReusableParameterizedMessage. Fixes LOG4J2-1409. Thanks to Shahan. |
rpopma |
|
Add filter and remove filter were not working properly in AbstractFilterable. Fixes LOG4J2-997. Thanks to Maytee Chinavanichkit. |
rgoers |
|
Changed RenameAction to use java.nio to better report rename failures. Fixes LOG4J2-1032. |
rgoers |
|
Fixed misleading WARN log events from Log4j about message factories and unexpected formatting. Fixes LOG4J2-1407. |
ggregory |
|
Added the module log4j-liquibase to BOM POM. Fixes LOG4J2-1408. |
ggregory |
|
Logger cache now accounts for message factory. Fixes LOG4J2-1180. |
ggregory |
|
Fix regression in properties configuration to support arbitrary component ids. Fixes LOG4J2-1402. |
rgoers |
|
(GC) CSV layouts should not create a new CSVPrinter for each log event. Requires Apache Commons CSV 1.4. Fixes LOG4J2-1385. |
ggregory |
|
Update liquibase-core from 3.4.2 to 3.5.1. Fixes LOG4J2-1398. |
ggregory |
|
Update Apache Commons CSV from 1.3 to 1.4. Fixes LOG4J2-1399. |
ggregory |
|
Added documentation about plugin builders compared to factories. Fixes LOG4J2-1411. |
mattsicker |
|
Fixed minor issues with the 2.6 web site. Fixes LOG4J2-1394. |
mattsicker,mikes |
Release 2.6 – 2016-05-25
Type |
Changes |
By |
|
(GC) Added support for garbage-free logging in steady state.
This includes Async Loggers and logging synchronously to the console and to a file,
but does not include the AsyncAppender. This release makes the GelfLayout and
the main patterns in the PatternLayout garbage-free. Fixes LOG4J2-1270. |
rpopma |
|
(GC) Added manual page on garbage-free logging. Fixes LOG4J2-1297. |
rpopma |
|
(GC) Update Logger wrapper Generator tool to generate methods for the new Logger methods. Fixes LOG4J2-1373. |
rpopma |
|
(GC) GelfLayout does now support garbage-free logging (with compressionType=OFF). Fixes LOG4J2-1356. |
mikes |
|
(GC) Added methods to the Logger interface for logging CharSequence messages. Fixes LOG4J2-1326. |
rpopma |
|
(GC) FileAppender, RollingFileAppender and MemoryMappedFileAppender are now also garbage-free by default. Fixes LOG4J2-1344. |
rpopma |
|
(GC) ConsoleAppender is now garbage-free by default. This logic is reusable for all AbstractOutputStreamAppender subclasses. Fixes LOG4J2-1343. |
rpopma |
|
(GC) Added unrolled varargs methods to Logger API, added Unbox utility to avoid auto-boxing when logging primitive values. Fixes LOG4J2-1278. |
rpopma |
|
(GC) Avoid allocating unnecessary temporary objects in LoggerContext's getLogger methods. Fixes LOG4J2-1318. |
rpopma |
|
(GC) Avoid allocating unnecessary temporary objects in MarkerManager's getMarker methods. Fixes LOG4J2-1333. |
rpopma |
|
(GC) Avoid allocating unnecessary temporary objects in PatternLayout's NamePatternConverter and ClassNamePatternConverter. Fixes LOG4J2-1321. |
rpopma |
|
(GC) Add MessageFactory that avoid allocation by reusing a cached ParameterizedMessage instance. Fixes LOG4J2-1271. |
rpopma |
|
(GC) ParameterizedMessage optimizations to avoid or at least postpone allocating temporary objects. Fixes LOG4J2-1271. |
rpopma |
|
(GC) Provide ThreadLocal-based gc-free caching mechanism in DatePatternConverter for non-webapps. Fixes LOG4J2-1283. |
rpopma |
|
(GC) Add interface StringBuilderFormattable to enable converting Messages and parameters to text without allocating temporary objects.
ParameterizedMessage, ObjectMessage, SimpleMessage and ThreadDumpMessage now implement StringBuilderFormattable. Fixes LOG4J2-1293. |
rpopma |
|
(GC) Update PatternLayout to utilize gc-free mechanism for LogEvent processing. Fixes LOG4J2-1291. |
rpopma |
|
(GC) Update RandomAccessFileAppender and RollingRandomAccessFileAppender to utilize gc-free Layout.encode() method. Fixes LOG4J2-1292. |
rpopma |
|
(GC) Add encode(LogEvent, ByteBufferDestination) method to Layout API to enable converting LogEvents to bytes without creating temporary objects. Fixes LOG4J2-1274. |
rpopma |
|
(GC) LoggerConfig.getProperties() should not allocate on each call. Fixes LOG4J2-1281. |
rpopma |
|
(GC) Improve LoggerConfig's data structure for AppenderControl objects to avoid allocating temporary objects during
traversal for each log event. Fixes LOG4J2-1272. |
rpopma |
|
(GC) AsyncLogger should use thread-local translator by default. Fixes LOG4J2-1269. |
rpopma |
|
Generate MDC properties as a JSON map in JSONLayout, with option to output as list of map entries. Fixes LOG4J2-623. |
rpopma |
|
Added a YAML layout. Fixes LOG4J2-1362. Thanks to Gary Gregory. |
rpopma |
|
Fixed memory leak related to shutdown hook. Fixes LOG4J2-1387. |
rpopma |
|
Documented benchmark results comparing Log4j 2 performance to other logging libraries. Fixes LOG4J2-1179. |
rpopma |
|
Copying a MutableLogEvent using Log4jLogEvent.Builder should not unnecessarily obtain caller location information. Fixes LOG4J2-1382. |
rpopma |
|
Document dependencies for layouts. Fixes LOG4J2-1011. |
mikes |
|
Pattern to drop first N package parts. Fixes LOG4J2-621. Thanks to Lee Theobald, Kamal Mettananda, Gary Gregory. |
ggregory |
|
Support merging configurations to for a composite configuration. Fixes LOG4J2-494. Thanks to Philipp Knobel. |
rgoers |
|
Option to not log stack traces for logged Throwables in GelfLayout. Fixes LOG4J2-1357. |
mikes |
|
Update SLF4J from 1.7.13 to 1.7.21. Fixes LOG4J2-1375. |
rpopma |
|
Migrate tests from Logback 1.1.3 to 1.1.7. Fixes LOG4J2-1374. |
rpopma |
|
Update Apache Commons CSV from 1.2 to 1.3. Fixes LOG4J2-1384. |
ggregory |
|
XMLLayout indents, but not the first child tag (Event). Fixes LOG4J2-1372. Thanks to Kamal Mettananda, Gary Gregory. |
rgoers |
|
Properties Configuration did not support includeLocation attribute on Loggers. Fixes LOG4J2-1363. |
rgoers |
|
The ConfigurationSource was not saved for BuiltConfigurations so monitor interval had no effect. Fixes LOG4J2-1263. |
rgoers |
|
"xz" compression results in plaintext, uncompressed files. Fixes LOG4J2-1369. Thanks to Alex Birch, Gary Gregory. |
ggregory |
|
(Log4j-internal) Provide message text as CharSequence for some message types to optimize some layouts. Fixes LOG4J2-1365. |
mikes |
|
(Log4j-internal) StatusLogger dropped exceptions when logging parameterized messages. Fixes LOG4J2-1368. |
rpopma |
|
Add an AutoCloseable ThreadContext class: CloseableThreadContext. Fixes LOG4J2-1348. Thanks to Greg Thomas, Gary Gregory. |
ggregory |
|
(Doc) Clarify documentation for properties that control Log4j behaviour. Fixes LOG4J2-1345. |
rpopma |
|
LoggerFactory in 1.2 API module is not compatible with 1.2. Fixes LOG4J2-1336. Thanks to Zbynek Vyskovsky. |
ggregory |
|
No configuration reload is triggered under Windows when replacing the configuration file with one that has older last modified date. Fixes LOG4J2-1354. Thanks to Arkadiusz Adolph. |
ggregory |
|
Exception from Log4jServletContextListener prevents jetty-maven-plugin run-forked. Fixes LOG4J2-1346. |
|
|
(Perf) AsyncLogger performance optimization: avoid calling instanceof TimestampMessage in hot path. Fixes LOG4J2-1339. |
rpopma |
|
Improve error handling in the Async Logger background thread: the new default exception handler no longer rethrows the error. Fixes LOG4J2-1324. |
rpopma |
|
Configuration file error does not show cause exception. Fixes LOG4J2-1309. |
ggregory |
|
Add pattern converter for thread id and priority in PatternLayout. Fixes LOG4J2-1299. |
ggregory |
|
Change flow logging text from "entry' to "Enter" and "exit" to "Exit". Fixes LOG4J2-1289. |
ggregory |
|
Made default MessageFactory configurable. Fixes LOG4J2-1284. |
rpopma |
|
Deprecate org.apache.logging.log4j.util.MessageSupplier. Fixes LOG4J2-1280. |
ggregory |
|
Logger methods taking Supplier parameters now correctly handle cases where the supplied value is a Message. Fixes LOG4J2-1280. |
rpopma |
|
FixedDateFormat was incorrect for formats having MMM with the French locale. Fixes LOG4J2-1268. |
rpopma |
|
Add enhanced entry and exit methods. Fixes LOG4J2-1255. |
rgoers |
|
Add shutdown methods to LogManager. Fixes LOG4J2-124. |
rgoers |
|
Creation of a LoggerContext will fail if shutdown is in progress. LogManager will default to SimpleLogger instead. Fixes LOG4J2-1222. |
rgoers |
|
Added async logger Timeout wait strategy and made this the default wait strategy for async loggers.
This prevents a rare deadlock that may occur on Solaris. Fixes LOG4J2-1221. Thanks to Michael Barker. |
rpopma |
|
Added option to discard events below a certain log level if the async logger ring buffer
or async appender queue is full. Fixes LOG4J2-1080. |
rpopma |
|
Make PatternLayout header and footer accept a pattern. Fixes LOG4J2-1237. Thanks to Mike Calmus, Gary Gregory. |
ggregory |
|
Make header and footer values customizable in JSONLayout. Fixes LOG4J2-1244. Thanks to Anshu Garg, Remko Popma, Gary Gregory. |
ggregory |
|
Make CSV Layout header and footers accept patterns. Fixes LOG4J2-1245. |
ggregory |
|
Dynamic Subject for SMTP Appender. Fixes LOG4J2-1192. Thanks to Jörg Bretschneider, Gary Gregory. |
ggregory |
|
FormattedMessage, MessageFormatMessage and StringFormattedMessage should support passing in a Locale to ensure appropriate formatting. Fixes LOG4J2-1277. Thanks to Gary Gregory, Ludovic Hochet. |
ggregory |
|
TlsSyslogFrame calculates message length incorrectly. Fixes LOG4J2-1260. Thanks to Blake Day, Gary Gregory. |
ggregory |
|
Async DynamicThresholdFilter does not use the log event's context map. Fixes LOG4J2-1258. Thanks to Francis Lalonde. |
ggregory |
|
Incorrect log rotation in last week of year. Fixes LOG4J2-1232. Thanks to Nikolai. |
ggregory |
|
Fixed broken nanotime in pattern layout. Fixes LOG4J2-1248. |
rpopma |
|
JSONLayout doesn't add a comma between log events. Fixes LOG4J2-908. Thanks to Konstantinos Liakos, Patrick Flaherty, Robin Coe, Gary Gregory. |
ggregory |
|
Don't concatenate SYSLOG Messages. Fixes LOG4J2-1230. Thanks to Vladimir Hudec, Ralph Goers, Gary Gregory. |
ggregory |
|
org.apache.logging.log4j.core.net.TcpSocketManager and other classes does not report internal exceptions to the status logger. Fixes LOG4J2-1238. |
ggregory |
|
Fix documentation to specify the correct default wait strategy used by async loggers. Fixes LOG4J2-1212. |
rpopma |
|
Documentation/XSD inconsistencies. Fixes LOG4J2-1215. Thanks to Erik Kemperman. |
ggregory |
|
LoggerMessageSupplierTest and LoggerSupplierTest are Locale sensitive. Fixes LOG4J2-1276. Thanks to Ludovic Hochet. |
ggregory |
|
Update Jackson from 2.7.3 to 2.7.4. Fixes LOG4J2-1380. |
ggregory |
|
Update Jackson from 2.7.0 to 2.7.2. Fixes LOG4J2-1304. |
ggregory |
|
Update LMAX Disruptor from 3.3.2 to 3.3.4. Fixes LOG4J2-1253. |
ggregory |
|
Update SLF4J from 1.7.12 to 1.7.13. Fixes LOG4J2-1219. |
ggregory |
|
Update Jackson from 2.6.3 to 2.6.4. Fixes LOG4J2-1239. |
ggregory |
|
Update Jackson from 2.6.4 to 2.7.0. Fixes LOG4J2-1249. |
ggregory |
|
Update Jackson from 2.7.2 to 2.7.3. Fixes LOG4J2-1351. |
ggregory |
|
Update Liquibase from 3.3.5 to 3.4.2. Fixes LOG4J2-1240. |
ggregory |
|
Update Kafka client from 0.9.0.0 to 0.9.0.1. Fixes LOG4J2-1294. |
ggregory |
|
Update javax.mail from 1.5.4 to 1.5.5. Fixes LOG4J2-1352. |
ggregory |
|
Update Apache Commons Compress from 1.10 to 1.11. Fixes LOG4J2-1358. |
ggregory |
|
Update Google java-allocation-instrumenter from 3.0 to 3.0.1. Fixes LOG4J2-1388. |
rpopma |
|
Misleading Value In Properties Example. Fixes LOG4J2-1233. Thanks to Bahri Gencsoy. |
ggregory |
|
Fix JUL bridge issue where LogRecord.getParameters() is used when null. Fixes LOG4J2-1251. Thanks to Romain Manni-Bucau. |
mattsicker |
|
Fix typo in Flow Tracing documentation. Fixes LOG4J2-1254. Thanks to Josh Trow. |
rpopma |
|
ClassNotFoundException for BundleContextSelector when initialising in an OSGi environment. Fixes LOG4J2-920. Thanks to Ludovic Hochet. |
mattsicker |
|
Remove serializability from classes that don't need it. Fixes LOG4J2-1300. |
mattsicker |
|
Add documentation links to runtime dependencies in each component intro page. Fixes LOG4J2-1303. |
mattsicker |
|
Fix RollingAppenderNoUnconditionalDeleteTest repeat test runs from failing. Fixes LOG4J2-1275. Thanks to Ludovic Hochet. |
mattsicker |
|
Stop throwing unnecessary exception in Log4jServletContextListener.contextDestroyed(). Fixes LOG4J2-1262. |
mattsicker |
|
JeroMqAppender should support layouts. Fixes LOG4J2-1252. |
mattsicker |
|
NullPointerException in MapLookup.lookup if the event is null. Fixes LOG4J2-1227. Thanks to Olivier Lemasle. |
mattsicker |
|
JeroMqAppender should use ShutdownCallbackRegistry instead of runtime hooks. Fixes LOG4J2-1306. |
mattsicker |
|
PatternLayout option to limit length of text. Fixes LOG4J2-1217. Thanks to Thies Wellpott. |
mattsicker |
|
Remove need to pre-specify appender et al. identifiers in property file config format. Fixes LOG4J2-1308. |
mattsicker |
|
Add a Log4jLookup class to help write log files relative to log4j2.xml. Fixes LOG4J2-1050. Thanks to Adam Retter. |
mattsicker |
|
Add JNDI lookup documentation. Fixes LOG4J2-1133. |
mattsicker |
|
JndiLookup mindlessly casts to String and should use String.valueOf(). Fixes LOG4J2-1310. |
mattsicker |
|
org.apache.logging.log4j.core.LoggerContext#updateLoggers should call firePropertyChangeEvent. Fixes LOG4J2-1206. |
mattsicker |
|
Log4jWebInitializerImpl: Use Thread instead of Class for fallback classloader. Fixes LOG4J2-248. |
mattsicker |
|
PatternLayout: Possible variable substitution in equals substitution parameter. Fixes LOG4J2-1169. Thanks to Gerald Kritzinger. |
mattsicker |
|
Update Log4j 1.x migration guide to include information about system property lookup syntax changes. Fixes LOG4J2-1322. |
mattsicker |
|
Fix NoClassDefFoundError in ReflectionUtil on Google App Engine. Fixes LOG4J2-1330. |
mattsicker |
Release 2.5 – 2015-12-06
Type |
Changes |
By |
|
Reduced memory usage of status messages in bounded queue; support zero-length queue that stores no messages. Fixes LOG4J2-324. |
rpopma |
|
Fixed rollover error when copying to a directory mapped to a remote Linux host. Fixes LOG4J2-1173. |
rpopma |
|
Added support for custom delete actions triggered by a rollover. Fixes LOG4J2-435. Thanks to Robert Schaft. |
rpopma |
|
Add PurgePolicy and IdlePurgePolicy to RoutingAppender. Fixes LOG4J2-649. Thanks to Aleksey Zvolinsky. |
rgoers |
|
Remove ConfigurationMonitor. The WatchManager is now used to check for configuration changes. Fixes LOG4J2-1202. |
rgoers |
|
Make KafkaAppender support SerializedLayout. Fixes LOG4J2-1195. Thanks to Melvin Du. |
mikes |
|
Allow rollover to occur at any time. Add CronTriggeringPolicy. Fixes LOG4J2-89. |
rgoers |
|
Allow triggering policy and rollover strategy to be modified during reconfiguration. Fixes LOG4J2-381. Thanks to Anthony Baldocchi. |
rgoers |
|
Add support for JSR 223 scripts in filters and the PatternSelector. Fixes LOG4J2-1136. |
rgoers |
|
Add getters for source and destination file in file rename action. Fixes LOG4J2-1168. Thanks to Steven Swor. |
ggregory |
|
Add getters for classes in org.apache.logging.log4j.core.appender.rolling.action. Fixes LOG4J2-1175. |
ggregory |
|
Added system property to allow users to control whether messages should be formatted in the background. Fixes LOG4J2-898. |
rpopma |
|
Support use-case for JDBC's CommonDataSource.setLogWriter(PrintWriter) and java.sql.DriverManager.setLogWriter(PrintWriter). Fixes LOG4J2-1178. |
ggregory |
|
Support use case for java.sql.DriverManager.setLogStream(PrintStream). Fixes LOG4J2-1187. |
ggregory |
|
Performance improvement when gathering location information. Fixes LOG4J2-1029. Thanks to Stefan Leonhartsberger. |
rpopma |
|
Fixed ThreadLocal leak [AsyncLogger$Info] on Tomcat when using AsyncLoggerContextSelector. Fixes LOG4J2-1172. |
rpopma |
|
Fixed memory leak when log4j jars are in Tomcat's lib folder. Fixes LOG4J2-1176. |
rpopma |
|
Logger cache does not account for message factory. Fixes LOG4J2-1180. Thanks to Mikael Ståldal. |
ggregory |
|
Documentation: fixed minor issues with the site and manual pages. Fixes LOG4J2-879. |
rpopma |
|
RollingFileAppender should also roll over when log event time is equal to rollover time, not only when later. Fixes LOG4J2-999. Thanks to Joan Balagueró. |
rpopma |
|
Fixed bug where omitting the <display-name> element in web.xml caused incorrect log4j initialization,
resulting in memory leaks when the web application was stopped or reloaded. Fixes LOG4J2-873. Thanks to Martin Dickins, LC, Luke Woodward. |
rpopma |
|
Better web app support for async loggers: Fixed a memory leak that occurred when the logging jars are placed
in the container's classpath and the configuration file uses AsyncRoot/AsyncLogger.
The problem was that the first web application started the Disruptor background thread [AsyncLoggerConfig-1] but did not stop it until all web apps are stopped.
Each web application now has its own Disruptor which is stopped/started together with the web app. Fixes LOG4J2-323. |
rpopma |
|
Better web app support for async loggers: it is now possible to place the logging jars in the container's
classpath when making all loggers asynchronous by using AsyncLoggerContextSelector. This fixes a problem where
logging would stop working after stopping and restarting a web application. Fixes LOG4J2-493. |
rpopma |
|
Use servlet context name for logger context name when available. Fixes LOG4J2-1171. |
rpopma |
|
Fixed a ThreadLocal memory leak in Tomcat8 that mentions AsyncLoggers when Async Loggers are not used. Fixes LOG4J2-1159. |
rpopma |
|
AbstractConfiguration executor should use a DaemonThreadFactory. Fixes LOG4J2-1166. |
rpopma |
|
Improve Log4j initialization status messages. Fixes LOG4J2-1165. |
rpopma |
|
Web site corrections and updates. Fixes LOG4J2-1156. |
rpopma |
|
Log4J JUL adapter is using MessageFormat on String passed by java.util.function.Supplier<String>. Fixes LOG4J2-1158. Thanks to Michael Fortin, Gary Gregory. |
ggregory |
|
org.apache.logging.log4j.core.Logger should be serializable. Fixes LOG4J2-801. |
mattsicker |
|
Fix compilation error for classes annotated with @Plugin. Fixes LOG4J2-1157. Thanks to Norbert Bartels. |
mattsicker |
|
Fix plugin documentation error about Converters. Fixes LOG4J2-948. Thanks to Andrew Flower. |
mattsicker |
|
Prefix all thread names Log4j creates with "Log4j2-". Fixes LOG4J2-1193. |
ggregory |
|
Documentation does not match parameters for LoggerNameLevelRewritePolicy. Fixes LOG4J2-1194. Thanks to Adam Brin. |
ggregory |
|
MongoDbConnection does not close MongoClient. Fixes LOG4J2-1196. Thanks to René Zanner. |
mattsicker |
|
Update Jackson from 2.6.2 to 2.6.3. Fixes LOG4J2-1174. |
ggregory |
|
Update kafka-clients from 0.8.2.2 to 0.9.0.0. Fixes LOG4J2-1207. |
ggregory |
Release 2.4.1 – 2015-10-08
Type |
Changes |
By |
|
Allow PatternLayout to select a pattern to use based on some selection criteria. Fixes LOG4J2-1129. |
rgoers |
|
Add %equals to PatternLayout to test and replace patterns with strings. Fixes LOG4J2-1145. |
ggregory |
|
Add %equalsIgnoreCase to PatternLayout to test and replace patterns with strings. Fixes LOG4J2-1147. |
ggregory |
|
Add %notEmpty to PatternLayout to avoid output of patterns where all variables are empty. Fixes LOG4J2-1146. |
ggregory |
|
Add possibility to set shutdown timeout on AsyncAppender. Fixes LOG4J2-1020. |
mikes |
|
Fixed NullPointerException when only root logger is defined (and no named loggers) in configuration properties file. Fixes LOG4J2-1153. |
rpopma |
|
Fixed bug where headers were not being written to first file with RollingFileAppender. Fixes LOG4J2-1140. |
rpopma |
|
Fixed bug where PatternLayout predefined date pattern with time zone always renders default date format. Fixes LOG4J2-1149. |
rpopma |
|
Fixed Log4jLookup. Fixes LOG4J2-1050. |
rpopma |
|
Fix potential memory leak in web applications by using a straight ThreadLocal field instead of subclassing ThreadLocal. Fixes LOG4J2-1142. |
rpopma |
|
Compression on rollover was broken: log file was renamed to .zip but not compressed. Fixes LOG4J2-1135. |
rpopma |
|
log4j2.xml cannot be parsed on Oracle Weblogic 12c. Fixes LOG4J2-1127. |
ggregory |
|
Do not use MongoDB driver 2.13.3 deprecated methods. Fixes LOG4J2-1132. |
ggregory |
|
Add %markerSimpleName in pattern layout should evaluate to marker name (not toString()). Fixes LOG4J2-1144. |
ggregory |
|
Web site corrections and updates. Fixes LOG4J2-1126. |
ggregory |
|
Performance improvement: backport Java 8 fast ISO-8859-1 String to byte[] encoder to AbstractStringLayout. Fixes LOG4J2-1151. |
rpopma |
|
Performance improvement when converting Strings to byte[] arrays. Fixes LOG4J2-935. |
rpopma |
|
Update MongoDB driver from 2.13.3 to 3.0.4. Fixes LOG4J2-1040. |
ggregory |
|
Reuse StringBuilder to improve performance for String-based layouts: CSV, GELF, HTML, RFC524, Syslog. Fixes LOG4J2-1128. |
ggregory |
|
Update mongo-java-driver from 2.13.2 to 2.13.3. Fixes LOG4J2-1131. |
ggregory |
|
Do not use Jackson deprecated methods. Fixes LOG4J2-1138. |
ggregory |
|
Update Jackson from 2.6.1 to 2.6.2. Fixes LOG4J2-1139. |
ggregory |
|
Update kafka-clients from 0.8.2.1 to 0.8.2.2. Fixes LOG4J2-1150. |
ggregory |
Release 2.4 – 2015-09-20
Type |
Changes |
By |
|
Add support for configuration via Properties. Fixes LOG4J2-635. |
rgoers |
|
Add ConfigurationBuilder for programmatic configuration. Fixes LOG4J2-952. |
rgoers |
|
Update Java platform from Java 6 to 7. From this version onwards, log4j 2 requires Java 7. Fixes LOG4J2-1017. |
ggregory |
|
Added support for Java 8 lambda expressions to lazily construct a log message only if
the requested log level is enabled. Fixes LOG4J2-599. |
rpopma |
|
Updated Logger wrapper generator tool to add Java 8 lambda support for custom log levels. Fixes LOG4J2-1118. |
rpopma |
|
New Appender for Apache Kafka. Fixes LOG4J2-1107. Thanks to Mikael Ståldal. |
ggregory |
|
New publisher Appender for ZeroMQ (using JeroMQ). Fixes LOG4J2-1113. Thanks to Gary Gregory. |
ggregory |
|
Add Comma Separated Value (CSV) layouts for parameter and event logging. Fixes LOG4J2-1088. Thanks to Gary Gregory. |
ggregory |
|
PatternLayout timestamp formatting performance improvement: replaced synchronized SimpleDateFormat with
Apache Commons FastDateFormat. This and better caching resulted in a ~3-30X faster timestamp formatting. Fixes LOG4J2-812. |
rgoers |
|
PatternLayout timestamp formatting performance improvement: predefined date formats (and variants using
a period '.' millisecond separator instead of ',') are now formatted ~2-10X faster than other date formats. Fixes LOG4J2-1097. |
rpopma |
|
Improved performance of ParameterizedMessage::getFormattedMessage by ~2X. Fixes LOG4J2-1096. |
rpopma |
|
LoggerConfig performance improvements: avoid unnecessary lock acquisition, use more efficient data structure. Fixes LOG4J2-1120. |
rpopma |
|
PatternLayout performance improvement by caching and reusing a ThreadLocal StringBuilder. Fixes LOG4J2-1125. |
rpopma |
|
Fixed potential race condition on reconfiguration. Introduced ReliabilityStrategy to facilitate
switching between different mechanisms for preventing log events from being dropped on reconfiguration. Fixes LOG4J2-1121. |
rpopma |
|
Add thread name to status logger layout. Fixes LOG4J2-1114. |
ggregory |
|
Core Configurator.initialize(String, ClassLoader, String) fails to work when config location is a file path. Fixes LOG4J2-1123. |
ggregory |
|
OutputStreamManager in ConsoleAppender leaking managers. Fixes LOG4J2-1117. Thanks to Marcus Thiesen. |
ggregory |
|
Write pending events to Flume when the appender is stopped. Fixes LOG4J2-1044. |
rgoers |
|
NullPointerException when passing null to java.util.logging.Logger.setLevel(). Fixes LOG4J2-1108. Thanks to Mikael Ståldal. |
ggregory |
|
org.apache.logging.log4j.jul.CoreLogger.setLevel() checks for security permission too late. Fixes LOG4J2-1110. |
ggregory |
|
Removed experimental interface LevelLogger which got committed to master by mistake. |
rpopma |
|
Pass log event when interpolating logger properties. Fixes LOG4J2-1010. |
rgoers |
|
Add Core Configurator APIs to change a logger's level. Fixes LOG4J2-1090. |
ggregory |
|
Add API org.apache.logging.log4j.Level.isInRange(Level, Level). Fixes LOG4J2-1105. Thanks to Gary Gregory. |
ggregory |
|
Add a LevelRangeFilter class. Fixes LOG4J2-1106. Thanks to Gary Gregory. |
ggregory |
|
Added support for system nanosecond time in pattern layout. Fixes LOG4J2-1074. |
rpopma |
|
Added support for compressing to bzip2 format on file rollover. Fixes LOG4J2-1075. |
rpopma |
|
Support additional Apache Commons Compress compression formats on rollover: Deflate, Pack200, XY. Fixes LOG4J2-1077. |
ggregory |
|
New module for Liquibase integration. Fixes LOG4J2-767. Thanks to Mikael Ståldal. |
ggregory |
|
New RewritePolicy for changing level of a log event. Fixes LOG4J2-1023. Thanks to Mikael Ståldal. |
ggregory |
|
Add a way to route messages based on the %marker in Layout for RoutingAppender. Fixes LOG4J2-1015. Thanks to Daniel Marcotte. |
ggregory |
|
Add a Log4jLookup class to help write log files relative to log4j2.xml. Fixes LOG4J2-1050. Thanks to Adam Retter. |
ggregory |
|
Add API org.apache.logging.log4j.LogManager.getFormatterLogger(). Fixes LOG4J2-1057. |
ggregory |
|
Expose Log4jContextFactory's ShutdownCallbackRegistry. Fixes LOG4J2-1066. Thanks to Charles Allen. |
ggregory |
|
Misleading StatusLogger WARN event in LogManager with java.util.Map. Fixes LOG4J2-1084. Thanks to Philipp Schneider. |
ggregory |
|
NoClassDefFoundError when starting app on Google App Engine. Fixes LOG4J2-1051. Thanks to Lukasz Lenart. |
ggregory |
|
ExtendedThrowablePatternConverter does not print suppressed exceptions. Fixes LOG4J2-684. Thanks to Joern Huxhorn, Mauro Molinari. |
ggregory |
|
Improper handling of JSON escape chars when deserializing JSON log events. Fixes LOG4J2-1069. Thanks to Sam Braam. |
ggregory |
|
Exceptions not logged when using TcpSocketServer + SerializedLayout. Fixes LOG4J2-1068. Thanks to Andy McMullan. |
ggregory |
|
ThrowableProxy getExtendedStackTraceAsString throws NPE on deserialized nested exceptions. Fixes LOG4J2-1067. Thanks to Sam Braam. |
ggregory |
|
AsyncAppender now resets the thread interrupted flag after catching InterruptedException. Fixes LOG4J2-1049. Thanks to Robert Schaft. |
rpopma |
|
FileConfigurationMonitor unnecessarily calls System.currentTimeMillis() causing high CPU usage. Fixes LOG4J2-1048. Thanks to Nikhil. |
rpopma |
|
Backward compatibility issue in log4j-1.2-api NDC pop() and peek(). Fixes LOG4J2-1037. Thanks to Marc Dergacz. |
ggregory |
|
Custom java.util.logging.Level gives null Log4j Level and causes NPE. Fixes LOG4J2-1025. Thanks to Mikael Ståldal. |
ggregory |
|
SimpleLogger creates unnecessary Map objects by calling ThreadContext.getContext() instead of getImmutableContext(). Fixes LOG4J2-1033. Thanks to Mikael Ståldal. |
ggregory |
|
HighlightConverter does not obey noConsoleNoAnsi. Fixes LOG4J2-1026. |
ggregory |
|
ZipCompressAction leaves files open until GC when an IO error takes place. Fixes LOG4J2-1019. |
ggregory |
|
GzCompressAction leaves files open until GC when an IO error takes place. Fixes LOG4J2-1020. |
ggregory |
|
Incorrect documentation for layout default charset. Fixes LOG4J2-1038. Thanks to Gili. |
ggregory |
|
Socket and Syslog appenders don't take timeout into account at startup. Fixes LOG4J2-1042. Thanks to Guillaume Turri. |
ggregory |
|
Circular suppressed Exception throws StackOverflowError. Fixes LOG4J2-934. Thanks to Kenneth Gendron. |
ggregory |
|
Circular Exception cause throws StackOverflowError. Fixes LOG4J2-1046. Thanks to Kenneth Gendron. |
ggregory |
|
Use System.nanoTime() to measure time intervals. Fixes LOG4J2-982. Thanks to Mikhail Mazurskiy. |
ggregory |
|
Externalize log4j2.xml via URL resource. Fixes LOG4J2-1045. Thanks to Günter Albrecht. |
ggregory |
|
Log4jMarker#contains(String) does not respect org.slf4j.Marker contract. Fixes LOG4J2-1058. Thanks to Daniel Branzea. |
ggregory |
|
Log4jMarker#contains(Marker) does not respect org.slf4j.Marker contract. Fixes LOG4J2-1060. |
ggregory |
|
Log4jMarker#remove(Marker) does not respect org.slf4j.Marker contract. Fixes LOG4J2-1061. |
ggregory |
|
Log4jMarker#add(Marker) does not respect org.slf4j.Marker contract. Fixes LOG4J2-1062. |
ggregory |
|
org.apache.logging.slf4j.Log4jMarker does not implement org.slf4j.Marker.equals(Object) org.slf4j.Marker.hashCode(). Fixes LOG4J2-1064. |
ggregory |
|
Header in layout should not be written on application startup if appending to an existing file. Fixes LOG4J2-1030. Fixes LOG4J2-889. Thanks to Maciej Karaś, Kenneth Leider. |
rpopma |
|
Clarify documentation for combining async with sync loggers. Fixes LOG4J2-918. |
rpopma |
|
GelfLayout throws exception if some log event fields are null. Fixes LOG4J2-1078. Thanks to Mikael Ståldal. |
ggregory |
|
Support batchSize in FlumeAvroManager. Fixes LOG4J2-1044. |
rgoers |
|
Define org.apache.logging.log4j.Marker.equals(Object) and org.apache.logging.log4j.Marker.hashCode(). Fixes LOG4J2-1065. |
ggregory |
|
Avoid creating temporary array object in org.apache.logging.slf4j.Log4jMarker.iterator(). Fixes LOG4J2-1063. |
ggregory |
|
log4j-web-2.1 should workaround a bug in JBOSS EAP 6.2. Fixes LOG4J2-890. Thanks to Hassan Kalaldeh, Robert Andersson, Remko Popma. |
ggregory |
|
MongoDB appender, username and password should be optional. Fixes LOG4J2-403. Thanks to Poorna Subhash P, Jeremy Lautman. |
ggregory |
|
Log4j2 tries to SystemClassLoader when running on Google AppEngine. Fixes LOG4J2-1035. |
ggregory |
|
Allow a list of keys to be specified in the MDC pattern converter. Fixes LOG4J2-1022. |
rgoers |
|
Fix FindBugs DM_DEFAULT_ENCODING bug in SimpleLogger.logMessage() and simplify code. Fixes LOG4J2-959. |
ggregory |
|
Update Apache Flume from 1.5.2 to 1.6.0. Fixes LOG4J2-1036. |
ggregory |
|
Update MongoDB driver from 2.11.2 to 2.13.2. Fixes LOG4J2-1041. |
ggregory |
|
Update database tests from H2 1.3.175 to 1.3.176. Fixes LOG4J2-1018. |
ggregory |
|
Update Java Mail from 1.5.2 to 1.5.4. Fixes LOG4J2-1070. |
ggregory |
|
Update Jackson from 2.5.3 to 2.5.4. Fixes LOG4J2-1079. |
ggregory |
|
Update Jackson from 2.5.4 to 2.6.0. Fixes LOG4J2-1879. |
ggregory |
|
Update Jackson from 2.6.0 to 2.6.1. Fixes LOG4J2-1092. |
ggregory |
|
Update Apache Commons Compress from 1.9 to 1.10. Fixes LOG4J2-1104. |
ggregory |
Release 2.3 – 2015-05-09
Type |
Changes |
By |
|
Incorrectly defined compressionType parameter to GelfLayout. Fixes LOG4J2-1009. Thanks to Mikael Ståldal. |
ggregory |
|
org.apache.logging.log4j.core.config.plugins.util.ResolverUtil.extractPath(URL) incorrectly converts '+' characters to spaces. Fixes LOG4J2-1008. Thanks to Ralph Goers, Gary Gregory. |
ggregory |
|
org.apache.logging.log4j.core.util#fileFromUri(URI uri) incorrectly converts '+' characters to spaces. Fixes LOG4J2-1007. Thanks to Ralph Goers, Gary Gregory. |
ggregory |
|
JUL Logger.throwing is mis-mapped to ERROR when it should be TRACE. Fixes LOG4J2-1003. Thanks to Dan Armbrust. |
ggregory |
|
System.out no longer works after the Console appender and JANSI are initialized. Fixes LOG4J2-965. Thanks to Khotyn Huang. |
ggregory |
|
Make org.apache.logging.log4j.core.Logger#updateConfiguration protected. Fixes LOG4J2-998. Thanks to Mariano Gonzalez. |
ggregory |
|
Move UTF-8 constant from Charsets to Constants class. Remove Charsets class. Fixes LOG4J2-995. |
rgoers |
|
Deadlock would occur if appender thread creates a new Logger during reconfiguration. Fixes LOG4J2-993. |
rgoers |
|
Async root logger config should default includeLocation to false. Fixes LOG4J2-991. Thanks to Ryan Rupp. |
rpopma |
|
AbstractFilter should not implement equals() and hashCode(). Fixes LOG4J2-985. Thanks to Sean Dawson. |
rpopma |
|
PatternLayout %highlight to support noConsoleNoAnsi like %style. Fixes LOG4J2-984. Thanks to Jonas Höpfner. |
ggregory |
|
Truncate from the end of text format modifier. Fixes LOG4J2-926. Thanks to David Ohana. |
ggregory |
|
Numerical overflow in BurstFilter not handled correctly. Fixes LOG4J2-980. Thanks to Mikhail Mazurskiy. |
ggregory |
|
Incorrect unlock in ProviderUtil. Fixes LOG4J2-981. Thanks to Mikhail Mazurskiy. |
ggregory |
|
KeyStoreConfiguration.createKeyStoreConfiguration() ignores keyManagerFactoryAlgorithm. Fixes LOG4J2-966. |
ggregory |
|
Using monitorInterval with YAML config file format causes JSONParseException. Fixes LOG4J2-976. Thanks to Matt Quinn. |
ggregory |
|
StringFormattedMessage serialization is incorrect. Fixes LOG4J2-964. Thanks to Jonne Jyrylä. |
ggregory |
|
A new StatusLoggerAdmin listener is added to StatusLogger every time the log is reconfigured. Fixes LOG4J2-947. Thanks to Stefan Wehner. |
ggregory |
|
SyslogLayout contains extra space. Fixes LOG4J2-968. Thanks to Paul D Johe. |
ggregory |
|
log4j2.component.properties not read for all properties. Fixes LOG4J2-967. Thanks to Stefan Wehner. |
ggregory |
|
Another bad priority in Syslog messages. Fixes LOG4J2-971. Thanks to Paul D Johe. |
ggregory |
|
org.apache.logging.log4j.core.net.ssl.TlsSyslogInputStreamReader does not need to create temp Integer objects. Fixes LOG4J2-972. |
ggregory |
|
Typo in EventLogger documentation. Fixes LOG4J2-974. Thanks to Daniel Galán y Martins. |
ggregory |
|
Update LMAX Disruptor from 3.3.0 to 3.3.2. Fixes LOG4J2-988. |
ggregory |
|
Migrate tests from Logback 1.1.2 to 1.1.3. Fixes LOG4J2-987. |
ggregory |
|
Update tests to use ActiveMQ from 5.10 to 5.11.1. Fixes LOG4J2-988. |
ggregory |
|
Update Jackson from 2.5.1 to 2.5.3. Fixes LOG4J2-1004. |
ggregory |
|
Update Slf4j from 1.7.7 to 1.7.12. Fixes LOG4J2-1005. |
ggregory |
Release 2.2 – 2015-02-22
Type |
Changes |
By |
|
(JMX) To avoid memory leaks when web applications are restarted, JMX notifications are sent from
the caller thread in web applications. For non-web applications notifications are sent from a background thread
as before. Fixes LOG4J2-938. Thanks to Mauro Molinari. |
rpopma |
|
Missing toUpperCase(Locale.ENGLISH). Fixes LOG4J2-957. Thanks to fatih guleryuz. |
ggregory |
|
Manual refers to Route "AppenderRef" attribute, should be "ref". Fixes LOG4J2-956. Thanks to David Kellerman. |
ggregory |
|
Documentation: clarify system properties to control status logger, improve troubleshooting FAQ entry. Fixes LOG4J2-955. |
rpopma |
|
Incorrect attribute name in PropertiesRewritePolicy example. Fixes LOG4J2-950. Thanks to Joel Edwards. |
ggregory |
|
Log4j Flume appender is not adding millisecond to the event headers when the event is logged at 000 milliseconds. Fixes LOG4J2-944. Thanks to Vinayaka Ramachandra. |
ggregory |
|
Allow JSON layout to create one compact log record per line. Fixes LOG4J2-941. Thanks to Konstantinos Liakos. |
ggregory |
|
HTML layout should not use attribute minimalization for hr noshade. Fixes LOG4J2-933. Thanks to ppiman at gmail.com. |
ggregory |
|
Specify the SyslogAppender connect timeout value as part of the configuration.
The SyslogAppender takes a new parameter connectTimeoutMillis. Fixes LOG4J2-895. |
ggregory |
|
Specify the SocketAppender connect timeout value as part of the configuration.
The SyslogAppender takes a new parameter connectTimeoutMillis. Fixes LOG4J2-899. |
ggregory |
|
Log4j 1.2 Bridge doesn't map level ALL correctly in Category.getEffectiveLevel(). Fixes LOG4J2-924. Thanks to Ryan Rupp. |
ggregory |
|
ConsoleAppender is missing @PluginFactory annotation at createAppender method. Fixes LOG4J2-931. Thanks to Robert Gacki. |
ggregory |
|
Logging system fails to initialize if XInclude API is not available. Fixes LOG4J2-919. Thanks to David Johle. |
ggregory |
|
ThrowableProxy.getExtendedStackTraceAsString causes NullPointerException. Fixes LOG4J2-914. Thanks to Kaj Bjurman. |
ggregory |
|
XML configuration does not report full error message for XInclude parser configuration problems. Fixes LOG4J2-912. |
ggregory |
|
ClassLoaderContextSelector uses ClassLoader.toString() as a key. Fixes LOG4J2-903. Thanks to Mauro Molinari. |
ggregory |
|
ThrowableProxy throws NoClassDefFoundError. Fixes LOG4J2-834. Thanks to Nikita Koval, Leonard Broman, Thiago Kronig. |
ggregory |
|
NullPointerException on filter when mapping JUL to Log4j2. Fixes LOG4J2-893. |
ggregory |
|
JUL adapter does not map Log4j'2 FATAL level to a JUL level. Fixes LOG4J2-892. |
ggregory |
|
AbstractLifecycle should not implement equals() and hashCode(). Fixes LOG4J2-881. Thanks to Mariano Gonzalez. |
ggregory |
|
Javadoc for org.apache.log4j.BasicConfigurator.configure() is incorrect. Fixes LOG4J2-897. |
ggregory |
|
AbstractLifecycle should not implement equals() and hashCode(). Fixes LOG4J2-891. |
ggregory |
|
[docs] Using Log4j 2 in Web Applications: Update example (Log4jWebLifeCycle is not visible). Fixes LOG4J2-946. Thanks to artemonster. |
ggregory |
|
Update docs for SyslogAppender: "No structured id name was supplied". Fixes LOG4J2-901. Thanks to Tihomir Meščić, Siegfried Greisinger. |
ggregory |
|
Update from Jackson 2.5.0 to 2.5.1. Fixes LOG4J2-958. |
ggregory |
|
Update from Jackson 2.4.4 to 2.5.0. Fixes LOG4J2-925. |
ggregory |
|
Update Jackson from 2.4.3 to 2.4.4. Fixes LOG4J2-910. |
ggregory |
|
Update Jackson from 2.4.2 to 2.4.3. Fixes LOG4J2-881. |
ggregory |
|
Update maven-core from 3.1.0 to 3.2.3. Fixes LOG4J2-882. |
ggregory |
|
Update tests from org.apache.felix.framework 4.2.1 to 4.4.1. Fixes LOG4J2-883. |
ggregory |
|
Update org.eclipse.osgi from 3.6.0 to 3.7.1. Fixes LOG4J2-884. |
ggregory |
|
Update Apache Flume from 1.5.0.1 to 1.5.2. Fixes LOG4J2-900. |
ggregory |
Release 2.1 – 2014-10-19
Type |
Changes |
By |
|
Some typo fixes and enhancements for the site. Fixes LOG4J2-676. Thanks to Stefan Bodewig. |
rgoers |
|
Add ShutdownCallbackRegistry interface for customizable shutdown callback handling. This is particularly
useful for application servers that wish to integrate with Log4j 2. Fixes LOG4J2-868. |
mattsicker |
|
Documentation: fixed missing closing parenthesis in code example. Fixes LOG4J2-866. Thanks to Gerard Weatherby. |
rpopma |
|
Fixed classloader issue that prevented Log4j from finding the implementation when used in a custom Ant task. Fixes LOG4J2-862. Thanks to Michael Sutherland. |
mattsicker |
|
Supported filtering on custom log levels in configuration. Fixes LOG4J2-589. |
rpopma |
|
Documentation: fix broken links on left navigation Extending Log4j Configuration sub-menu. Fixes LOG4J2-861. |
rpopma |
|
Documentation: add sections on the JUL Adapter, IO Streams and NoSQL Appenders to the Maven and Ivy page. Fixes LOG4J2-856. |
rpopma |
|
Documentation: clarified why log4j-core is a compile time dependency in Maven and Ivy page. Fixes LOG4J2-797. Thanks to Andreas Rytina. |
rpopma |
|
Documentation: fix broken links on Appenders manual page. Fixes LOG4J2-855. |
rpopma |
|
Prevent NPE when configuration with AsyncLogger/AsyncRoot is reloaded. Fixes LOG4J2-807. |
rpopma |
|
Add a Java lookup to provide nicely formatted runtime version information. Fixes LOG4J2-848. |
ggregory |
|
Move reflection utility class to API's private utility classes. Fixes LOG4J2-809. |
mattsicker |
|
Add 2.1.0 to compatible versions in Log4j API ProviderUtil and update Log4jAPIVersion to 2.1.0 in
core META-INF/log4j-provider.properties. Fixes LOG4J2-845. |
mattsicker |
|
Documentation: added Runtime Dependencies link to left nav-bar on site. Fixes LOG4J2-833. |
rpopma |
|
Documentation: added section on XInclude to user manual Configuration page. Fixes LOG4J2-816. |
rpopma |
|
Documentation: fixed minor issues with Log4j2 web site/documentation. Fixes LOG4J2-678. Thanks to Matt Sicker. |
rpopma |
|
Update JMH to 1.1 from 0.7.2. Fixes LOG4J2-844. |
rpopma |
|
Migrate JpaHyperSqlAppenderTest JUnit performance test to log4j-perf. Fixes LOG4J2-843. |
rpopma |
|
Migrate JpaH2AppenderTest JUnit performance test to log4j-perf. Fixes LOG4J2-842. |
rpopma |
|
Migrate JdbcHyperSqlAppenderTest JUnit performance test to log4j-perf. Fixes LOG4J2-841. |
rpopma |
|
Migrate JdbcH2AppenderTest JUnit performance test to log4j-perf. Fixes LOG4J2-840. |
rpopma |
|
Respect external interrupt signal to allow application shutdown after joining AsyncAppender thread. Fixes LOG4J2-830. |
rpopma |
|
MarkerManager Log4jMarker.hasParents() returns opposite of correct result. Fixes LOG4J2-813. Thanks to David Erichsen, Brandon Barry. |
ggregory |
|
Documentation: fixed capitalization inconsistency in user manual example config. Fixes LOG4J2-785. |
rpopma |
|
Fixed issue in RollingFile filePattern: backslashes are path separators, not escape characters. Fixes LOG4J2-829. |
rpopma |
|
Add the Log4j IOStreams component. Fixes LOG4J2-547. |
mattsicker |
|
Added Memory-Mapped File Appender. Fixes LOG4J2-431. Thanks to Claude Mamo. |
rpopma |
|
ThrowableProxy fails if a class in logged stack trace throws java.lang.Error from initializer. Fixes LOG4J2-832. Thanks to Seth Leger. |
ggregory |
|
Documentation: updated FAQ "which jars" diagrams for JUL bridge and 2.1 version. Fixes LOG4J2-831. |
rpopma |
|
Support use of TypeConverter classes through the standard Plugin system. Fixes LOG4J2-827. |
mattsicker |
|
Avoid ConverterKey plugin clashes by using a more predictable plugin loading infrastructure.
Plugins have been segmented into three parts: class path, user-specified packages, and OSGi bundles. Fixes LOG4J2-745. Thanks to Scott Harrington. |
mattsicker |
|
Fixed plugin scanning redundancy causing massive slowdowns in certain environments. Fixes LOG4J2-798. Thanks to Scott Harrington. |
mattsicker |
|
Reduced CachedClock thread contention. Fixes LOG4J2-753. |
rpopma |
|
Fixed memory leak in Tomcat 6 caused by clock background threads unintentionally
started by Tomcat after web application stop. Fixes LOG4J2-819. Thanks to Gary Gregory. |
mattsicker |
|
Add simple validation constraint annotations for the Plugin system. Fixes LOG4J2-825. |
mattsicker |
|
Implement a GELF layout. Fixes LOG4J2-428. Thanks to Mark Paluch, Mikael Ståldal. |
ggregory |
|
FlumePersistentManager now handles LockConflictExceptions in Berkeley Db when sending a batch. Fixes LOG4J2-391. Thanks to Kamal Bahadur. |
rgoers |
|
Remove invalid Oracle Maven repository. Fixes LOG4J2-782. |
mattsicker |
|
Update Spring Framework to 3.2.11.RELEASE from 3.2.8.RELEASE. Fixes LOG4J2-780. |
mattsicker |
|
Unify the two JMS appenders into a single appender. Configurations written for 2.0 will still work in 2.1+. Fixes LOG4J2-815. |
mattsicker |
|
Add java.util.logging implementation based on log4j-api. See log4j-jul documentation for more details. Fixes LOG4J2-608. |
mattsicker |
|
Fixed issue where log4j-to-slf4j did not work correctly with SLF4J Simple Logger. Fixes LOG4J2-796. |
rpopma |
|
SimpleLogger throws ArrayIndexOutOfBoundsException for an empty array. Fixes LOG4J2-811. Thanks to Yogesh Rao. |
ggregory |
|
Fix OSGi Import-Package problem with the JMS API. Fixes LOG4J2-663. Thanks to Florian Brunner. |
mattsicker |
|
Add support for custom SLF4J Markers in log4j-slf4j-impl module. Fixes LOG4J2-793. |
mattsicker |
|
PatternLayout should use platform character encoding by default, not UTF-8. Fixes LOG4J2-783. Thanks to Minglei Lee. |
rpopma |
|
Add lookup for application main arguments. Fixes LOG4J2-771. |
ggregory |
|
Add lookup for JVM arguments. Fixes LOG4J2-787. |
ggregory |
|
Update Jackson to 2.4.2 from 2.4.1 (for XML and JSON processing). Fixes LOG4J2-790. |
ggregory |
|
Incomplete documentation for JSONLayout. Fixes LOG4J2-766. Thanks to Bruno P. Kinoshita. |
ggregory |
|
All life cycle implementations should be serializable.
This is still work in progress. Fixes LOG4J2-800. |
ggregory |
|
org.apache.logging.log4j.core.Logger should be serializable.
This is still work in progress. Fixes LOG4J2-801. |
ggregory |
|
Update javax.mail to 1.5.2 from 1.5.0. Fixes LOG4J2-810. |
ggregory |
|
Update org.eclipse.persistence.jpa to 2.5.2 from 2.5.1. Fixes LOG4J2-822. |
ggregory |
|
FlumeAppender: maxDelay not in seconds, but milliseconds.
Add time scale to some settings, for example maxDelayMillis instead of maxDelay.
The old names are aliased for compatibility. Fixes LOG4J2-867. |
ggregory |
Release 2.0.2 – 2014-08-16
Type |
Changes |
By |
|
Update Apache Flume to 1.5.0.1 from 1.5.0. Fixes LOG4J2-775. |
ggregory |
|
Site: log4j-core component pages were still using the old logo. Fixes LOG4J2-773. |
rpopma |
|
Documentation improvement: link to dependency tree from log4j-core component page,
link to log4j-core component page from FAQ page. Fixes LOG4J2-760. |
rpopma |
|
Resolved race condition that caused log file rotation to fail with error: "Unable to create directory ...". Fixes LOG4J2-679. |
rpopma |
|
Prevent application from hanging when PatternLayout configuration has opening '{' but no closing '}'. Fixes LOG4J2-726. |
rpopma |
|
Startup takes a long time if you have empty packages attribute. Fixes LOG4J2-769. Thanks to Scott Harrington. |
rpopma |
|
Improved asynchronous loggers and appenders to ensure the formatted message does not change even if
parameters are modified by the application. (ParameterizedMessage was already safe.)
Improved documentation. Fixes LOG4J2-763. Thanks to Stephen Connolly. |
rpopma |
|
Emit warning message to console if no configuration file found. Fixes LOG4J2-729. |
rpopma |
|
Improve warning message when missing log4j-core in the classpath. Fixes LOG4J2-765. |
rpopma |
|
Clarified in documentation that Commons Logging jar is required when using log4j-jcl. Fixes LOG4J2-722. |
rpopma |
|
Clarified in documentation that SLF4J API jar is required when using log4j-slf4j-impl. Fixes LOG4J2-723. |
rpopma |
|
Allow Log4jContextFactory subclasses to specify a custom ContextSelector. Fixes LOG4J2-730. |
rpopma |
|
Fixed various minor site/documentation issues, mostly versioning related. Fixes LOG4J2-759. |
rpopma |
|
Prevent JUnit test from creating unnecessary Log4j2Plugins.dat during build. Fixes LOG4J2-756. Thanks to Scott Harrington. |
rpopma |
Release 2.0.1 – 2014-07-29
Type |
Changes |
By |
|
Avoid unnecessary Clock calls when TimestampMessage is logged. Fixes LOG4J2-744. Thanks to Scott Harrington. |
rpopma |
|
Improved error message if configuration file not found. Fixes LOG4J2-704. |
rpopma |
|
Webapp configuration page has incorrect class name. Fixes LOG4J2-750. Thanks to Mike Calmus. |
ggregory |
|
Retain the default date pattern after fixing the ISO8601 pattern. Fixes LOG4J2-749. Thanks to Scott Harrington. |
rpopma |
|
DatePatternConverter ISO8601_PATTERN now conforms to ISO8601. Fixes LOG4J2-670. |
rpopma |
|
Reinstate the package configuration attribute for discovering custom plugins. Fixes LOG4J2-741. |
rpopma |
|
XInclude not working with relative path. Fixes LOG4J2-742. Thanks to Pascal Chollet. |
ggregory |
|
Fixed typo in webapp manual regarding sample web.xml file. Fixes LOG4J2-740. Thanks to Kosta Krauth. |
mattsicker |
|
RollingFileManager deadlock if async action thread fails to start. Fixes LOG4J2-738. Thanks to Timothy Stack. |
ggregory |
|
Fixed log4j-bom so that it won't specify a default scope on any third party dependencies. Fixes LOG4J2-736. |
mattsicker |
|
Fixed log4j-bom so that it won't interfere with spring-bom and others. Fixes LOG4J2-735. |
mattsicker |
|
Updated documentation regarding extensions to LoggerContextFactory and Log4j 2 providers. Fixes LOG4J2-731. |
mattsicker |
|
Fixed ClassLoader issues in loading Log4j providers in an OSGi environment. Fixes LOG4J2-373. |
mattsicker |
|
Added WebLoggerContextUtils class to log4j-web for helper methods useful for asynchronous servlets. Fixes LOG4J2-725. |
mattsicker |
|
Added documentation for Custom Levels and Custom Loggers. Fixes LOG4J2-710. |
rpopma |
|
Correctly handle NetworkOnMainThreadException thrown on Android during Log4j2 initialization. Fixes LOG4J2-719. |
rpopma |
|
Automatically disable log4j JMX when detecting we are running on Android. Fixes LOG4J2-716. |
rpopma |
|
Fixed AbstractDatabaseManager to close connection on writeInternal error. Fixes LOG4J2-657. Thanks to Stefan Wehner. |
rpopma |
|
Android: java.lang.VerifyError: org/apache/logging/log4j/core/util/Closer. Fixes LOG4J2-713. Thanks to Nelson Melina. |
ggregory |
|
Android: Could not find class 'javax.naming.InitialContext', referenced from method org.apache.logging.log4j.core.lookup.JndiLookup.lookup. Fixes LOG4J2-703. Thanks to Nelson Melina. |
ggregory |
|
Update to LMAX Disruptor 3.3.0 from 3.2.1. Fixes LOG4J2-732. |
ggregory |
|
Update to latest Jackson jars from the 2.4.1.X line. Fixes LOG4J2-733. |
ggregory |
Release 2.0 – 2014-07-12
Type |
Changes |
By |
|
Fixed issue where Async Logger does not log thread context stack data.
API change: added method getImmutableStackOrNull() to ThreadContext.ContextStack interface. Fixes LOG4J2-705. |
rpopma |
|
Update docs to clarify how to use formatter logger and standard logger together. Fixes LOG4J2-631. |
rpopma |
|
Added support for generating custom logger wrappers that replace the existing log levels
and extended logger wrappers that add custom log levels to the existing ones. Fixes LOG4J2-519. |
rpopma |
|
LoggerConfigs with no Level now inherit the Level from their parent. Fixes LOG4J2-441. |
rgoers |
|
RegexFilter does not match multiline log messages. Fixes LOG4J2-696. |
ggregory |
|
PatternLayout manual page missing documentation on header/footer. Fixes LOG4J2-699. |
rpopma |
|
Fixed Serialization error with SocketAppender and Async Loggers.
(Fixed in RC2, but wasn't included in release notes.). Fixes LOG4J2-625. |
rpopma |
|
JMX GUI: fixed occasional ArrayIndexOutOfBoundsException after pressing "reconfigure with XML below".
(Fixed in RC2, but wasn't included in release notes.). Fixes LOG4J2-538. |
rpopma |
|
AsyncLoggerContextSelector should ensure that different AsyncLoggerContext objects created by web app classloaders have unique names. Fixes LOG4J2-666. |
rpopma |
|
Fix annotation processor warnings on JDK 1.7+. Fixes LOG4J2-683. Thanks to Jurriaan Mous. |
mattsicker |
|
Fix strange compilation error that popped up in a test class. Fixes LOG4J2-694. |
mattsicker |
|
Update documentation to specify only Maven 3 is supported. Fixes LOG4J2-692. |
rgoers |
|
Log4j Web test dependencies should be in scope "test" in the pom. Fixes LOG4J2-690. Thanks to Philip Helger. |
rgoers |
|
Special characters (tab and so on) in PatternLayout do not work. Fixes LOG4J2-682. Thanks to Scott Harrington. |
ggregory |
|
Make org.apache.logging.log4j.core.layout.AbstractLayout immutable. Fixes LOG4J2-685. |
ggregory |
|
Core's OptionConverter support for \b is broken (affects PatternLayout). Fixes LOG4J2-686. |
ggregory |
|
Rename org.apache.logging.log4j.core.util.Closer.closeSilent() to closeSilently(). Fixes LOG4J2-687. |
ggregory |
|
Make org.apache.logging.log4j.core.layout.PatternLayout immutable. Fixes LOG4J2-688. |
ggregory |
|
Update Jackson to 2.4.1. Fixes LOG4J2-689. |
ggregory |
|
Some exceptions are not logged when configuration problems are detected. Fixes LOG4J2-707. |
ggregory |
|
Update Apache Commons Logging to 1.2 from 1.1.3. Fixes LOG4J2-709. |
ggregory |
Release 2.0-rc2 – 2014-06-21
Type |
Changes |
By |
|
RollingFile and RollingRandomAccessFile now write the layout footer before rollover. Fixes LOG4J2-675. |
rpopma |
|
RollingRandomAccessFile now writes the layout header after rollover. Fixes LOG4J2-581. Thanks to Alexander Khokhlov. |
rpopma |
|
RollingFileManager now correctly honours the bufferedIO configuration after rollover. Fixes LOG4J2-622. Thanks to Farooq Khan. |
rpopma |
|
Made RollingFileAppender buffer size configurable. Fixes LOG4J2-674. |
rpopma |
|
Improved documentation regarding log4j status logger. Fixes LOG4J2-141. Thanks to Joern Huxhorn. |
rpopma |
|
Fixed issue with "Reconfigure using XML below" function in JMX Client GUI.
ConfigurationSource is now a top-level class and can be obtained with Configuration.getConfigurationSource().
LoggerContext.getConfiguration().getConfigurationSource()
provides a reliable public method for obtaining a logger context's configuration location and content. Fixes LOG4J2-539. Thanks to Colin Froggatt. |
rpopma |
|
Invalid XML configuration files do not prevent the config file from being checked again. Fixes LOG4J2-619. Thanks to Scott Harrington. |
rgoers |
|
JMX: Updating a Logger's level via jConsole now correctly takes effect. Fixes LOG4J2-637. Thanks to Mansoor Sajjad, Jon Wilmoth. |
rpopma |
|
Correctly process log events when combining AsyncLoggers with AsyncAppender. Fixes LOG4J2-668. |
rpopma |
|
Prevent NPE when combining AsyncLoggers with AsyncLoggerConfigs. Fixes LOG4J2-669. |
rpopma |
|
Create an appender to route log events to the ServletContext log. Fixes LOG4J2-42. |
rgoers |
|
Support default value for missing key in look ups with fallback to looking in the properties map. Fixes LOG4J2-419. Thanks to Woonsan Ko. |
rgoers |
|
FlumeAvroManager now always uses a client type of default_failover. Fixes LOG4J2-563. Thanks to Michael Friedmann. |
rgoers |
|
Allow configuration files to be located as Servlet Context resources. Fixes LOG4J2-554. |
rgoers |
|
Reset rollover time when size rollover is triggered. Fixes LOG4J2-535. |
rgoers |
|
Moved plugin cache file to META-INF for OSGi compatibility. Fixes LOG4J2-664. |
mattsicker |
|
Fix NPE that can be caused by a null ThreadContextClassLoader. Fixes LOG4J2-640. |
mattsicker |
|
Add Vagrantfile for testing in GNU+Linux. Fixes LOG4J2-655. |
mattsicker |
|
Log4j 2 throws ArrayIndexOutOfBoundsException. Fixes LOG4J2-651. |
ggregory |
|
Add log4j-perf module to provide a home for all log4j performance tests.
Add support for JMH microbenchmark performance tests. Fixes LOG4J2-654. |
rpopma |
|
Add support for default plugin values and attributes. Fixes LOG4J2-652. |
mattsicker |
|
Add support for types other than String for plugin factory values/attributes. Fixes LOG4J2-598. |
mattsicker |
|
Refactor Log4jLogEvent to lazily create ThrowableProxy. Fixes LOG4J2-250. |
rpopma |
|
Upgrade to Flume 1.5.0. Fixes LOG4J2-647. |
ggregory |
|
Implement a SecureSocketAppender and secure server (SSL/TLS). Fixes LOG4J2-644. |
ggregory |
|
Merge the TLS Syslog appender into the Syslog appender. Fixes LOG4J2-646. |
ggregory |
|
Perform reconfiguration in a separate thread to prevent deadlocks. Fixes LOG4J2-620. |
rgoers |
|
Override commons-logging dependency version in tests. Fixes LOG4J2-641. |
mattsicker |
|
Prevent NPE in AsyncLogger and AsyncLoggerConfig if logger is used after log4j has been shut down. Fixes LOG4J2-639. Thanks to Mck SembWever. |
rpopma |
|
FailoverAppender was not resetting its status after the primary appender recovered. Fixes LOG4J2-469. |
rgoers |
|
Generate MDC properties as a JSON map in JSONLayout. Fixes LOG4J2-623. |
rgoers |
|
Made RollingRandomAccessFileAppender buffer size configurable. Fixes LOG4J2-566. Thanks to Luigi Alice. |
rpopma |
|
Resolved issue where AsyncAppender dropped events if queue still contained
events when application is stopped. Fixes LOG4J2-520. Thanks to JavaTech, Andre Bogus. |
rpopma |
|
Resolved a problem with the previous solution for LOG4J2-392 that resulted in dropped events
when using AsyncLoggerConfig with slow appenders when application is stopped. Fixes LOG4J2-392. Thanks to Andre Bogus. |
rpopma |
|
The OSGi version of log4j-web imports Servlet 2.5 at minimum instead of 3.0. Fixes LOG4J2-613. |
mattsicker |
|
Unit tests are now less verbose during the build process. Fixes LOG4J2-602. |
rgoers |
|
Fix shutdown thread memory leak in servlet containers. Fixes LOG4J2-570. |
mattsicker |
|
Use Clock to generate all log event timestamps, not just for Async Loggers. Fixes LOG4J2-628. |
rpopma |
|
Document the system properties used in Log4J 2. Fixes LOG4J2-629. |
rpopma |
|
Make Throwable transient in ThrowableProxy. Fixes LOG4J2-542. |
rgoers |
|
Update SLF4J to 1.7.7. Fixes LOG4J2-617. |
mattsicker |
|
Update Jackson to 2.3.3. Fixes LOG4J2-616. |
mattsicker |
|
During shutdown, a NullPointerException could be thrown due to the NullConfiguration class no longer being
available to the ClassLoader. Fixes LOG4J2-440. |
mattsicker |
|
Cyclic dependency with log4j-slf4j-impl in OSGi. Fixes LOG4J2-346. |
mattsicker |
|
The log4j-1.2-api module didn't export any packages to OSGi. Fixes LOG4J2-345. |
mattsicker |
|
Password data from the NoSQL plugins no longer shows up in cleartext in debug logging. Fixes LOG4J2-605. |
mattsicker |
|
A StringIndexOutOfBounds exception could occur during property substitution. Fixes LOG4J2-448. Thanks to X86core. |
rgoers |
|
StatusLogger was not skipping multiple instances of the FQCN class, causing messages from classes in
the Verbose list to be printed. Fixes LOG4J2-597. |
rgoers |
|
Add support for multiple parents to Markers. Fixes LOG4J2-585. Thanks to Bruce Brouwer. |
rgoers |
|
Introduce Java annotation processor as the new plugin pre-caching mechanism. This is available in log4j-core.
All custom plugins created before this should be re-built against the current log4j-core. Fixes LOG4J2-595. |
mattsicker |
|
Renamed SLF4J logger class to Log4jLogger. Fixes LOG4J2-564. |
mattsicker |
|
Rework Level comparison APIs. Fixes LOG4J2-579. |
ggregory |
|
Add org.apache.logging.log4j.Logger.getLevel(). Fixes LOG4J2-576. |
ggregory |
|
Make Blocking the default WaitStrategy for Async Loggers. Fixes LOG4J2-574. |
rpopma |
|
Introduce ExtendedLogger interface to facilitate implementing and extending Loggers. Fixes LOG4J2-555. Thanks to Bruce Brouwer. |
rpopma |
|
SyslogAppenderTest and RFC5424LayoutTest were failing in Java 8. Fixes LOG4J2-560. |
rgoers |
|
Allow spaces around commas in Configuration's package attribute. Fixes LOG4J2-561. Thanks to vibin. |
ggregory |
|
Have Logger API expose a PrintWriter instead of custom LoggerStream. Fixes LOG4J2-547. Thanks to Bruce Brouwer. |
rgoers |
|
Add EncodingPatternConverter to escape newlines and HTML special characters. Fixes LOG4J2-439. Thanks to Bruce Brouwer. |
rgoers |
|
Allow header and footer to be specified as lookup patterns in PatternLayout. Fixes LOG4J2-496. |
rgoers |
|
Add equals and hashcode to Log4jLogEvent. Fixes LOG4J2-499. |
rgoers |
|
SLf4JLogger is now Serializable. Fixes LOG4J2-410. Thanks to Ivlin Zeng. |
rgoers |
|
Add support for configuration via YAML. Fixes LOG4J2-427. Thanks to Alexander Reelsen. |
rgoers |
|
Add DateLookup and ThreadContextLookup to default lookups. Fixes LOG4J2-378. |
rgoers |
|
Add support to add a LoggerConfig. Document two ways to modify the configuration. Fixes LOG4J2-468. |
rgoers |
|
Rename org.apache.logging.log4j.core.net.SocketServer to TCPSocketServer and refactor with UDP. Fixes LOG4J2-582. |
ggregory |
|
Update Jackson to 2.3.2 from 2.2.2. Fixes LOG4J2-592. |
ggregory |
Release 2.0-rc1 – 2014-02-16
Type |
Changes |
By |
|
Removed the DataSourceConnectionSource and the <DriverManager> plugin for the JDBC Appender. It is not
safe to use. Please use the DataSource or factory connection sources backed by a connection pool. |
nickwilliams |
|
Renamed the org.apache.logging.log4j.core.appender.db.nosql.mongo package to
org.apache.logging.log4j.core.appender.db.nosql.mongodb. |
nickwilliams |
|
Renamed the org.apache.logging.log4j.core.appender.db.nosql.couch package to
org.apache.logging.log4j.core.appender.db.nosql.couchdb. |
grobmeier |
|
(JMX - ObjectNames changed!) Unloading one web application unloads JMX MBeans for all web applications. Fixes LOG4J2-500. |
rpopma |
|
Space Level numbers by 100 instead of 1. Fixes LOG4J2-507. |
ggregory |
|
Fixed bugs where rolled log files were overwritten by RollingFile appender with
composite time and size based policies. Fixes LOG4J2-531. Thanks to Geoff Ballinger. |
rpopma |
|
Changed the MongoDBConnection to add a MongoDB encoding hook instead of a decoding hook. Fixes LOG4J2-475. Thanks to Matt Sicker. |
nickwilliams |
|
Fixed the JPAAppender's overuse of transactions by connecting (borrowing from pool) on new write internal or on
flush. Fixes LOG4J2-489. |
nickwilliams |
|
Fixed failure of JDBC and JPA appender to properly release database connections by connecting (borrowing from
pool) on new write internal or on flush. Fixes LOG4J2-457. |
nickwilliams |
|
Fixed problem with JDBC and JPA appender connectivity in WebSphere by connecting (borrowing from pool) on new
write internal or on flush. Fixes LOG4J2-442. |
nickwilliams |
|
Ensured the JDBCAppender commits transactions after a single write or a flush of multiple writes. Fixes LOG4J2-438. |
nickwilliams |
|
Fixed inability to recover from lost database connection in database appenders by connecting (borrowing from
pool) on new write internal or on flush. Fixes LOG4J2-407. |
nickwilliams |
|
(JMX) JMX Client GUI should dynamically update when LoggerContext MBeans are registered/unregistered in MBean
server. Fixes LOG4J2-530. |
rpopma |
|
Stop AsyncLoggerConfig Disruptor thread(s), then AsyncAppender thread(s) first
before stopping other appenders. Fixes LOG4J2-511. Thanks to James Pretorius. |
rpopma |
|
Stop AsyncLoggerConfig Disruptor thread(s), then AsyncAppender thread(s) first
before stopping other appenders. Fixes LOG4J2-392. Thanks to ilynaf, Andre Bogus. |
rpopma |
|
(OSGi) logging.log4j-1.2-api doesn't export the log4j API 1.2. Dependent bundles can not be resolved. Fixes LOG4J2-345. Thanks to Roland Weiglhofer, Matt Sicker. |
rpopma |
|
LocalizedMessage serialization is broken. Fixes LOG4J2-523. |
ggregory |
|
Fixed issues with time-based file rollover (monthly, weekly, hourly and every minute). Fixes LOG4J2-385. Thanks to Ace Funk, Porfirio Partida. |
rpopma |
|
Added a ServletContext attribute that, when set to "true", disables Log4j's auto-initialization in
Servlet 3.0+ web applications. Fixes LOG4J2-452. |
nickwilliams |
|
Exposed Log4j web support interface and methods and the LoggerContext through ServletContext attributes
so that threads not affected by filters (such as asynchronous threads) can utilize the LoggerContext. Also
updated the Log4j filter so that it supports async. Fixes LOG4J2-512. Thanks to Chandra Sekhar Kakarla, Matt Sicker. |
nickwilliams |
|
Created a utility to properly escape backslashes before creating URIs, and changed URI creation to use the
utility instead of instantiating URI directly. Fixes LOG4J2-409. Thanks to Frank Steinmann, Thomas Neidhart. |
nickwilliams |
|
Changed the Servlet 3.0 auto-initializer to add the filter by class to get around a WebLogic bug. Fixes LOG4J2-344. Thanks to Keir Lawson, Tomasz Wladzinski. |
nickwilliams |
|
Changed the Servlet 3.0 auto-initializer so that it does nothing in a Servlet 2.5 or older application. This
ensures behavioral consistency across containers. This includes additional fixes to abort initialization if a
duplicate filter already exists and to check the actual Servlet EFFECTIVE version. Fixes LOG4J2-359. Thanks to Abhinav Shah. |
nickwilliams |
|
Switch in log4j-1.2-api Category.getEffectiveLevel has no cases for FATAL, OFF. Fixes LOG4J2-517. |
rpopma |
|
Add support for custom logging levels. Fixes LOG4J2-41. Thanks to Nick Williams. |
rgoers |
|
(JMX) Unregister all log4j JMX MBeans when the LoggerContext is stopped
to allow web application classes to be GC-ed on undeploy. Fixes LOG4J2-406. Thanks to Kerrigan Joseph. |
rpopma |
|
Configuration was being processed twice at startup. Fixes LOG4J2-405. |
rgoers |
|
ThreadContext now uses plain ThreadLocal by default, unless system property
isThreadContextMapInheritable has value "true". Fixes LOG4J2-479. Thanks to MK. |
rpopma |
|
Configure properties and setup Interpolator before processing rest of configuration. Fixes LOG4J2-398. |
rgoers |
|
Add Stream interface to Loggers. Fixes LOG4J2-481. Thanks to Matt Sicker. |
rgoers |
|
Update EasyMock to version 3.2. Fixes LOG4J2-490. Thanks to Matt Sicker. |
rgoers |
|
hostName property was not being set until after the first configuration element. Fixes LOG4J2-470. |
rgoers |
|
Support arrays as sub-elements of a JSON configuration. Fixes LOG4J2-464. |
rgoers |
|
(JMX) Fixed MalformedObjectNameException if context name contains '=' or newline characters. Fixes LOG4J2-492. Thanks to Shaddy Baddah, Herlani Junior. |
rpopma |
|
(OSGi) Fix NPE during shutdown. Fixes LOG4J2-377. Thanks to Roland Weiglhofer, Matt Sicker. |
rpopma |
|
Fixed documentation for MyApp example application in the Automatic Configuration section. Fixes LOG4J2-463. Thanks to Michael Diamond, Matt Sicker. |
rpopma |
|
Fixed error in documentation code example in manual/eventlogging.html. Fixes LOG4J2-408. Thanks to Dongqing Hu, Matt Sicker. |
rpopma |
|
Fixed typo in documentation: system property should be log4j2.loggerContextFactory. Fixes LOG4J2-451. Thanks to Vinay Pothnis, Matt Sicker. |
rpopma |
|
(JMX) Fixed issue where log4j2 LoggerContext did not show up in JMX GUI or JConsole. Fixes LOG4J2-443. Thanks to Colin Froggatt, Tudor Har. |
rpopma |
|
Fixed issue where toString methods that perform logging could deadlock AsyncAppender. Fixes LOG4J2-485. |
rpopma |
|
ResolverUtil cannot find packages in file URLs which include the '+' character. Fixes LOG4J2-445. Thanks to Anthony Baldocchi. |
rpopma |
|
Use the formatted Message in RFC5424Layout for non-StructuredDataMessages. Fixes LOG4J2-430. Thanks to David Gstir. |
rgoers |
|
Set external context when constructing the LoggerContext. Fixes LOG4J2-459. |
rgoers |
|
Cannot load log4j2 config file if path contains plus '+' characters. Fixes LOG4J2-466. Thanks to Jan Tepke. |
rpopma |
|
Fix LogEvent to never return null Level, fixes LevelPatternConverter.format may throw NPE. Fixes LOG4J2-462. Thanks to Daisuke Baba. |
rpopma |
|
Fix LogEvent to never return null Level, fixes ThresholdFilter throws NPE. Fixes LOG4J2-465. Thanks to Daisuke Baba. |
rpopma |
|
Fixed issue where toString methods that perform logging could deadlock AsyncLogger. Fixes LOG4J2-471. Thanks to Anthony Baldocchi. |
rpopma |
|
Documentation fix: The attribute of Route to refer to an appender is "ref" not "AppenderRef". Fixes LOG4J2-482. Thanks to Hongdi Ren. |
rpopma |
|
Added option to toggle Thread name caching in AsyncLogger. Fixes LOG4J2-467. Thanks to Anthony Baldocchi. |
rpopma |
|
The message and ndc fields are not JavaScript escaped in JSONLayout. Fixes LOG4J2-478. Thanks to Michael Friedmann.. |
ggregory |
|
RingBufferLogEvent should return Message timestamp for TimestampMessage messages. Fixes LOG4J2-455. Thanks to Robin Zhang Tao. |
rpopma |
|
NPE in ClassLoaderContextSelector. Fixes LOG4J2-477. Thanks to Tal Liron. |
rpopma |
|
TimeBasedTriggeringPolicy should use event time millis. Fixes LOG4J2-454. Thanks to Robin Zhang Tao. |
rpopma |
|
BaseConfiguration class does not properly implement Configuration interface. Fixes LOG4J2-472. Thanks to Tal Liron. |
rpopma |
|
XMLLayout does not include marker name. Fixes LOG4J2-447. Thanks to Jeff Hudren, Mark Paluch, Scott Deboy. |
ggregory |
|
Update Flume Appender to use Flume 1.4.0. Fixes LOG4J2-453. |
rgoers |
|
(JMX) Added MBeans for instrumenting AsyncAppenders and AsyncLogger RingBuffers,
exposing queue size, remaining capacity and other attributes. Fixes LOG4J2-423. |
rpopma |
|
Resolved memory leak by releasing reference to ThreadLocal when
AsyncLogger is stopped. Fixes LOG4J2-323. |
rpopma |
|
Resolved memory leak by populating AsyncLoggerConfigHelper ring buffer
via EventTranslatorTwoArg, eliminating the need for a ThreadLocal. Fixes LOG4J2-425. |
rpopma |
|
Create a lookup for resource bundle substitution. Fixes LOG4J2-420. |
ggregory |
|
Fix Event Level / LoggerConfig Level table at the architecture documentation page. Fixes LOG4J2-417. |
ggregory |
|
Format log event time as UNIX time (seconds or milliseconds). Fixes LOG4J2-415. |
ggregory |
|
@EnterpriseNumber" was missing in the ID of structured data when RFC5424Layout is used. Fixes LOG4J2-404. Thanks to Kamal Bahadur. |
rgoers |
|
Fixed issue that prevented Log4J from working in Google App Engine. Fixes LOG4J2-379. |
rpopma |
|
Configure FileAppender buffer size. Fixes LOG4J2-401. |
ggregory |
|
Configure RandomAccessFileAppender buffer size. Fixes LOG4J2-402. |
ggregory |
|
Rename package org.apache.logging.log4j.core.appender.rolling.helper to org.apache.logging.log4j.core.appender.rolling.action. Fixes LOG4J2-528. |
ggregory |
|
Resource leak in Flume appender when it cannot create a BerkeleyDB db. Fixes LOG4J2-532. |
ggregory |
|
PatternLayout option to not output ANSI escape codes if no Console is available. Fixes LOG4J2-413. |
ggregory |
Release 2.0-beta9 – 2013-09-14
Type |
Changes |
By |
|
Renamed FastFileAppender and FastRollingFileAppender to RandomAccessFileAppender
and RollingRandomAccessFileAppender. Configurations using the Fast(Rolling)File element
no longer work and should be modified to use the (Rolling)RandomAccessFile element. Fixes LOG4J2-317. |
ggregory |
|
Changed the "suppressExceptions" configuration attribute for all Appenders to "ignoreExceptions" to avoid
confusion with Java 7 suppressed exceptions. Also renamed the Appender#isExceptionSuppressed() method to
Appender#ignoreExceptions() to avoid the same confusion. All Appenders by default internally log and then ignore
exceptions encountered while logging. Setting "ignoreExceptions" to "false" on an Appender causes it to allow
exceptions to propagate to the caller. You must set "ignoreExceptions" to "false" for Appenders you are wrapping
in the Failover Appender. |
nickwilliams |
|
Changed the (relatively new) PatternLayout configuration attribute "suppressExceptions" to
"alwaysWriteExceptions" to more correctly indicate what it does. As such, the meaning of this attribute has
reversed (previous "true"s should become "false"s, and vice versa). Since this was an undocumented attribute up
until now, it's unlikely this change will affect any users. |
nickwilliams |
|
Fix table of contents generation in pdf. Fixes LOG4J2-226. |
rgoers |
|
Allow classpath scheme when specifying configuration file location as a system property. Fixes LOG4J2-395. Thanks to Abhinav Shah. |
rgoers |
|
Initialize PluginManager once during configuration. Move advertisement setup into BaseConfiguration. Fixes LOG4J2-393. |
rgoers |
|
FlumePersistentManager now handles LockConflictExceptions in Berkeley Db. Fixes LOG4J2-391. Thanks to Kamal Bahadur. |
rgoers |
|
Allow the default file rollover strategy to define the compression level. Fixes LOG4J2-399. |
ggregory |
|
Add TLSAppender. Also added missing license headers to several files. Fixes LOG4J2-338. Thanks to Tibor Benke. |
rgoers |
|
Use rollover date when substituting ${date} in the filePattern. Fixes LOG4J2-380. |
rgoers |
|
Added FAQ page to the site. Fixes LOG4J2-253. |
rpopma |
|
Add a diagram to the site (FAQ page) that explains when to use which jar. Fixes LOG4J2-362. |
rpopma |
|
Centralized reflective use of Reflection#getCallerClass and properly handled its instability in various versions
of Java. Fixes LOG4J2-322. |
nickwilliams |
|
Reset the Configuration if the ClassLoaderContextSelector creates a LoggerContext without a configuration
location and then is later provided one. Fixes LOG4J2-293. |
rgoers |
|
Changed the ConfigurationFactory to recognize and properly use the classpath: URI scheme in addition to the
classloader: URI scheme. Fixes LOG4J2-293. Thanks to Abhinav Shah. |
nickwilliams |
|
Changed the Servlet 3.0 auto-initializer so that it does nothing in a Servlet 2.5 or older application. This
ensures behavioral consistency across containers. Fixes LOG4J2-359. Thanks to Abhinav Shah. |
nickwilliams |
|
Add more options to PatternLayout to display more detailed information about a Throwable. Fixes LOG4J2-374. Thanks to Tibor Benke. |
ggregory |
|
[Pattern Layout] Customize level names by length. Fixes LOG4J2-383. |
ggregory |
|
[Pattern Layout] Customize level names to lower-case. Fixes LOG4J2-384. |
ggregory |
|
Add support for multiple SD-ELEMENTs in a RFC 5424 syslog message. Fixes LOG4J2-355. Thanks to Tibor Benke. |
ggregory |
|
Cleaned up tests and cleared up documentation for the JPA appender following the resolution of EclipseLink
issue #412454. |
nickwilliams |
|
Fixed issue where SMTPAppender did not send mails with error or fatal level without prior info event. Fixes LOG4J2-310. Thanks to Olivier Lemasle. |
rpopma |
|
Add PatternLayout constructor to Log4j 1.2 bridge for Velocity. Fixes LOG4J2-368. |
rgoers |
|
Match artifact ids with Maven module names. Fixes LOG4J2-333. Thanks to Hervé Boutemy. |
ggregory |
|
Add WebLookup to retrieve information from the ServletContext. Fixes LOG4J2-364. Thanks to David Nault. |
rgoers |
|
JMS appenders send two messages for one append. Fixes LOG4J2-367. Thanks to David Parry. |
ggregory |
|
Double stack trace logging when using %throwable in %style and %highlight. Fixes LOG4J2-319. |
ggregory |
|
Allow Plugins to have aliases. Fixes LOG4J2-360. |
rgoers |
|
NoSQLAppender using MongoDB provider ignores username and password attributes. Fixes LOG4J2-358. |
nickwilliams |
|
Create a JSON Layout. Fixes LOG4J2-356. |
ggregory |
|
Removed unnecessary generics from Appender interface and implementing classes. Fixes LOG4J2-343. Thanks to Henning Schmiedehausen. |
rpopma |
|
[OSGi] wrong Fragment-Host in manifest files. Fixes LOG4J2-351. Thanks to Roland Weiglhofer. |
rpopma |
|
AsyncLogger errors after multiple calls to LoggerContext.reconfigure(). Fixes LOG4J2-336. Thanks to Andre Bogus. |
rpopma |
|
Give the AsyncAppender thread a more descriptive name for easier debugging/profiling. Fixes LOG4J2-347. Thanks to David Phillips. |
rpopma |
|
Modified documentation to refer to SLF4J Binding instead of SLF4J Bridge. Fixes LOG4J2-332. Thanks to Hervé Boutemy. |
rgoers |
|
Ignore xml:base attributes. Fixes LOG4J2-342. |
rgoers |
|
Insure jars and distributions only have a single License and Notice file. Fixes LOG4J2-309. |
rgoers |
|
Enable XInclude for XML configurations. Fixes LOG4J2-341. |
ggregory |
|
JPAAppender stops logging because META-INF/log4j-provider.properties is left open. Fixes LOG4J2-320. |
ggregory |
|
FlumePersistentManager's writer thread had high CPU usage. Fixes LOG4J2-335. |
rgoers |
|
Removed erroneous check for affected MongoDB records, which always returns zero on inserts. Fixes LOG4J2-331. |
nickwilliams |
|
Added a BSON Transformer so that MongoDB can persist Log4j events. Fixes LOG4J2-330. |
nickwilliams |
|
StatusLogger now only creates StatusData objects if they are the appropriate logging level. Fixes LOG4J2-329. |
rgoers |
|
FlumePersistentManager was calling Berkeley DB's count method too frequently. Fixes LOG4J2-328. |
rgoers |
|
Additional fix to make AsyncAppender threads daemon threads and improve their thread name. Fixes LOG4J2-280. |
rpopma |
|
The slf4j-ext jar is now an optional dependency of the SLF4J bridge. Fixes LOG4J2-165. |
rgoers |
|
Allow shutdown hook to be disabled in the configuration. Fixes LOG4J2-318. |
rgoers |
|
RoutingAppender's default Route can now be an appender reference. Fixes LOG4J2-166. |
rgoers |
|
Add JNDILookup plugin. Fixes LOG4J2-313. Thanks to Woonsan Ko. |
rgoers |
|
Add getThrowable method to ThrowableProxy. Fixes LOG4J2-299. |
rgoers |
|
ThrowableProxy no longer extends Throwable. Fixes LOG4J2-216. |
rgoers |
|
Synchronized flush() and close() methods in the XxxFileManager and OutputStreamManager classes. Fixes LOG4J2-311. |
rpopma |
|
XML layout improvements (compact vs. pretty, namespace, namespace prefix, root element). Fixes LOG4J2-312. |
ggregory |
|
Update Java Mail dependency to 1.5.0 from 1.4.7. Fixes LOG4J2-388. |
ggregory |
|
Update JDBC tests to use H2 database 1.3.173 from 1.3.172. Fixes LOG4J2-325. |
ggregory |
|
Update commons-logging to 1.1.3 from 1.1.1. Fixes LOG4J2-366. |
ggregory |
|
Update HSQLDB dependency to 2.3.0 from 2.2.9. Fixes LOG4J2-390. |
ggregory |
|
Clarified which library versions were used in Async Loggers performance test. Fixes LOG4J2-308. |
rpopma |
|
Updated Async Loggers' LMAX Disruptor library from 3.0.1 to 3.2.0. Fixes LOG4J2-307. |
rpopma |
|
Update JSON Jackson library to 2.2.2 from 2.2.1. Fixes LOG4J2-306. |
ggregory |
|
Update Jackson dependency to 1.9.13 from 1.9.11. Fixes LOG4J2-387. |
ggregory |
|
Ease porting from 1.x Logger.getRootLogger(): add LogManager.getRootLogger(). Fixes LOG4J2-305. |
ggregory |
|
Fixed Async Loggers memory leak. Fixes LOG4J2-304. |
rpopma |
|
Fixed JDBC, JPA, and NoSQL appenders so that the failover appender properly fails over on error. Fixes LOG4J2-291. |
nickwilliams |
|
Improved site by adding quick jump-off page and menu for Javadoc links for all components. |
nickwilliams |
|
Logger.info(Message) Javadoc is incorrect. Fixes LOG4J2-397. Thanks to Yonatan Graber. |
ggregory |
Release 2.0-beta8 – 2013-07-10
Type |
Changes |
By |
|
Improved logging initialization in Servlet containers, especially Servlet 3.0 and newer where Log4j now
initializes and deinitializes automatically with no deployment descriptor configuration. Fixes LOG4J2-270. |
nickwilliams |
|
Added toString methods to ThreadContextStack/Map implementation classes. Fixes LOG4J2-302. |
rpopma |
|
Add printf methods to Logger API. Fixes LOG4J2-301. |
rgoers |
|
WriterThread was ending when no agents are available which caused an OutOfMemoryError. Fixes LOG4J2-300. |
rgoers |
|
Allow the default status level to be specified as a system property. Fixes LOG4J2-282. |
rgoers |
|
Filter calls from Avro or Flume to be ignored by the FlumeAppender. Fixes LOG4J2-278. |
rgoers |
|
FlumePersistentManager now calls Berkeley DB from threads to avoid encountering interrupts in the application. Fixes LOG4J2-279. |
rgoers |
|
Wasted work in FlumePersistentManager.createManager. Fixes LOG4J2-296. |
ggregory |
|
Wasted work in TestConfigurator.testEnvironment. Fixes LOG4J2-297. |
ggregory |
|
Wasted work in StyleConverterTest.setupClass. Fixes LOG4J2-298. |
ggregory |
|
AsyncLogger threads are now daemon threads and won't prevent the JVM from shutting down anymore. Fixes LOG4J2-280. |
rpopma |
|
Fast(Rolling)FileAppender now correctly handles messages exceeding the buffer size. Fixes LOG4J2-295. |
rpopma |
|
FastRollingFileAppender with TimeBasedTriggeringPolicy now works correctly if append=false. Fixes LOG4J2-271. |
rpopma |
|
FastRollingFileAppender with TimeBasedTriggeringPolicy now works correctly if append=false. Fixes LOG4J2-267. |
rpopma |
|
Fast(Rolling)FileAppender now correctly appends to (does not overwrite) existing file. Fixes LOG4J2-292. |
rpopma |
|
LogManager.getLogger can now be called without a logger name or with a null logger name. Fixes LOG4J2-294. |
rgoers |
|
Upgrade javadoc plugin to 2.9.1 to fix javadoc security issue. Fixes LOG4J2-289. |
rgoers |
|
Update JUnit to 4.11 from 4.7. Fixes LOG4J2-288. |
gregory |
|
Update test H2 JDBC driver to 1.172 from 1.171. Fixes LOG4J2-286. |
gregory |
|
Update Jansi jar to 1.11 from 1.9. Fixes LOG4J2-285. |
gregory |
|
Update Log4j 1 dependency to 1.2.17 from 1.2.16. Fixes LOG4J2-284. |
gregory |
|
Update NoSQL dependencies: lightcouch 0.0.6 from 0.0.5, mongodb 2.11.2 from 2.11.1. Fixes LOG4J2-386. |
gregory |
|
Remove dependency on Apache ORO jar. Fixes LOG4J2-283. |
gregory |
|
Wasted work in RollingAppenderSizeTest.testAppender() and others. Fixes LOG4J2-277. |
gregory |
|
Fix NullPointerException (regression due to fix for LOG4J2-228). Fixes LOG4J2-139. |
rgoers |
|
Include arbitrary message fields in RFC-5424 structured data. Fixes LOG4J2-168. Thanks to Scott Severtson. |
rgoers |
|
FlumeAvroManager fails to notify client of failing event if Flume RPCClient cannot be created. Fixes LOG4J2-275. |
rgoers |
|
Wasted work in UUIDUtil initialization. Fixes LOG4J2-274. |
ggregory |
|
Wasted work in XMLLayout.toSerializable(). Fixes LOG4J2-273. |
ggregory |
Release 2.0-beta7 – 2013-06-01
Type |
Changes |
By |
|
Allow context parameters in Log4jContextListener to include properties. Fixes LOG4J2-249. |
rgoers |
|
Do not allow a charset on RFC5424Layout - use UTF-8. Fixes LOG4J2-263. |
rgoers |
|
StringFormattedMessage and MessageFormatMessage now will accept a Throwable as their last argument and
pass it on. Fixes LOG4J2-242. |
rgoers |
|
Allow custom LogEventFactories. Fixes LOG4J2-243. |
rgoers |
|
Add support for interceptors in the embedded Flume Appender. Fixes LOG4J2-262. Thanks to Edward Sargisson. |
rgoers |
|
Use transaction when batch size is 1. Fixes LOG4J2-269. |
rgoers |
|
Add guid to FlumeEvent headers for non-Map Messages. Fixes LOG4J2-268. |
rgoers |
|
Data buffer is reset in finally clause. Fixes LOG4J2-246. |
rgoers |
|
UDP now sends one event per packet. Fixes LOG4J2-228. |
rgoers |
|
Method name changes in interface org.apache.logging.log4j.spi.ThreadContextMap:
getContext() to getCopy(), get() to getImmutableMapOrNull(). |
rpopma |
|
Improve ThreadContext performance with copy-on-write map and stack. Fixes LOG4J2-154. |
rpopma |
|
Add missing "not" to error message. Fixes LOG4J2-261. Thanks to Edward Sargisson. |
rgoers |
|
Break up core into multiple osgi jars. Fixes LOG4J2-10. Thanks to Timothy Ward. |
rgoers |
|
Remove LoggerContext when LoggerContext is stopped. Fixes LOG4J2-223. |
rgoers |
|
XML layout does not specify charset in content type. Fixes LOG4J2-260. |
ggregory |
|
HTML layout does not specify charset in content type. Fixes LOG4J2-259. |
ggregory |
|
HTML layout does not output meta element for charset. Fixes LOG4J2-258. |
ggregory |
|
XML layout ignores charset for the XML processing instruction's encoding attribute. Fixes LOG4J2-257. |
ggregory |
|
Multi-byte character strings are now assumed to be in the platform default encoding, not UTF-8. Fixes LOG4J2-255. |
rpopma |
|
Mark OutputStream in OutputStreamManager as volatile. Mark header and footer as final. Fixes LOG4J2-254. |
rgoers |
|
Rewrite Appender was ignoring filters on referenced appenders. Fixes LOG4J2-244. |
rgoers |
|
Avoid EmptyStack exception if getCallerClass and SecurityManager are not available. Fixes LOG4J2-245. |
rgoers |
|
New JDBC, JPA, and NoSQL database Appenders. Fixes LOG4J2-229. Thanks to Nick Williams. |
ggregory |
|
SocketServer.isActive should be volatile because it is accessed from different threads. Fixes LOG4J2-247. |
ggregory |
|
Provide configuration information (location, content type, content if possible) via a registered Advertiser. Fixes LOG4J2-251. |
sdeboy |
Release 2.0-beta6 – 2013-05-05
Type |
Changes |
By |
|
Logger.getParent() was not returning the correct Logger. Fixes LOG4J2-231. |
rgoers |
|
Renamed Plugin annotation attribute from "type" to "category". Fixes LOG4J2-201. |
rgoers |
|
Moved JMX Client GUI classes into separate jmx-gui submodule. Fixes LOG4J2-237. |
rpopma |
|
Fix: install default root logger if not configured (this is unchanged),
but make sure to include configured named loggers. Clarified documentation. Fixes LOG4J2-219. Thanks to Peter DePasquale. |
rpopma |
|
Use OSGi version format in Fragment-Host. Fixes LOG4J2-159. |
rgoers |
|
RegexFilter threw a NullPointerException when used as a context-wide filter. Fixes LOG4J2-234. |
rgoers |
|
Add support for interpolating Environment variables when processing the configuration. Fixes LOG4J2-192. |
rgoers |
|
Removed dependency on tools jar from core module, made jconsole dependency optional. Fixes LOG4J2-235. Thanks to Sebastian Oerding. |
rpopma |
|
Fixed link to log4j-user mailing list. Fixes LOG4J2-233. |
rpopma |
|
Improved error reporting when misconfigured. Fixes LOG4J2-230. Thanks to Wojciech Zaręba. |
rpopma |
|
Disruptor will now shutdown during Tomcat shutdown. Fixes LOG4J2-222. Thanks to Steven Yang. |
rgoers |
|
Renamed AsynchAppender to AsyncAppender. Plugin name became Async (was Asynch). |
rpopma |
|
Removed CheckStyle false positives for NewlineAtEndOfFile and whitespace following '*' at end of line in javadoc. |
rpopma |
|
Moved Clock interface to package org.apache.logging.log4j.core.helpers. |
rpopma |
|
Documentation updates to clarify use and impact of location in pattern layouts. Fixes LOG4J2-225. |
rpopma |
|
The FlumeAppender failed to start if the Flume RPCClient could not connect to any Flume agents. Fixes LOG4J2-224. |
rgoers |
|
Fix LoggerContext start and stop to eliminate IllegalStateException and NoClassDefFound errors. Fixes LOG4J2-223. |
rgoers |
|
Remove hundreds of compiler warnings. Fixes LOG4J2-221. Thanks to Nick Williams. |
rgoers |
|
Various small documentation fixes. Fixes LOG4J2-215. |
rpopma |
|
Ensure PluginManager streams are always closed. Fixes LOG4J2-217. Thanks to Fabien Sanglard. |
rpopma |
Release 2.0-beta5 – 2013-04-20
Type |
Changes |
By |
|
Fix deadlock in SocketAppender. Added option to not wait for socket reconnect. Fixes LOG4J2-205. |
rgoers |
|
Add JMX support. Fixes LOG4J2-207. Thanks to Remko Popma. |
rgoers |
|
Removing extra spaces in entry and exit method output. Fixes LOG4J2-211. Thanks to Nick Williams. |
rgoers |
|
Async documentation update. Fixes LOG4J2-214. Thanks to Remko Popma. |
rgoers |
|
Loggers without a "." had no parent logger. Fixes LOG4J2-212. |
rgoers |
|
Move async subproject into core. Fixes LOG4J2-208. Thanks to Remko Popma. |
rgoers |
|
Call LoggerContext.stop when the application is shutdown. Fixes LOG4J2-212. |
rgoers |
|
MapMessage was not enclosing key value in quotes when generating XML. Fixes LOG4J2-210. Thanks to Arkin Yetis. |
rgoers |
|
FlumeAvroManager now uses Flume RPCClient. Fixes LOG4J2-198. |
rgoers |
|
FlumeAvroManager now uses Flume RPCClient. Fixes LOG4J2-196. |
rgoers |
|
Use the Maven group ID org.apache.logging.log4j for all artifacts. Fixes LOG4J2-207. |
ggregory |
|
Add tag library. Fixes LOG4J2-187. Thanks to Nick Williams. |
rgoers |
|
Unit tests now create files in the target directory. Fixes LOG4J2-195. Thanks to Remko Popma. |
rgoers |
|
RollingFastFileAppender (in log4j-async) did not roll over. Fixes LOG4J2-193. Thanks to Remko Popma. |
rgoers |
|
Highlight subprojects in sub-navigation. Fixes LOG4J2-199. Thanks to Remko Popma. |
rgoers |
|
LoggerContext method renamed to removeFilter from removeFiler. Fixes LOG4J2-200. Thanks to Remko Popma. |
rgoers |
|
ThrowableFormatOptionsTest failed on Windows due to CR/LF issue. Fixes LOG4J2-194. Thanks to Remko Popma. |
rgoers |
|
BaseConfiguration addLoggerAppender saved appender using the Logger name. Fixes LOG4J2-190. Thanks to Werner. |
rgoers |
|
Move Throwable pattern converter options processing to ThrowableFormatOptions class. Fixes LOG4J2-160. Thanks to Joanne Polsky. |
rgoers |
|
Allowed Loggers access to the properties in the LoggerConfig. Fixes LOG4J2-157. Thanks to Remko Popma. |
rgoers |
|
Added ability to include or exclude location information. Fixes LOG4J2-153. Thanks to Remko Popma. |
rgoers |
|
Allow Logger and LoggerContext to be subclassed. Fixes LOG4J2-151. Thanks to Remko Popma. |
rgoers |
|
Add methods is/setEndOfBatch to LogEvent. Fixes LOG4J2-164. Thanks to Remko Popma. |
rgoers |
|
Add support for asynchronous loggers. Fixes LOG4J2-163. Thanks to Remko Popma. |
rgoers |
|
The blocking parameter did not work properly on AsynchAppender. Fixes LOG4J2-189. Thanks to Werner. |
rgoers |
|
AppenderRefs on AsynchAppender didn't support the level and filter elements. Fixes LOG4J2-188. Thanks to Werner. |
rgoers |
|
Avoid IllegalArgumentException in AsynchAppender. Fixes LOG4J2-176. Thanks to Remko Popma. |
rgoers |
|
Add Logger interface APIs to log at given levels. Fixes LOG4J2-179. |
ggregory |
|
OutputStreamManager now adds the layout header whenever the OutputStream is set. Fixes LOG4J2-181. |
rgoers |
|
Fix NullPointerException in DatagramOutputStream when flush is called from multiple threads. Fixes LOG4J2-177. Thanks to Remko Popma. |
rgoers |
|
Added FlumePersistentManager which writes to BerkeleyDB and then writes to Flume asynchronously. |
rgoers |
|
Plugin cache should be reset when addPackages is called. Fixes LOG4J2-175. |
sdeboy |
|
Expose file appender configuration details via an advertisement mechanism. Fixes LOG4J2-155. |
sdeboy |
|
Add Fragment-Host to MANIFEST.MF for log4j-core. Fixes LOG4J2-159. Thanks to Jan Winter. |
rgoers |
|
Configurator throws a ClassCastException if LogManager returns a SimpleLoggerContext. Fixes LOG4J2-167. |
rgoers |
|
ConfigurationFactory was adding factories on every call. Fixes LOG4J2-169. |
rgoers |
|
Modify ClassLoaderContextSelector to use the first ClassLoader in the child parent hierarchy that
has a Context with a configuration to allow JSPs to use the WebApp's context and configuration. Fixes LOG4J2-161. |
rgoers |
|
Add RFC 5424 compliant escaping rules to RFC5424Layout. Fixes LOG4J2-158. Thanks to Scott Severtson. |
rgoers |
Release 2.0-beta4 – 2013-01-28
Type |
Changes |
By |
|
LocalizedMessageTest fails on linux system. Fixes LOG4J2-156. Thanks to Andreas Born. |
ggregory |
|
RollingFileAppender's FileRenameAction was throwing a NullPointerException if no directory was specified
on the target file name. Fixes LOG4J2-152. Thanks to Remko Popma. |
rgoers |
|
Convert all System.getProperty calls to use PropertiesUtil to suppress SecurityExceptions. Fixes LOG4J2-150. |
rgoers |
|
ThreadContextMapFilter was matching on the key instead of the value of the key. Fixes LOG4J2-147. Thanks to William Burns. |
rgoers |
|
Allow FlumeAvroManager to initialize even if it cannot connect to an agent. |
rgoers |
|
SMTPAppender will only cache filtered events. Fixes LOG4J2-149. Thanks to Scott Severtson. |
rgoers |
|
Add missing serial version IDs. Fixes LOG4J2-145. |
ggregory |
|
NullPointerException in RFC5424Layout. Fixes LOG4J2-144. |
ggregory |
|
MessagePatternConverter now returns "null" if the log message is null. Fixes LOG4J2-143. |
rgoers |
|
Serialized LogEvents were not reset in the output stream causing them to deserialize incorrectly. Fixes LOG4J2-142. |
rgoers |
|
Fix null pointer exception in SocketAppender if no protocol is specified. The protocol will default
to TCP for the SocketAppender and UDP for the SyslogAppender. Fixes LOG4J2-139. |
rgoers |
|
Added Log4j 2 to SLF4J adapter. |
rgoers |
|
Typo in documentation of SocketAppender. Fixes LOG4J2-140. Thanks to Joern Huxhorn. |
ggregory |
|
Fix hang in Dumbster SMTP test server. Fixes LOG4J2-137. |
rgoers |
|
Allow newlines to be escaped in Syslog and RFC5424 layouts. Allow Throwables to be included in
the output from RFC5424Layout. Fixes LOG4J2-136. Thanks to Scott Severtson. |
rgoers |
|
Add SMTPAppender. Fixes LOG4J2-131. Thanks to Scott Severtson. |
rgoers |
|
PatternLayout should format throwables without requiring a converter. Fixes LOG4J2-130. |
rgoers |
|
Added hostName and contextName to property map. |
rgoers |
|
BaseConfiguration does not close the first appender. Fixes LOG4J2-135. Thanks to Ingo Feltes. |
ggregory |
|
Add MessageFormatMessage and FormattedMessage. |
rgoers |
|
Use %red, %white, %blue, and so on in the console appender. Fixes LOG4J2-134. |
ggregory |
|
Allow custom message creation via a message factory. Fixes LOG4J2-133. |
ggregory |
|
AbstractLogger.catching(Throwable) checks for DEBUG level but logs at ERROR level. Fixes LOG4J2-132. |
ggregory |
|
RoutingAppender was only creating a single appender for the default Route. Fixes LOG4J2-129. |
rgoers |
|
Allow JMS appenders to recover if the queue or topic is unavailable. Fixes LOG4J2-126. |
rgoers |
|
Add follow attribute to Console Appender. Fixes LOG4J2-128. |
rgoers |
|
AbstractLogger methods were not passing Markers to the isEnabled methods. Fixes LOG4J2-127. |
rgoers |
|
Added Flume Appender samples. |
rgoers |
|
Add unit test to verify exceptions are thrown when the socket connection fails. Fixes LOG4J2-122. |
rgoers |
|
JMSQueue and JMSTopic Appenders did not allow name to be specified. Fixes LOG4J2-125. |
rgoers |
|
Enhanced javadoc copyright statement. Fixes LOG4J2-111. |
rgoers |
|
Renamed log4j12-api to log4j-1.2-api. Fixes LOG4J2-110. |
rgoers |
|
TCPSocketManager would fail if the initial connection could not be established. Fixes LOG4J2-120. |
rgoers |
|
A broken socket connection would cause the TCPSocketManager to continuously reconnect. Fixes LOG4J2-119. |
rgoers |
|
The example for ThreadContextMapFilter was incorrect. Fixes LOG4J2-123. Thanks to Olivier Lamy. |
rgoers |
|
File renaming was using the wrong date value. Enhanced DefaultRolloverStrategy to store newest files in
highest index as well as lowest. Fixes LOG4J2-116. |
rgoers |
|
ThreadContext Map elements with null values are now ignored when constructing a Flume event and in the
RFC5424 Layout. Fixes LOG4J2-115. |
rgoers |
|
StructuredDataFilter createFilter was annotated with PluginAttr instead of PluginElement for the
KeyValuePairs. Fixes LOG4J2-113. |
rgoers |
|
StructuredDataMessage was validating the length of the values in the event Map instead of the lengths
of the keys. Fixes LOG4J2-114. Thanks to Arkin Yetis. |
rgoers |
Release 2.0-beta3 – 2012-11-11
Type |
Changes |
By |
|
Fix NullPointerException in ClassLoaderContextSelector when no class is returned from
the SecurityManager. Fixes LOG4J2-108. |
rgoers |
|
Add ability to customize the names of the Levels in the LevelPatternConverter. Fixes LOG4J2-105. |
rgoers |
|
PatternParser was not properly handling adjacent nested options. Fixes LOG4J2-107. |
rgoers |
|
Add support for loading plugins inside the OSGi bundle. Fixes LOG4J2-95. |
rgoers |
|
Add ThreadContext.push(String format, Object... args). Fixes LOG4J2-85. |
rgoers |
|
The LogEvent was wrapping a ThrowableProxy with another ThrowableProxy when deserializing. Fixes LOG4J2-103. Thanks to Das Archive. |
rgoers |
|
Created combined jar to combine API and Core contents for users who only want the Log4j implementation. |
rgoers |
|
Convert LogManager binding to use "regular" java properties instead of XML properties to workaround a
bug in Oracle's xmlparserv2 jar. Fixes LOG4J2-104. |
rgoers |
|
Added PropertiesRewritePolicy and ability to define properties on a Logger. Fixes LOG4J2-28. |
rgoers |
|
Build pdf of user's guide. Fixes LOG4J2-87. |
rgoers |
|
Added font and fontSize parameters to HTMLLayout. Replace newlines in message with br tag. Fixes LOG4J2-29. |
rgoers |
|
Added ability to configure from an InputSource. Fixes LOG4J2-55. |
rgoers |
|
The Facility value was being improperly calculated. Fixes LOG4J2-102. Thanks to Emanuele Colombo. |
rgoers |
|
A NullPointerException would occur if no format value was passed to the SyslogAppender. Fixes LOG4J2-101. Thanks to Emanuele Colombo. |
rgoers |
|
MapRewritePolicy had an extra call to putAll that caused updates to behave like adds. Fixes LOG4J2-99. Thanks to Das Archive. |
rgoers |
|
Avoid NPE when duplicate LoggerContextFactorys are present. Allow factories to specify a weight to allow
real implementations to outrank test implementations. Provide a simple default LoggerContextFactory. |
rgoers |
|
Added several missing classes and methods for Log4j 1.x compatibility. Fixes LOG4J2-97. |
rgoers |
|
Interpolator was not stripping Lookup key separator when trying to locate the default value for a variable. Fixes LOG4J2-94. Thanks to Denis Treskunov. |
rgoers |
|
Log4j 1.2 Category.forcedLog was wrapping the message with an ObjectMessage even if the parameter was an
ObjectMessage. |
rgoers |
Release 2.0-beta2 – 2012-10-07
Type |
Changes |
By |
|
Made ParameterizedMessage, StringFormattedMessage and ThreadDumpMessage immutable. LocalizedMessage is
immutable except that it will be updated with the logger name when it is added to the LogEvent. |
rgoers |
|
DefaultConfiguration was not starting the Console Appender. |
rgoers |
|
Add interval and modulate options to TimeBasedTriggeringPolicy to allow more fine-grained control of
when file rolling should occur. Fixes LOG4J2-35. |
rgoers |
|
Add support for filtering packages from stack traces. Fixes LOG4J2-58. |
rgoers |
|
If system property "disableThreadContextStack" is set pushes to the ThreadContext will be ignored. If
system property "disableThreadContext" is set both puts and pushes will be ignored. Fixes LOG4J2-84. |
rgoers |
|
If system property "disableThreadContextMap" is set puts to the ThreadContext will be ignored. If
system property "disableThreadContext" is set both puts and pushes will be ignored. Fixes LOG4J2-83. |
rgoers |
|
Add support for ANSI colors by adding the highlight and style pattern converters. Fix pattern
parsing to allow nested patterns. |
rgoers |
|
Converted DynamicThresholdFilter to use KeyValuePair. Fixed bugs in the Map-based filters
to allow declaration of multiple values for a key to match the documentation. Fixes LOG4J2-92. |
rgoers |
|
Many logging methods in AbstractLogger were set to an incorrect logging level. catching was
using the THROWING marker and was set to debug instead of error. Fixes LOG4J2-88. |
rgoers |
|
Allow the status logging to be directed to stderr or to a file. |
rgoers |
|
Log4j 1.2 adapter's Category class was missing 3 log methods. Fixes LOG4J2-91. |
rgoers |
|
If the ThreadContext stack is empty the LogEvent will contain a null value to reduce the overhead of
creating log events and in the size of the serialized object. Changed the ThreadContext stack to use
a custom stack interface instead of java.util.Stack as that class is overly heavy. This change will
cause an API incompatibility. Fixes LOG4J2-84. |
rgoers |
|
If the ThreadContext map is empty the LogEvent will contain a null value to reduce the overhead of creating
log events and in the size of the serialized object. Fixes LOG4J2-83. |
rgoers |
|
Add getFormats to MultiformatMessage and allow StructuredDataMessage to format as XML. |
rgoers |
|
Add documentation on client vs server mode to performance page. Fixes LOG4J2-90. |
rgoers |
|
Move variable substitution from PatternLayout to appropriate converters to improve performance. |
rgoers |
Release 2.0-beta1 – 2012-09-18
Type |
Changes |
By |
|
Added AsynchAppender. |
rgoers |
|
PatternLayout was not honoring format modifiers. Fixes LOG4J-81. |
rgoers |
|
Created web module to allow web applications to include the Log4j context listener in WEB-INF/lib even if
Log4j is in the container's class path. Allow locating the LoggerContext to include the ClassLoader. Updated
the Loader utility to always choose the child ClassLoader. Verified in Jboss 5 and Tomcat. |
rgoers |
|
MarkerFilter called MarkerManager.getMarker causing the Marker to be created during the processing of the
configuration. This prevents the application from creating the Marker with any parents. MarkerWrapper in
SLF4J-impl was getting a ClassCastException in instanceOf because the Marker isn't a MarkerWrapper. Fixes LOG4J2-82. |
rgoers |
|
Allow Log4j 2 to be used as the implementation with SLF4J and SLF4J's jcl-over-slf4j by adding filtering
to the log method in SLF4JLogger. Fixes LOG4J2-80. Thanks to Oliver Lamy. |
rgoers |
|
LogFactoryImpl.setAttribute in the Commons Logging bridge got a NullPointerException when passed a null value.
It will now remove the attribute. Fixes LOG4J2-78. |
rgoers |
|
RoutingAppender was calling the stop method for each of its referenced Appenders and was calling
the stop method of the default Appender a second time. It will now only call the stop method of
Appenders it creates. Fixes LOG4J2-77. |
rgoers |
|
RewriteAppender was calling the stop method of the referenced appender causing the referenced appender's
manager to have its use count decremented too many times. Fixes LOG4J2-76. |
rgoers |
|
Logger.error(Marker, Message, Throwable) was internally using Level.TRACE. Fixes LOG4J2-74. |
rgoers |
|
Enhanced Log4jContextListener to accept a configuration file location. Modified FileConfigurationMonitor
to monitor files configured that way. Fixed other reconfiguration related bugs. Tested in JBoss and
Tomcat. Fixes LOG4J2-75. |
rgoers |
|
NullPointerException in RollingFileManager when filePattern does not cause the file to be compressed. Fixes LOG4J2-72. |
rgoers |
|
FileRenameAction did not create the parent directories of the archive files causing the rollover to fail. Fixes LOG4J2-71. |
rgoers |
|
Update the versions of SLF4J and Logback. |
rgoers |
Release 2.0-alpha2 – 2012-08-24
Type |
Changes |
By |
|
Add getLogger(Class) to LogManager. Fixes LOG4J2-70. |
rgoers |
|
Allow Flume agents to be embedded into the Flume Appender. Fixes LOG4J2-69. |
rgoers |
|
Add support for formatting using String.format(). Fixes LOG4J2-68. |
rgoers |
|
Allow components besides core to create a PluginMap for faster plugin loading and not
having to specify the plugin package in the configuration. Fixes LOG4J2-67. |
rgoers |
|
Fix compilation problems in Java 7. Fixes LOG4J2-64. |
rgoers |
|
Allow variable substitution on the configuration attributes and on the root log level. Fixes LOG4J2-65. |
rgoers |
Release 2.0-alpha1 – 2012-07-29
Type |
Changes |
By |
|
Added ability to filter on the AppenderRef by adding either a level or a filter. Fixes LOG4J2-60. Thanks to Shane Kelly. |
rgoers |
|
Level.toLevel would throw an IllegalArgumentException instead of returning the default value. Fixes LOG4J2-56. Thanks to John Owen Atala. |
rgoers |
|
Remove LoggerContext support for custom logger factories. All Loggers returned
by LoggerContext should be compatible and of the same type. Fixes LOG4J2-51. Thanks to John Vasileff. |
rgoers |
|
Make sure all application facing log methods use their own FQCN. This patch
resolves a unit test failure for the %C pattern when using the Category logger. Fixes LOG4J2-50. Thanks to John Vasileff. |
rgoers |
|