
org.sonar.server.app.ServerProcessLogging Maven / Gradle / Ivy
/*
* SonarQube
* Copyright (C) 2009-2016 SonarSource SA
* mailto:contact AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.sonar.server.app;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.ConsoleAppender;
import java.util.logging.LogManager;
import org.slf4j.bridge.SLF4JBridgeHandler;
import org.sonar.api.utils.MessageException;
import org.sonar.api.utils.log.LoggerLevel;
import org.sonar.process.LogbackHelper;
import org.sonar.process.Props;
import org.sonar.ce.log.CeLogDenyFilter;
import org.sonar.ce.log.CeLogging;
import org.sonar.server.platform.ServerLogging;
/**
* Configure logback for given server sub process (Web Server or CE). Logs must be written to console, which is
* forwarded to file logs/sonar.log by the app master process.
*/
public class ServerProcessLogging {
private static final String LOG_FORMAT = "%d{yyyy.MM.dd HH:mm:ss} %-5level XXXX[%logger{20}] %msg%n";
private final LogbackHelper helper = new LogbackHelper();
private final String processName;
private final String logLevelProperty;
public ServerProcessLogging(String processName, String logLevelProperty) {
this.processName = processName;
this.logLevelProperty = logLevelProperty;
}
public LoggerContext configure(Props props) {
LoggerContext ctx = helper.getRootContext();
ctx.reset();
helper.enableJulChangePropagation(ctx);
configureAppender(ctx, props);
configureLevels(props);
// Configure java.util.logging, used by Tomcat, in order to forward to slf4j
LogManager.getLogManager().reset();
SLF4JBridgeHandler.install();
return ctx;
}
private void configureAppender(LoggerContext ctx, Props props) {
String logFormat = LOG_FORMAT.replace("XXXX", processName);
ConsoleAppender consoleAppender = helper.newConsoleAppender(ctx, "CONSOLE", logFormat, new CeLogDenyFilter());
ctx.getLogger(Logger.ROOT_LOGGER_NAME).addAppender(consoleAppender);
ctx.getLogger(Logger.ROOT_LOGGER_NAME).addAppender(CeLogging.createAppenderConfiguration(ctx, props));
}
private void configureLevels(Props props) {
String levelCode = props.value(logLevelProperty, "INFO");
LoggerLevel level;
if ("TRACE".equals(levelCode)) {
level = LoggerLevel.TRACE;
} else if ("DEBUG".equals(levelCode)) {
level = LoggerLevel.DEBUG;
} else if ("INFO".equals(levelCode)) {
level = LoggerLevel.INFO;
} else {
throw MessageException.of(String.format("Unsupported log level: %s. Please check property %s", levelCode, logLevelProperty));
}
ServerLogging.configureLevels(helper, level);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy