发表于: 2018-01-24 16:24:27

2 574


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

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

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

                                             

下载依赖的jar

(jar包的地址)

http://maven.outofmemory.cn/org.aspectj/aspectjweaver/1.7.4/

http://blog.csdn.net/turleslove/article/details/52575771(参考文档)

创建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/>

查看日志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

 

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

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

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

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

 

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

 

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

 

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

 



返回列表 返回列表
评论

    分享到