zoukankan      html  css  js  c++  java
  • java logAspect

    @Around("execution(* com.iotx.cep.biz.rpc.impl.*.*(..)) "
    + "&& !execution(* com.iotx.cep.biz.rpc.impl.CepEngineServiceImpl.calcOffsetForSameSource(..))")
    public Object addRpcLog(ProceedingJoinPoint jp) throws Throwable {
    long startTime = System.currentTimeMillis();
    String serviceName = extractServiceName(jp);
    String method = jp.getSignature().getName();
    String ip = LogUtil.getLocalIp();
    String remoteIp = LogUtil.getRemoteIp();
    IoTxResult result = null;
    try {
    result = (IoTxResult)jp.proceed();
    } catch (IllegalArgumentException e) {
    hsfLogger.warn("service={}; method={}", serviceName, method, e);
    result = ResultCreator.paramError(e.getMessage());
    } catch (Throwable t) {
    hsfLogger.error("service={}; method={}", serviceName, method, t);
    result = ResultCreator.serverError(t.getMessage());
    } finally {
    String params = JSON.toJSONString(jp.getArgs());
    String resultStr = JSON.toJSONString(result);
    long usedTime = System.currentTimeMillis() - startTime;
    appendHsfLog(serviceName, method, usedTime, ip, remoteIp, result == null ? 0 : result.getCode(),
    params, resultStr);
    appendRpcProfilerLog(serviceName, method, result == null ? 0 : result.getCode(), usedTime);
    }
    return result;
    }
  • 相关阅读:
    ###MySQL 数据库DataBase
    操作mysql数据库
    发送邮件
    模块-os.system的两个模块/random模块/datetime模块/写日志
    map/fileter
    日期相关-时间模块
    内置函数
    集合+函数
    函数-变量-参数-递归
    模块(os模块)
  • 原文地址:https://www.cnblogs.com/diegodu/p/9406507.html
Copyright © 2011-2022 走看看