AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

聊聊SpringBoot的LogbackLoggingSystem

來源: 責編: 時間:2023-11-02 17:14:07 336觀看
導讀序本文主要研究一下springboot的LogbackLoggingSystemLoggingSystemorg/springframework/boot/logging/LoggingSystem.javapublic abstract class LoggingSystem { public abstract void beforeInitialize(); public

本文主要研究一下springboot的LogbackLoggingSystemrXR28資訊網——每日最新資訊28at.com

LoggingSystem

org/springframework/boot/logging/LoggingSystem.javarXR28資訊網——每日最新資訊28at.com

public abstract class LoggingSystem {	public abstract void beforeInitialize();	public void initialize(LoggingInitializationContext initializationContext, String configLocation, LogFile logFile) {	}	public void cleanUp() {	}	public Runnable getShutdownHandler() {		return null;	}	public Set<LogLevel> getSupportedLogLevels() {		return EnumSet.allOf(LogLevel.class);	}	public void setLogLevel(String loggerName, LogLevel level) {		throw new UnsupportedOperationException("Unable to set log level");	}	public List<LoggerConfiguration> getLoggerConfigurations() {		throw new UnsupportedOperationException("Unable to get logger configurations");	}	public LoggerConfiguration getLoggerConfiguration(String loggerName) {		throw new UnsupportedOperationException("Unable to get logger configuration");	}				}

LoggingSystem定義了beforeInitialize抽象方法,需要子類實現,,同時還提供了setLogLevel、getLoggerConfigurations、getLoggerConfiguration,默認是拋出UnsupportedOperationExceptionrXR28資訊網——每日最新資訊28at.com

NoOpLoggingSystem

static class NoOpLoggingSystem extends LoggingSystem {		@Override		public void beforeInitialize() {		}		@Override		public void setLogLevel(String loggerName, LogLevel level) {		}		@Override		public List<LoggerConfiguration> getLoggerConfigurations() {			return Collections.emptyList();		}		@Override		public LoggerConfiguration getLoggerConfiguration(String loggerName) {			return null;		}	}

NoOpLoggingSystem繼承了LoggingSystem,其方法都是空操作rXR28資訊網——每日最新資訊28at.com

AbstractLoggingSystem

org/springframework/boot/logging/AbstractLoggingSystem.javarXR28資訊網——每日最新資訊28at.com

public abstract class AbstractLoggingSystem extends LoggingSystem {	protected static final Comparator<LoggerConfiguration> CONFIGURATION_COMPARATOR = new LoggerConfigurationComparator(			ROOT_LOGGER_NAME);	private final ClassLoader classLoader;	public AbstractLoggingSystem(ClassLoader classLoader) {		this.classLoader = classLoader;	}	@Override	public void beforeInitialize() {	}	@Override	public void initialize(LoggingInitializationContext initializationContext, String configLocation, LogFile logFile) {		if (StringUtils.hasLength(configLocation)) {			initializeWithSpecificConfig(initializationContext, configLocation, logFile);			return;		}		initializeWithConventions(initializationContext, logFile);	}	/**	 * Load sensible defaults for the logging system.	 * @param initializationContext the logging initialization context	 * @param logFile the file to load or {@code null} if no log file is to be written	 */	protected abstract void loadDefaults(LoggingInitializationContext initializationContext, LogFile logFile);	/**	 * Load a specific configuration.	 * @param initializationContext the logging initialization context	 * @param location the location of the configuration to load (never {@code null})	 * @param logFile the file to load or {@code null} if no log file is to be written	 */	protected abstract void loadConfiguration(LoggingInitializationContext initializationContext, String location,			LogFile logFile);	/**	 * Reinitialize the logging system if required. Called when	 * {@link #getSelfInitializationConfig()} is used and the log file hasn't changed. May	 * be used to reload configuration (for example to pick up additional System	 * properties).	 * @param initializationContext the logging initialization context	 */	protected void reinitialize(LoggingInitializationContext initializationContext) {	}	//......}

AbstractLoggingSystem繼承了LoggingSystem,它主要是重寫了initialize方法,若存在configLocation配置則執行initializeWithSpecificConfig,否則執行initializeWithConventions;它同時還定義了loadDefaults、loadConfiguration抽象方法需要子類實現rXR28資訊網——每日最新資訊28at.com

Slf4JLoggingSystem

org/springframework/boot/logging/Slf4JLoggingSystem.javarXR28資訊網——每日最新資訊28at.com

public abstract class Slf4JLoggingSystem extends AbstractLoggingSystem {	private static final String BRIDGE_HANDLER = "org.slf4j.bridge.SLF4JBridgeHandler";	public Slf4JLoggingSystem(ClassLoader classLoader) {		super(classLoader);	}	@Override	public void beforeInitialize() {		super.beforeInitialize();		configureJdkLoggingBridgeHandler();	}	@Override	public void cleanUp() {		if (isBridgeHandlerAvailable()) {			removeJdkLoggingBridgeHandler();		}	}	@Override	protected void loadConfiguration(LoggingInitializationContext initializationContext, String location,			LogFile logFile) {		Assert.notNull(location, "Location must not be null");		if (initializationContext != null) {			applySystemProperties(initializationContext.getEnvironment(), logFile);		}	}	//......}

Slf4JLoggingSystem繼承了AbstractLoggingSystem,它覆蓋了beforeInitialize,新增configureJdkLoggingBridgeHandler;其cleanUp方法在isBridgeHandlerAvailable的時候執行removeJdkLoggingBridgeHandler;其loadConfiguration在initializationContext不為null的時候執行applySystemPropertiesrXR28資訊網——每日最新資訊28at.com

configureJdkLoggingBridgeHandler

private void configureJdkLoggingBridgeHandler() {		try {			if (isBridgeJulIntoSlf4j()) {				removeJdkLoggingBridgeHandler();				SLF4JBridgeHandler.install();			}		}		catch (Throwable ex) {			// Ignore. No java.util.logging bridge is installed.		}	}

configureJdkLoggingBridgeHandler主要是判斷是否將JUL綁定到SLF4J,是的話則removeJdkLoggingBridgeHandler,然后執行SLF4JBridgeHandler.install()rXR28資訊網——每日最新資訊28at.com

removeJdkLoggingBridgeHandler

private void removeJdkLoggingBridgeHandler() {		try {			removeDefaultRootHandler();			SLF4JBridgeHandler.uninstall();		}		catch (Throwable ex) {			// Ignore and continue		}	}	private void removeDefaultRootHandler() {		try {			Logger rootLogger = LogManager.getLogManager().getLogger("");			Handler[] handlers = rootLogger.getHandlers();			if (handlers.length == 1 && handlers[0] instanceof ConsoleHandler) {				rootLogger.removeHandler(handlers[0]);			}		}		catch (Throwable ex) {			// Ignore and continue		}	}

removeJdkLoggingBridgeHandler主要是執行removeDefaultRootHandler,以及SLF4JBridgeHandler.uninstall()rXR28資訊網——每日最新資訊28at.com

applySystemProperties

protected final void applySystemProperties(Environment environment, LogFile logFile) {		new LoggingSystemProperties(environment).apply(logFile);	}	public void apply(LogFile logFile) {		PropertyResolver resolver = getPropertyResolver();		setSystemProperty(resolver, EXCEPTION_CONVERSION_WORD, "exception-conversion-word");		setSystemProperty(PID_KEY, new ApplicationPid().toString());		setSystemProperty(resolver, CONSOLE_LOG_PATTERN, "pattern.console");		setSystemProperty(resolver, FILE_LOG_PATTERN, "pattern.file");		setSystemProperty(resolver, FILE_CLEAN_HISTORY_ON_START, "file.clean-history-on-start");		setSystemProperty(resolver, FILE_MAX_HISTORY, "file.max-history");		setSystemProperty(resolver, FILE_MAX_SIZE, "file.max-size");		setSystemProperty(resolver, FILE_TOTAL_SIZE_CAP, "file.total-size-cap");		setSystemProperty(resolver, LOG_LEVEL_PATTERN, "pattern.level");		setSystemProperty(resolver, LOG_DATEFORMAT_PATTERN, "pattern.dateformat");		setSystemProperty(resolver, ROLLING_FILE_NAME_PATTERN, "pattern.rolling-file-name");		if (logFile != null) {			logFile.applyToSystemProperties();		}	}

applySystemProperties通過LoggingSystemProperties設置了系統屬性方便后續log配置文件使用rXR28資訊網——每日最新資訊28at.com

LogbackLoggingSystem

org/springframework/boot/logging/logback/LogbackLoggingSystem.javarXR28資訊網——每日最新資訊28at.com

public class LogbackLoggingSystem extends Slf4JLoggingSystem {	private static final String CONFIGURATION_FILE_PROPERTY = "logback.configurationFile";	private static final LogLevels<Level> LEVELS = new LogLevels<>();	static {		LEVELS.map(LogLevel.TRACE, Level.TRACE);		LEVELS.map(LogLevel.TRACE, Level.ALL);		LEVELS.map(LogLevel.DEBUG, Level.DEBUG);		LEVELS.map(LogLevel.INFO, Level.INFO);		LEVELS.map(LogLevel.WARN, Level.WARN);		LEVELS.map(LogLevel.ERROR, Level.ERROR);		LEVELS.map(LogLevel.FATAL, Level.ERROR);		LEVELS.map(LogLevel.OFF, Level.OFF);	}	private static final TurboFilter FILTER = new TurboFilter() {		@Override		public FilterReply decide(Marker marker, ch.qos.logback.classic.Logger logger, Level level, String format,				Object[] params, Throwable t) {			return FilterReply.DENY;		}	};	public LogbackLoggingSystem(ClassLoader classLoader) {		super(classLoader);	}	@Override	protected String[] getStandardConfigLocations() {		return new String[] { "logback-test.groovy", "logback-test.xml", "logback.groovy", "logback.xml" };	}	//......}

LogbackLoggingSystem繼承了Slf4JLoggingSystem,其getStandardConfigLocations返回logback-test.groovy, logback-test.xml, logback.groovy, logback.xmlrXR28資訊網——每日最新資訊28at.com

beforeInitialize

@Override	public void beforeInitialize() {		LoggerContext loggerContext = getLoggerContext();		if (isAlreadyInitialized(loggerContext)) {			return;		}		super.beforeInitialize();		loggerContext.getTurboFilterList().add(FILTER);	}

beforeInitialize方法主要是添加了TurboFilterrXR28資訊網——每日最新資訊28at.com

initialize

@Override	public void initialize(LoggingInitializationContext initializationContext, String configLocation, LogFile logFile) {		LoggerContext loggerContext = getLoggerContext();		if (isAlreadyInitialized(loggerContext)) {			return;		}		super.initialize(initializationContext, configLocation, logFile);		loggerContext.getTurboFilterList().remove(FILTER);		markAsInitialized(loggerContext);		if (StringUtils.hasText(System.getProperty(CONFIGURATION_FILE_PROPERTY))) {			getLogger(LogbackLoggingSystem.class.getName()).warn("Ignoring '" + CONFIGURATION_FILE_PROPERTY					+ "' system property. Please use 'logging.config' instead.");		}	}

initialize方法執行super.initialize(initializationContext, configLocation, logFile),然后markAsInitialized(loggerContext)rXR28資訊網——每日最新資訊28at.com

loadDefaults

@Override	protected void loadDefaults(LoggingInitializationContext initializationContext, LogFile logFile) {		LoggerContext context = getLoggerContext();		stopAndReset(context);		boolean debug = Boolean.getBoolean("logback.debug");		if (debug) {			StatusListenerConfigHelper.addOnConsoleListenerInstance(context, new OnConsoleStatusListener());		}		LogbackConfigurator configurator = debug ? new DebugLogbackConfigurator(context)				: new LogbackConfigurator(context);		Environment environment = initializationContext.getEnvironment();		context.putProperty(LoggingSystemProperties.LOG_LEVEL_PATTERN,				environment.resolvePlaceholders("${logging.pattern.level:${LOG_LEVEL_PATTERN:%5p}}"));		context.putProperty(LoggingSystemProperties.LOG_DATEFORMAT_PATTERN, environment.resolvePlaceholders(				"${logging.pattern.dateformat:${LOG_DATEFORMAT_PATTERN:yyyy-MM-dd HH:mm:ss.SSS}}"));		context.putProperty(LoggingSystemProperties.ROLLING_FILE_NAME_PATTERN, environment				.resolvePlaceholders("${logging.pattern.rolling-file-name:${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz}"));		new DefaultLogbackConfiguration(initializationContext, logFile).apply(configurator);		context.setPackagingDataEnabled(true);	}

loadDefaults方法通過LOG_LEVEL_PATTERN、LOG_DATEFORMAT_PATTERN、ROLLING_FILE_NAME_PATTERN以及LogbackConfigurator來初始化DefaultLogbackConfigurationrXR28資訊網——每日最新資訊28at.com

loadConfiguration

@Override	protected void loadConfiguration(LoggingInitializationContext initializationContext, String location,			LogFile logFile) {		super.loadConfiguration(initializationContext, location, logFile);		LoggerContext loggerContext = getLoggerContext();		stopAndReset(loggerContext);		try {			configureByResourceUrl(initializationContext, loggerContext, ResourceUtils.getURL(location));		}		catch (Exception ex) {			throw new IllegalStateException("Could not initialize Logback logging from " + location, ex);		}		List<Status> statuses = loggerContext.getStatusManager().getCopyOfStatusList();		StringBuilder errors = new StringBuilder();		for (Status status : statuses) {			if (status.getLevel() == Status.ERROR) {				errors.append((errors.length() > 0) ? String.format("%n") : "");				errors.append(status.toString());			}		}		if (errors.length() > 0) {			throw new IllegalStateException(String.format("Logback configuration error detected: %n%s", errors));		}	}	private void configureByResourceUrl(LoggingInitializationContext initializationContext, LoggerContext loggerContext,			URL url) throws JoranException {		if (url.toString().endsWith("xml")) {			JoranConfigurator configurator = new SpringBootJoranConfigurator(initializationContext);			configurator.setContext(loggerContext);			configurator.doConfigure(url);		}		else {			new ContextInitializer(loggerContext).configureByResource(url);		}	}

loadConfiguration方法主要是執行configureByResourceUrl,該方法通過SpringBootJoranConfigurator或者ContextInitializer的configureByResource進行配置rXR28資訊網——每日最新資訊28at.com

小結

springboot定義了LoggingSystem、AbstractLoggingSystem、Slf4JLoggingSystem,依次繼承,而LogbackLoggingSystem則繼承Slf4JLoggingSystem,它主要是定義了要加載的默認的配置文件logback-test.groovy, logback-test.xml, logback.groovy, logback.xml,以及loadDefaults方法,通過LOG_LEVEL_PATTERN、LOG_DATEFORMAT_PATTERN、ROLLING_FILE_NAME_PATTERN以及LogbackConfigurator來初始化DefaultLogbackConfiguration。rXR28資訊網——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-16642-0.html聊聊SpringBoot的LogbackLoggingSystem

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Go的分布式應用:使用Raft算法

下一篇: 使用Docker Compose編排多個容器

標簽:
  • 熱門焦點
  • K60至尊版剛預熱 一加Ace2 Pro正面硬剛

    Redmi這邊剛如火如荼的宣傳了K60 Ultra的各種技術和硬件配置,作為競品的一加也坐不住了。一加中國區總裁李杰發布了兩條微博,表示在自家的一加Ace2上早就已經采用了和PixelWo
  • 5月iOS設備好評榜:iPhone 14僅排第43?

    來到新的一月,安兔兔的各個榜單又重新匯總了數據,像安卓陣營的榜單都有著比較大的變動,不過iOS由于設備的更新換代并沒有那么快,所以相對來說變化并不大,特別是iOS好評榜,老款設
  • CSS單標簽實現轉轉logo

    轉轉品牌升級后更新了全新的Logo,今天我們用純CSS來實現轉轉的新Logo,為了有一定的挑戰性,這里我們只使用一個標簽實現,將最大化的使用CSS能力完成Logo的繪制與動畫效果。新logo
  • 一篇文章帶你了解 CSS 屬性選擇器

    屬性選擇器對帶有指定屬性的 HTML 元素設置樣式。可以為擁有指定屬性的 HTML 元素設置樣式,而不僅限于 class 和 id 屬性。一、了解屬性選擇器CSS屬性選擇器提供了一種簡單而
  • 虛擬鍵盤 API 的妙用

    你是否在遇到過這樣的問題:移動設備上有一個固定元素,當激活虛擬鍵盤時,該元素被隱藏在了鍵盤下方?多年來,這一直是 Web 上的默認行為,在本文中,我們將探討這個問題、為什么會發生
  • 拼多多APP上線本地生活入口,群雄逐鹿萬億市場

    Tech星球(微信ID:tech618)文 | 陳橋輝 Tech星球獨家獲悉,拼多多在其APP內上線了&ldquo;本地生活&rdquo;入口,位置較深,位于首頁的&ldquo;充值中心&rdquo;內,目前主要售賣美食相關的
  • 蘋果公司要求三星和LG Display生產「無邊框」OLED iPhone顯示屏

    據 The Elec 報道,蘋果已要求其供應商為未來的 iPhone 型號開發「無邊框」OLED 顯示面板。蘋果顯然已要求三星和 LG Display 開發新的 OLED 顯示面
  • 3699元!iQOO Neo8 Pro頂配版今日首銷:1TB UFS 4.0同價位唯一

    5月23日,iQOO推出了全新的iQOO Neo8系列,包含iQOO Neo8和iQOO Neo8 Pro兩個版本,其中標準版搭載高通驍龍8+,而Pro版更是首發搭載了聯發科天璣9200+旗艦
  • iQOO Neo8系列新品發布會

    旗艦雙芯 更強更Pro
Top