All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.logicbus.backend.bizlog.handler.Log4j Maven / Gradle / Ivy

There is a newer version: 1.6.17
Show newest version
package com.logicbus.backend.bizlog.handler;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.w3c.dom.Element;

import com.anysoft.stream.AbstractHandler;
import com.anysoft.util.Properties;
import com.anysoft.util.PropertiesConstants;
import com.anysoft.util.Settings;
import com.logicbus.backend.bizlog.BizLogItem;
import com.logicbus.backend.bizlog.BizLogger;
import com.logicbus.models.servant.ServiceDescription.LogType;

/**
 * log4j文件写出
 * @author yyduan
 *
 * @since 1.6.7.12
 */
public class Log4j extends AbstractHandler implements BizLogger {

	/**
	 * a logger of log4j
	 */
	protected Logger logger = null;
	
	/**
	 * 线程id
	 */
	protected int thread = 0;
	
	/**
	 * 输出间隔符
	 */
	protected String delimiter = "%%";
	
	protected String eol = "$$";
	
	/**
	 * 计费标志
	 */
	protected boolean isBilling = true;
		
	/**
	 * 应用
	 * 
	 * @since 1.2.7.1
	 */
	protected String app;
	
	/**
	 * 服务主机(ip:port)
	 * 
	 * @since 1.2.7.1
	 */
	protected String hostPattern = "${server.host}:${server.port}";
	
	protected String host = null;
	
	
	protected void onConfigure(Element _e, Properties p)  {
		thread = PropertiesConstants.getInt(p, "thread", 0);
		delimiter = PropertiesConstants.getString(p,"delimiter", delimiter);
		eol = PropertiesConstants.getString(p,"eol", eol);
		isBilling = PropertiesConstants.getBoolean(p,"billing", isBilling);
		app = PropertiesConstants.getString(p, "app", "${server.app}");
		hostPattern = PropertiesConstants.getRaw(p,"host",hostPattern);
		
		logger = LoggerFactory.getLogger("Bizlog" + thread);
	}

	
	protected void onHandle(BizLogItem item,long t) {
		if (item.logType == LogType.none){
			return;
		}
	
		if (host == null){
			host = Settings.get().transform(hostPattern);
		}
		
		/**
		 * 单条记录的缓存
		 */
		StringBuffer buf = new StringBuffer();
		
		buf.append(isBilling?1:0).append(delimiter)
		.append(item.sn).append(delimiter)
		.append(item.startTime).append(delimiter)
		.append(app).append(delimiter)
		.append(host).append(delimiter)
		.append(item.clientIP).append(delimiter)
		.append(item.client).append(delimiter)
		.append(item.duration).append(delimiter)
		.append(item.id).append(delimiter)
		.append(item.result).append(delimiter)
		.append(item.result.equals("core.ok")?"":item.reason).append(delimiter)
		.append(item.url).append(delimiter);
		
		if (item.content != null && item.content.length() > 0){
			buf.append(item.content.replaceAll("\n", "").replaceAll("\r",""));
		}
		
		buf.append(eol);
		logger.info(buf.toString());
	}
	
	protected void onFlush(long t) {
		//no buffer
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy