帆软使用的第三方框架。
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

80 lines
2.7 KiB

package com.fr.third.alibaba.ttl.threadpool.agent.internal.logging;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.Level;
/**
* logger adaptor for ttl java agent, internal use for ttl usage only!
*
* @author Jerry Lee (oldratlee at gmail dot com)
* @since 2.6.0
*/
public abstract class Logger {
public static final String TTL_AGENT_LOGGER_KEY = "ttl.agent.logger";
public static final String STDOUT = "STDOUT";
public static final String STDERR = "STDERR";
private static volatile int loggerImplType = -1;
public static void setLoggerImplType(String type) {
if (loggerImplType != -1) {
throw new IllegalStateException("TTL logger implementation type is already set! type = " + loggerImplType);
}
if (STDERR.equalsIgnoreCase(type)) loggerImplType = 0;
else if (STDOUT.equalsIgnoreCase(type)) loggerImplType = 1;
else loggerImplType = 0;
}
public static Logger getLogger(Class<?> clazz) {
if (loggerImplType == -1) throw new IllegalStateException("TTL logger implementation type is NOT set!");
switch (loggerImplType) {
case 1:
return new StdOutLogger(clazz);
default:
return new StdErrorLogger(clazz);
}
}
final Class<?> logClass;
private Logger(Class<?> logClass) {
this.logClass = logClass;
}
public void info(String msg) {
log(Level.INFO, msg, null);
}
public abstract void log(Level level, String msg, Throwable thrown);
private static class StdErrorLogger extends Logger {
StdErrorLogger(Class<?> clazz) {
super(clazz);
}
@Override
public void log(Level level, String msg, Throwable thrown) {
if (level == Level.SEVERE) {
final String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date());
System.err.printf("%s %s [%s] %s: %s%n", time, level, Thread.currentThread().getName(), logClass.getSimpleName(), msg);
if (thrown != null) thrown.printStackTrace();
}
}
}
private static class StdOutLogger extends Logger {
StdOutLogger(Class<?> clazz) {
super(clazz);
}
@Override
public void log(Level level, String msg, Throwable thrown) {
final String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date());
System.out.printf("%s %s [%s] %s: %s%n", time, level, Thread.currentThread().getName(), logClass.getSimpleName(), msg);
if (thrown != null) thrown.printStackTrace(System.out);
}
}
}