我是靠谱客的博主 冷静金鱼,最近开发中收集的这篇文章主要介绍resin 系统日志_resin服务器的日志查看的controller的时间打印,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

查看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的时间打印所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部