I use a legacy library that writes logs using log4j. My default log4j.properties file directs the log to the console, but in some specific functions of my main program, I would like to disable logging altogether (from all classes).
I tried this:
Logger.getLogger(BasicImplementation.class.getName()).setLevel(Level.OFF);
where "BasicImplementation" is one of the main classes that does logging, but it didn't work - the logs are still written to the console.
Here is my log4j.properties:
log4j.rootLogger=warn, stdout
log4j.logger.ac.biu.nlp.nlp.engineml=info, logfile
log4j.logger.org.BIU.utils.logging.ExperimentLogger=warn
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %-5p %d{HH:mm:ss} [%t]: %m%n
log4j.appender.logfile = ac.biu.nlp.nlp.log.BackupOlderFileAppender
log4j.appender.logfile.append=false
log4j.appender.logfile.layout = org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern = %-5p %d{HH:mm:ss} [%t]: %m%n
log4j.appender.logfile.File = logfile.log
In the version 1.8 of java.util.logging.Logger the correctly form is:
Logger.getLogger("").setLevel(Level.OFF);
You can use
to disable any logging in java code
So, you have 3 loggers defined, including the root:
Unfortunately, to disable them programatically, you need to specify ALL OF THEM in the code:
Here's how to reset it back to what's set in the config file.
If you wanna achieve perfect silence (like for a quiet command line tool), you can always use the NullAppender.
Perhaps like that:
Logger.getRootLogger().shutdown();
You could try TO disable it changing your log4j.properties:
Ref: http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/Level.html#OFF