监控sql执行时间

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
import org.apache.commons.lang.time.StopWatch;

import com.njhh.fmcp.log.PortalRunLog;
import com.njhh.fmcp.util.BeanMaker;
import com.njhh.fmcp.util.SystemConfigUtil;

/**
 * 监控系统dao执行时间
 * @author
 *
 */
public class SqlTimeAdvice implements MethodInterceptor{
    private PortalRunLog log = (PortalRunLog)BeanMaker.getBean("monitorLog");
    private PortalRunLog runLog = (PortalRunLog)BeanMaker.getBean("portalRunLog");
    private long time = SystemConfigUtil.getTimeThresholdKey();
    
    @Override
    public Object invoke(MethodInvocation invocation) throws Throwable {
        StopWatch clock = new StopWatch();
        // 计时开始
        clock.start();
        Object result = null;
        // 监控的类名
        String className = invocation.getMethod().getDeclaringClass().getSimpleName();
        //监控的方法名  
        String methodName = className + "." + invocation.getMethod().getName();
        try {
            //这个是我们监控的bean的执行并返回结果
            result = invocation.proceed();
        } catch (Throwable e) {
            //监控的参数
            runLog.error("数据库执行异常 , 方法名[" + methodName + "]" + " 参数:" + getString(invocation.getArguments()));
            throw e;
        }
        clock.stop(); //计时结束
        // 执行超过1秒的sql需要记录到监控日志
        if (clock.getTime() >= time){
            log.info("执行时间:" + clock.getTime() + " ms [" + methodName + "]" + " 参数:" + getString(invocation.getArguments()));
        }
        return result;  
    }
    
     public String getString(Object[] objs) {
         StringBuffer stringBuffer = new StringBuffer();
         for (Object object : objs) {
            stringBuffer.append("[").append(object.toString()).append("],");
         }
         if (stringBuffer.length() > 0){
             stringBuffer.deleteCharAt(stringBuffer.length() - 1);
         }
         return stringBuffer.toString();  
     }

}


<bean id="SqlProxyCreator"
        class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"
        p:beanNames="*Dao,*DaoImpl" p:interceptorNames="sqlTimeAdvice" />
    
    <bean id="sqlTimeAdvice" class="com.njhh.fmcp.interceptor.SqlTimeAdvice" /> 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值