We don’t allow questions seeking recommendations for books, tools, software libraries, and more. You can edit the question so it can be answered with facts and citations.
Closed 6 years ago.
Improve this questionThis question gets asked periodically, but I've long felt that existing Java logging frameworks were overcomplicated and over-engineered, and I want to see what's new.
I have a more critical issue on my current project as we've standardized on JSON as our human-readable data encoding, and most logging frameworks I've seen require XML. I would really rather avoid using JSON for 95% of my apps configuration, and XML for the rest just because of the logging framework (truth be told, I hate XML used for anything other than text markup, its original intended purpose).
Are there any hot new Java logging frameworks that are actively maintained, reasonably powerful, have a maven re开发者_StackOverflow中文版po, can be reconfigured without restarting your app, and don't tie you to XML?
You have 3 options:
- Log4J
- java.util.logging (JUL)
- Logback (the successor of Log4J)
Now, let's see how they meet your requirements:
- actively maintained
- reasonably powerful
- have a maven repo
- can be reconfigured without restarting your app
- don't tie you to XML
log4j
:
- No, not actively maintained
- Yes -
- Yes -
- Yes -
- Yes (using Java properties file, see Configuration).
java.util.logging
(JUL):
- I'd say Yes -
- at your discretion -
- N/A -
- Yes (via JMX or
LogManager#readConfiguration()
- - Yes (using properties files)
Logback:
- Yes -
- Yes -
- Yes -
- Yes, via JMX or autoScan -
- Configuration files in XML or Groovy
It looks like you'll have to make some concessions (or find a framework I'm not aware of). I would go for Logback, this is where things happen now.
wasn't logback the latest?
SLF4J is the latest and greatest, as far as I know.
Surely the XML required to configure log4j couldn't be considered oppressive. You might be objecting to XML config in general, but even that's changing. Spring gives the option of using XML or annotations, as do most other frameworks. I think objecting to XML anything other than markup is going too far. Should Ant and NANT shut down because they chose XML? I think not.
While the common configuration method for log4j is xml, you can also configure it programatically, which means you can use any configuration system you want (and also reconfigure it at runtime).
You might want to look into our Java logging tool SmartInspect (it's commercial). SmartInspect is actively maintained, can be configured with two lines of code and supports configuration files that just contain name = value pairs (no XML :)). SmartInspect can also automatically reload configurations files on-the-fly when they are changed - a useful feature for live configuration changes and production systems. SmartInspect also comes with a graphical log analysis and monitoring tool that you might find useful:
(source: gurock.com)
精彩评论