发表于: 2018-01-15 23:27:30

1 654


今天完成的事情

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





返回列表 返回列表
评论

    分享到