resin服务器的日志查看的controller的时间打印

查看Resin日志,统计访问DB时间,Controller处理时间。

准备开始查看resin的日志和DB访问的时间

开始没有方向怎么处理这个(查了很多的材料)

v2-c96b4324b84f88766a07f99fe3b77743_b.jpg


下载依赖的jar 包

(jar包的地址)

maven.outofmemory.cn/or


v2-ec2aa5030eb8a6923c9bd68cfaed5b05_b.jpg


blog.csdn.net/turleslov(参考文档)

创建AOP的类

package com.fuwei.aop;


import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import org.aspectj.lang.ProceedingJoinPoint;

import org.aspectj.lang.annotation.Around;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.reflect.MethodSignature;

import org.springframework.stereotype.Component;

/**

* 检测方法执行耗时的spring切面类

* 使用@Aspect注解的类,Spring将会把它当作一个特殊的Bean(一个切面),也就是不对这个类本身进行动态代理

* @author blinkfox

* @date 2016-07-04

*/

@Aspect

@Component

public class ControllerAspect {

private static Log logger = LogFactory.getLog(ControllerAspect.class);

// 一分钟,即60000ms

private static final long ONE_MINUTE = 60000;

// service层的统计耗时切面,类型必须为final String类型的,注解里要使用的变量只能是静态常量类型的

public static final String POINT = "execution (* com.fuwei.service.impl.*.*(..))";

/**

* 统计方法执行耗时Around环绕通知

* @param joinPoint

* @return

*/

@Around(POINT)

public Object timeAround(ProceedingJoinPoint joinPoint) {

// 定义返回对象、得到方法需要的参数

Object obj = null;

Object[] args = joinPoint.getArgs();

long startTime = System.currentTimeMillis();

try {

obj = joinPoint.proceed(args);

} catch (Throwable e) {

logger.error("统计某方法执行耗时环绕通知出错", e);

}

// 获取执行的方法名

long endTime = System.currentTimeMillis();

MethodSignature signature = (MethodSignature) joinPoint.getSignature();

String methodName = signature.getDeclaringTypeName() + "." + signature.getName();

// 打印耗时的信息

this.printExecTime(methodName, startTime, endTime);

return obj;

}

/**

* 打印方法执行耗时的信息,如果超过了一定的时间,才打印

* @param methodName

* @param startTime

* @param endTime

*/

private void printExecTime(String methodName, long startTime, long endTime) {

long diffTime = endTime - startTime;

if (diffTime > ONE_MINUTE) {

logger.warn("-----" + methodName + " 方法执行耗时:" + diffTime + " ms");

}

}

}


实现统计的类方法

(这个添加自动注解---->Aop的访问)

<context:component-scan base-package="com.fuwei.aop"/>

<context:component-scan base-package="com.fuwei.service.impl"/>

<aop:aspectj-autoproxy/>


v2-b5c8b9eba33a80de7f349b7046ce79cb_b.jpg


查看日志Nginx的修改代码

#!/bin/bash

cd /var/log/nginx

echo "数据库响应时间统计:" > count-nginx.txt

echo "响应时间在在10ms以内的为:" >> count-nginx.txt

cat DB-time.txt | awk 'BEGIN{sum=0}{if($13<10) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在10-50ms以内的为:" >> count-nginx.txt

cat DB-time.txt | awk 'BEGIN{sum=0}{if(($13>=10)$$($13<50)) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在50-100s以内的为:" >> count-nginx.txt

cat DB-time.txt | awk 'BEGIN{sum=0}{if(($13>=50)$$($13<100)) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在100ms以内的为:" >> count-nginx.txt

cat DB-time.txt | awk 'BEGIN{sum=0}{if($13>=100) sum++;} END{print sum}' >> count-nginx.txt

#统计nginx的响应时间

echo "Nginx响应时间(划分时间段):" >> count-nginx.txt

echo "响应时间在在0.005s以内的为:" >> count-nginx.txt

cat /var/log/nginx/access.log | awk 'BEGIN{sum=0}{if($24<0.005) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在0.005--0.010s以内的为:" >> count-nginx.txt

cat /var/log/nginx/access.log | awk 'BEGIN{sum=0}{if(($9>=0.005)&&($24<0.01)) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在0.01--0.02s以内的为:" >> count-nginx.txt

cat /var/log/nginx/access.log | awk 'BEGIN{sum=0}{if(($24>=0.01)&&($24<0.02)) sum++;} END{print sum}' >> count-nginx.txt

echo "响应时间在在0.02s以外的为:" >> count-nginx.txt

cat /var/log/nginx/access.log | awk 'BEGIN{sum=0}{if($24>=0.02) sum++;} END{print sum}' >> count-nginx.txt



v2-5234a0ca2f2caa7489622a70f56c95e8_b.jpg


这个时间获取有问题(找不到原因)


v2-78fae73f7a4f9db8edeea39a9fd62127_b.jpg


对脚本这块有问题可能自己了解比较少(后面学多了再来弄)那个脚本还是有点问题

准备top查看使用Top命令查看WEB服务占用内存和CPU。


v2-6d60f337d0054c7dda468638cb35b197_b.jpg


今天完成的事情: 还是关于resin的DB访问时间,了解了熟悉linux的操作命令


今天的困难:还是那个打印的时间不知道怎么回事还是出来不了


明天的计划:看看深度思考,任务三花了很多时间,感觉好浪费,后面对日志打印有了更深入的了解后面看看怎么解决


今天的收获:一般般,就是解决不了问题有点难过

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值