We are currently using Tomcat 7 with a single log configuration specified using -Djava.util.logging.config.file and the default ClassLoaderLogManager with -Djava.util.logging.manager="org.apache.juli.ClassLoaderLogManager". This works great for a one-time startup config.
We have several servlets and other code that runs outside the servlet context. We run on a dedicated tomcat server that we completely control, and we want all the code to use the same log configuration. We are using the java.util.logging API for logging. This means that LogManager.getLogManager().getLogger(name) needs to work, and that Logger.isLoggable(Level) needs to work.
ClassLoaderLogManager seems geared towards the opposite of our situation: allowing servlets to specify individual log settings. We want all the logs controlled in one place. But, we do want the other JULI benefits like the improved FileHandlers.
Now the question: How can I reload these settings from the file at runtime without reloading the application?
What I've tried:
- LogManager.getLogManger.readConfiguration(): results in an effective NOOP in ClassLoaderLogManager because Thread.currentThread.getContextClassLoader() isn't the system classloader.
- Explicitly setting Thread.setContextClassLoader(ClassLoader.getSystemClassLoader()) and then calling the above. This did actually read the config file (stepped through in a debugger) but it didn't propagate the changes down to existing loggers in the contained ClassLoaders. Logger.setLevel() was never called on existing loggers.
- also calling reset() before these calls doesn't seem to change anything.
- JMX appears to only expose the loggers for a single ClassLoader (possibly the system ClassLoader)