查看Resin日志,统计访问DB时间,Controller处理时间。
准备开始查看resin的日志和DB访问的时间
开始没有方向怎么处理这个(查了很多的材料)
![v2-c96b4324b84f88766a07f99fe3b77743_b.jpg](https://img-blog.csdnimg.cn/img_convert/a7188ce3538124a47ed265d604d68fc3.png)
下载依赖的jar 包
(jar包的地址)
http://maven.outofmemory.cn/org.aspectj/aspectjweaver/1.7.4/
![v2-ec2aa5030eb8a6923c9bd68cfaed5b05_b.jpg](https://img-blog.csdnimg.cn/img_convert/3525cfd82f02bc2a83e7d51eaa965185.png)
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/>
![v2-b5c8b9eba33a80de7f349b7046ce79cb_b.jpg](https://img-blog.csdnimg.cn/img_convert/90c6004f6978c5f75ad125900e31fa87.png)
查看日志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](https://img-blog.csdnimg.cn/img_convert/37e262cd7255e2db5df74b6fba4cc687.png)
这个时间获取有问题(找不到原因)
![v2-78fae73f7a4f9db8edeea39a9fd62127_b.jpg](https://img-blog.csdnimg.cn/img_convert/d69faf698618e58f5f6406a759dea8d8.png)
对脚本这块有问题可能自己了解比较少(后面学多了再来弄)那个脚本还是有点问题
准备top查看使用Top命令查看WEB服务占用内存和CPU。
![v2-6d60f337d0054c7dda468638cb35b197_b.jpg](https://img-blog.csdnimg.cn/img_convert/070f9a90893c677adf46462fc180ee42.png)
今天完成的事情: 还是关于resin的DB访问时间,了解了熟悉linux的操作命令
今天的困难:还是那个打印的时间不知道怎么回事还是出来不了
明天的计划:看看深度思考,任务三花了很多时间,感觉好浪费,后面对日志打印有了更深入的了解后面看看怎么解决
今天的收获:一般般,就是解决不了问题有点难过