I’m configuring the logging for a Java application. What I’m aiming for is two logs: one for all messages and one for just messages above a certain level.
The app uses the java.util.logging.* classes: I’m using it as is, so I’m limited to configuration through a logging.properties file.
I don’t see a way to configure two FileHandlers differently: the docs and examples I’ve seen set properties like:
java.util.logging.FileHandler.level = INFO
While I want two different Handlers logging at different levels to different files.
Any suggestions?
http://java.sun.com/j2se/1.4.2/docs/guide/util/logging/overview.html is helpful. You can only set one Level for any individual logger (as you can tell from the setLevel() method on the logger). However, you can take the lowest of the two common levels, and then filter programmatically.
Unfortunately, you can’t do this just with the configuration file. To switch with just the configuration file you would have to switch to something like log4j, which you’ve said isn’t an option.
So I would suggest altering the logging in code, with Filters, with something like this:
And then on the second handler, do setFilter(new LevelFilter(Level.INFO)) or whatever. If you want it file configurable you could use a logging properties setting you’ve made up yourself, and use the normal Properties methods.
I think the configuration code for setting up the two file handlers ad the programmatic code is fairly simple once you have the design, but if you want more detail add a comment and I’ll edit.