概述
查看Resin日志,统计访问DB时间,Controller处理时间。
准备开始查看resin的日志和DB访问的时间
开始没有方向怎么处理这个(查了很多的材料)
下载依赖的jar 包
(jar包的地址)
创建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的访问)
查看日志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。
今天完成的事情: 还是关于resin的DB访问时间,了解了熟悉linux的操作命令
今天的困难:还是那个打印的时间不知道怎么回事还是出来不了
明天的计划:看看深度思考,任务三花了很多时间,感觉好浪费,后面对日志打印有了更深入的了解后面看看怎么解决
今天的收获:一般般,就是解决不了问题有点难过
最后
以上就是冷静金鱼为你收集整理的resin 系统日志_resin服务器的日志查看的controller的时间打印的全部内容,希望文章能够帮你解决resin 系统日志_resin服务器的日志查看的controller的时间打印所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复