发表于: 2018-01-15 23:27:30
1 655
今天完成的事情:
1.配置nginx的日志格式使其可以输出响应时间。
$upstream_response_time 这个时间是 Nginx 等待后端程序响应的时间。
配置了一个简化版的日志, mylog
自己配置了一下格式,输出如下。
用脚本统计了一下次数和时间:
2.统计访问DB时间,Controller处理时间,在网上查了一下,要使用spring AOP 所有先学AOP
AOP术语
2.1横切关注点:从每个方法中抽取出来的同一类非核心业务。
①切入点表达式的语法格式:execution([权限修饰符] [返回值类型] [简单类名/全类名] [方法名]([参数列表]))
2.2切面(Aspect):封装横切关注点信息的类,每个关注点体现为一个通知方法。 带有@Aspect注解的Java类,包含很多通知。
2.3通知(Advice):切面必须要完成的各个具体工作 标注有某种注解的简单的Java方法
通知注解:
[1]@Before:前置通知,在方法执行之前执行
[2]@After:后置通知,在方法执行之后执行
[3]@AfterRunning:返回通知,在方法返回结果之后执行
[4]@AfterThrowing:异常通知,在方法抛出异常之后执行
[5]@Around:环绕通知,围绕着方法执行
2.4目标(Target):被通知的对象
2.5代理(Proxy):向目标对象应用通知之后创建的代理对象
2.6连接点(Joinpoint)
横切关注点在程序代码中的具体体现,对应程序执行的某个特定位置。例如:类某个方法调用前、调用后、方法捕获到异常后等。
在应用程序中可以使用横纵两个坐标来定位一个具体的连接点:
2.7切入点(pointcut):
定位连接点的方式。每个类的方法中都包含多个连接点,所以连接点是类中客观存在的事物。如果把连接点看作数据库中的记录,那么切入点就是查询条件——AOP可以通过切入点定位到特定的连接点。切点通过org.springframework.aop.Pointcut 接口进行描述,它使用类和方法作为连接点的查询条件。
然后模仿着写了一下用来统计db和controller:
controller
@Aspect
@Component
public class LogInterceptor {
private final Logger logger = (Logger) LoggerFactory.getLogger(AddStudentController.class);
long startTime,endTime,allTime;
@Before(value = "execution(* com.controller.*.*(..))")
public void before(){
this.startTime=System.currentTimeMillis();
}
@After(value = "execution(* com.controller.*.*(..))")
public void after(JoinPoint joinPoint){
String name = joinPoint.getSignature().getName();
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
this.endTime=System.currentTimeMillis();
this.allTime = this.endTime-this.startTime;
logger.info("[" + df.format(new Date()) + "]"+ name +"Controller耗时(ms):" + this.allTime);
}
}
db
@Aspect
@Component
public class LogInterceptorJDBC {
private final Logger logger = (Logger) LoggerFactory.getLogger(AddStudentController.class);
long startTime,endTime,alltime;
@Before(value = "execution(* com.service.*.doSomeBusinessStuff(..))")
public void before(){
this.startTime=System.currentTimeMillis();
}
@After(value = "execution(* com.service.*.doSomeBusinessStuff(..))")
public void after(JoinPoint joinPoint){
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String name = joinPoint.getSignature().getName();
this.endTime=System.currentTimeMillis();
this.alltime=this.endTime - this.startTime;
logger.info("["+ df.format(new Date()) + "]" + name +"DB耗时(ms):" + this.alltime);
}
}
log4j输出
这个输出文档还没想好统计脚本怎么写,明天继续。
收获:
1查资料过程中发现老大写的好文
https://www.zhihu.com/question/58481553/answer/157160792
对于客户端-服务器-web应用 整个框架有了基本认知。
2.学会了配置nginx输出日志格式和路径。
3.对AOP有了一点点认识。
遇到的问题:
1.shell脚本看不懂,有没有其他选择。。。
2.AOP理解起来比较困难。
明天的计划:
1.完成统计脚本和部署脚本。
任务3开始时间:2018.1.15.
预计完成时间:2018.1.18.
禅道:http://task.ptteng.com/zentao/project-task.html
评论