kafka Log4jController 源码
kafka Log4jController 代码
文件路径:/core/src/main/scala/kafka/utils/Log4jController.scala
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package kafka.utils
import java.util
import java.util.Locale
import org.apache.kafka.common.utils.Utils
import org.apache.log4j.{Level, LogManager, Logger}
import scala.collection.mutable
import scala.jdk.CollectionConverters._
object Log4jController {
val ROOT_LOGGER = "root"
private def resolveLevel(logger: Logger): String = {
var name = logger.getName
var level = logger.getLevel
while (level == null) {
val index = name.lastIndexOf(".")
if (index > 0) {
name = name.substring(0, index)
val ancestor = existingLogger(name)
if (ancestor != null) {
level = ancestor.getLevel
}
} else {
level = existingLogger(ROOT_LOGGER).getLevel
}
}
level.toString
}
/**
* Returns a map of the log4j loggers and their assigned log level.
* If a logger does not have a log level assigned, we return the root logger's log level
*/
def loggers: mutable.Map[String, String] = {
val logs = new mutable.HashMap[String, String]()
val rootLoggerLvl = existingLogger(ROOT_LOGGER).getLevel.toString
logs.put(ROOT_LOGGER, rootLoggerLvl)
val loggers = LogManager.getCurrentLoggers
while (loggers.hasMoreElements) {
val logger = loggers.nextElement().asInstanceOf[Logger]
if (logger != null) {
logs.put(logger.getName, resolveLevel(logger))
}
}
logs
}
/**
* Sets the log level of a particular logger
*/
def logLevel(loggerName: String, logLevel: String): Boolean = {
val log = existingLogger(loggerName)
if (!Utils.isBlank(loggerName) && !Utils.isBlank(logLevel) && log != null) {
log.setLevel(Level.toLevel(logLevel.toUpperCase(Locale.ROOT)))
true
}
else false
}
def unsetLogLevel(loggerName: String): Boolean = {
val log = existingLogger(loggerName)
if (!Utils.isBlank(loggerName) && log != null) {
log.setLevel(null)
true
}
else false
}
def loggerExists(loggerName: String): Boolean = existingLogger(loggerName) != null
private def existingLogger(loggerName: String) =
if (loggerName == ROOT_LOGGER)
LogManager.getRootLogger
else LogManager.exists(loggerName)
}
/**
* An MBean that allows the user to dynamically alter log4j levels at runtime.
* The companion object contains the singleton instance of this class and
* registers the MBean. The [[kafka.utils.Logging]] trait forces initialization
* of the companion object.
*/
class Log4jController extends Log4jControllerMBean {
def getLoggers: util.List[String] = {
// we replace scala collection by java collection so mbean client is able to deserialize it without scala library.
new util.ArrayList[String](Log4jController.loggers.map {
case (logger, level) => s"$logger=$level"
}.toSeq.asJava)
}
def getLogLevel(loggerName: String): String = {
val log = Log4jController.existingLogger(loggerName)
if (log != null) {
val level = log.getLevel
if (level != null)
log.getLevel.toString
else
Log4jController.resolveLevel(log)
}
else "No such logger."
}
def setLogLevel(loggerName: String, level: String): Boolean = Log4jController.logLevel(loggerName, level)
}
trait Log4jControllerMBean {
def getLoggers: java.util.List[String]
def getLogLevel(logger: String): String
def setLogLevel(logger: String, level: String): Boolean
}
相关信息
相关文章
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
7、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦