java自定义异常信息日志输出

用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.");
    }

}

其中可能还有不足,但是可以慢慢优化,输出最主要的异常日志信息。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值