用slf4j输出日志的时候,日志信息要不是太简要或者是日志信息太长了不便于查看已经大量日志输出也会浪费内存,于是自己想办法减少日志输出量,还有优化的空间。
package com.hrht.util;
import java.io.PrintWriter;
import java.io.StringWriter;
/**
* Created by fangyukang on 2017/10/11.
*/
public class TraceUtil {
public static String getTrace(Throwable t) {
StringWriter stringWriter= new StringWriter();
PrintWriter writer= new PrintWriter(stringWriter);
t.printStackTrace(writer);
StringBuffer buffer= stringWriter.getBuffer();
String[] str = buffer.toString().split("\\r\\n\\t");
buffer = new StringBuffer();
buffer.append("Exception\r\n\t").append(str[0]).append("\r\n\t").append(str[1]);
writer.close();
return buffer.toString();
}
}
这里只输出第一行以及第二行的日志信息,本来是想把信息直接读两行就算了,但是一看要改源码于是用这种折中的办法也是能达到效果,反正一个异常信息也就是那么多,java代码处理速度不用说,没有什么大的影响。
这是调用部分代码:
package com.hrht.controller;
import com.hrht.common.JsonView;
import com.hrht.rpc.db.dao.TestDao;
import com.hrht.rpc.db.model.Test;
import org.apache.thrift.TException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
import static com.hrht.util.TraceUtil.getTrace;
/**
* Created by fangyukang on 2017/10/10.
*/
@RestController
@RequestMapping(value = "/test")
public class TestController extends BaseController {
Logger logger = LoggerFactory.getLogger(TestController.class);
@Autowired
TestDao testDao;
@RequestMapping(value = "/getList")
public JsonView getList() throws TException {
logger.info("enter <TestController>...... getList()");
List<Test> list = null;
try {
list = testDao.getList();
return success("Query testList success.", list);
}catch (Exception e){
logger.error(getTrace(e));
}
return error("Query testList fail.");
}
}
其中可能还有不足,但是可以慢慢优化,输出最主要的异常日志信息。