2017-06-28一次奇怪的慢问题诊断ERROR_INTERNET_CONNECTION_RESET

   开发反馈,新增单据会一直hang着,等待300s就报页面找不到。

   1.用httpwatch看到的结果是:

+ 0.0001 299.461781 0 GET ERROR_INTERNET_CONNECTION_RESEThttps://10.10.5.5:12000/web/workticket/create?ticketType=11&bureauCode=02922

  在weblogic日志中可以看到事务超时了。

[ERROR] 2017-06-28 10:39:11:046 gg.f.device.workticket.facade.internal.WorkTicketFacade (AbstractExceptionHandler.java:78) - 系统发生运行时异常,暂时无法处理您的请求,请您稍后再试
org.springframework.transaction.UnexpectedRollbackException: JTA transaction unexpectedly rolled back (maybe due to a timeout); nested exception is weblogic.transaction.RollbackException: Timed out tx=BEA1-1667F46BECB34430EE84 after 600 seconds
.........................................................................................
at gg.f.device.workticket.controller.ticket.WorkticketManagerController.create(WorkticketManagerController.java:1162) [sproc4gd-workticket-webapp-1.0.1-SNAPSHOT.jar:1.0.1-SNAPSHOT]
at gg.f.device.workticket.controller.ticket.WorkticketManagerController$$FastClassByCGLIB$$7dd10baa.invoke() [spring-core-3.2.4.RELEASE.jar:1.0.1-SNAPSHOT]

at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) [spring-core-3.2.4.RELEASE.jar:3.2.4.RELEASE]
at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:698) [spring-aop-3.2.4.RELEASE.jar:3.2.4.RELEASE]

   2.查看这段代码WorkticketManagerController.java:1162,调用了一个方法createDTO,拼装一个DTO(类似VO的实例bean),很简单的方法,最后一段代码调用接口(更新全文索引)。现在只有打印很多日志,看代码停止哪里。

   3.增量后,发现日志都打印了,说明出了这个拼装方法(createDTO),但是主方法里面并未打印,那又说明没有出拼装方法(createDTO).两者相矛盾。

   4.果断注释掉这个调用接口的方法,页面出来了,问题解决了。当然,现在还没有搞清楚这个接口问题在哪里。

 



你可能感兴趣的:(j2ee,weblogic)