Spring webflow + Jpa + Hibernate运行时无响应问题处理

问题现象:

使用Spring webflow过程的页面需要从Mysql查询数据,在前台展现出来,在查询几次后页面就没有响应,服务器的日志最后一条就是Hibernate的SQL语句。

运行环境:

JRE:1.8

Spring framework:4.3.8.RELEASE

Spring webflow:2.4.5.RELEASE

Spring data jpa:1.11.4.RELEASE

Hibernate:5.2.5.Final

MySql:5.7.14

Tomcat:8.0(使用tomcat的数据库连接池)

问题解决过程:

1. 怀疑数据库死锁

开发环境只有一个用户,并且这些页面的操作只有查询,并在用Mysql workbench登录查询同一个表的记录正常,所以排除这种可能性

2. 可能是自身对webflow中使用jpa的方法没有理解,所以做一些尝试:

- 查看《spring in action》、《spring web flow权威指南》,都没有对在web flow中使用持久化的说明

- 查看spring官网的webflow,对于Flow Managed Persistence的说明,主要实现一个流操作中的数据持久化和事务。每一次进入一个flow时会启用一个新的持久化上下文,并且在mysql后台看到会增加一个客户端连接,这个连接应该要等这个flow被commit后才会释放。

这里有2个疑问:

* 为什么每一个flow进入时会打开一个新的数据库连接,理论上Hibernate的Session管理机制会创建一个新的session?

* 这个flow如果没有被完整执行,也就是中途退出了,那么这个持久化上下文只能等到连接超时才能释放,如果高并发那很快会挂掉,如何处理?

3. 验证

将连接池的最大连接数改成5个,通过点击页面,到第6个页面时就会挂住没有响应,因为拿不到连接10s后超时报错,此时如果连接池设置中没有加maxWaitMillis="10000"那么会一直等待,这个现象会让人无从入手调查,这点大家要注意

<Context>
	<Resource name="jdbc/pt" type="javax.sql.DataSource" auth="Container"
		maxTotal="5" maxIdle="30" maxWaitMillis="10000"
		driverClassName="com.mysql.jdbc.Driver" username="pt" password="pt123"
		url="jdbc:mysql://127.0.0.1:3306/pt" />
</Context>

4. 解决

尝试去除webflow的<persistence-context/>标签,数据的一致性交给service处理

去除后页面上从后台数据库查询记录正常,但当选定查询结果中的某一个记录跳转到下一个页面时(选定的记录ID作为request parameters传到flow的Action,由Action调用service层再调用dao层加载这个记录的具体信息),报错:

org.hibernate.LazyInitializationException: could not initiali

dao层是继承了Spring的JpaRepository类,加载时调用getOne方法,查看getOne的javadoc,See Also:EntityManager.getReference(Class, Object)

对象是延迟加载的。

换成CrudRepository类的findOne方法后可以正常显示数据。

问题解决!

时间: 2024-08-10 17:35:08

Spring webflow + Jpa + Hibernate运行时无响应问题处理的相关文章

Spring+Jersey+JPA+Hibernate+MySQL实现CRUD操作案例

本文承接我的另一篇博文:Spring+Jersey+Hibernate+MySQL+HTML实现用户信息增删改查案例(附Jersey单元测试),主要更改内容如下: Spring配置文件applicationContext中原先使用的是Hibernate,现在改为Hibernate对JPA的支持: 增加了C3P0连接池: 修改了Dao操作实现,改为Spring接管的JPA实现. 如果读者想详细查看Spring整合Jersey与前端交互可以点击上述连接.本文主要介绍以上三处修改内容,并且使用Jers

关于VS2012 生成或调试时无响应的另一种情况

最近在做一个项目,差不多结尾了. 然后某天发现,生成和调试都会卡好一会(差不多要1分钟吧)才可以正常开始. 然后各种找问题,重装VS,重装系统,什么中文输入法,结果都一样. 最后只能怀疑是项目 问题了,后来想起来主窗口使用了一个自己写的用户控件,这个控件是容器来的,然后里面的控件全部变成空白了,当然之前是正常的,后来不知道为什么变成这样,然后我就自己手动将控件添加回去这个控件内 在Form1.Designer.cs文件内的 this.xxxx.Controls.Add(this.button3)

Spring Boot整合Spring MVC、Spring、Spring Data JPA(Hibernate)

一句话总结:Spring Boot不是新的功能框架,而是为了简化如SSH.SSM等等多个框架的搭建.整合及配置.使用Spring Boot 10分钟搭建起Spring MVC.Spring.Spring Data JPA(Hibernate)基础后台架构.基本零配置,全注解. 步骤一: 使用Spring Boot提供的网站生成maven项目及基础依赖.打开https://start.spring.io/网站,右侧输入想要的特性依赖.输入Web提供整合Spring MVC,输入JPA提供整合Spr

Spring Boot + JPA(hibernate 5) 开发时,数据库表名大小写问题

这几天在用spring boot开发项目, 在开发的过程中遇到一个问题hibernate在执行sql时,总会提示表不存在. 寻找之后发现, 建表时,表统一采用了大写.hibernate会把大写统一转换成小写.且 mysql在 linux下 大小写敏感. 解决: 1. 尝试修改mysql的cnf文件,改成不区分大小写.修改完成之后发现问题并没有解决,还产生了新的问题,表名无论大小写都失败了. 2. 数据库层面修改没有效果, 表结构和表名不能修改,那只能通过代码实现来解决此问题了. 先感谢  三个博

利用Spring Roo搭建spring/springMVC/jpa(hibernate)

之前看spring实战的时候,书中提到spring roo工具,一直没有来得及尝试. 这次十一,我和女友一致认为前两天人太挤出去是受罪,于是就窝在了家里,就有了点时间来研究一下技术. 好了,言归正传 ,我比较懒,所以一直在寻找最简单的办法去完成一些事情. 对于框架集成也是如此 ,已经尝试过各种方法了,就是为了寻找更简单,实用. 本次是利用Spring Roo进行搭建,认为是目前最简单的了,并且Roo的配置几乎都是最佳实践. -------------------------------PART1

MySQL删除数据库时无响应解决办法

删除远程主机上MySQL中的一个数据库时,远程主机一直在响应,无法正常删除. 这个问题的解决办法如下:在远程主机上登录MySQL,执行show full processlist;观察state和info两列,查看有哪些线程在运行.经过查询发现之前远程删除的时候由于网络中断,锁表了.所以导致再次登录的时候删除操作无响应.这时候只要使用kill命令+对应线程前面id,将线程结束掉,就可以正常删除了. REF: https://blog.csdn.net/cccheer/article/details

Spring学习笔记——Spring事务只对运行时异常回滚

我们在使用Spring时候一般都知道事务在遇到异常的时候会回滚,岂不知Spring的事务默认只有在发生运行时异常即:RunTimeException时才会发生事务,如果一个方法抛出Exception或者Checked异常Spring的事务并不会回滚. 下面我们来看看异常的分类,异常一般分为Checked异常和RunTime异常. CheckedException: Java认为Checked异常都是可以被处理的异常,所以Java程序必须显式的处理Checked异常,如果程序没有处理checked

spring data jpa hibernate jpa 三者之间的关系

JPA规范与ORM框架之间的关系是怎样的呢? JPA规范本质上就是一种ORM规范,注意不是ORM框架——因为JPA并未提供ORM实现,它只是制订了一些规范,提供了一些编程的API接口,但具体实现则由服务厂商来提供实现,JBoss应用服务器底层就以Hibernate作为JPA的实现. 既然JPA作为一种规范——也就说JPA规范中提供的只是一些接口,显然接口不能直接拿来使用.虽然应用程序可以面向接口编程,但JPA底层一定需要某种JPA实现,否则JPA依然无法使用.从笔者的视角来看,Sun之所以提出J

当接口被调用时使用Spring拦截器注入运行时数据

开发背景 使用CXF暴露与调用接口,为了方便追踪错误,所以想要在接口被调用时将一些运行时数据记录起来,所以就想到了拦截器. CXF自带拦截器,但是据我初步了解,自带的拦截器都是经过封装,用来打印日志什么的,好像没有提供给开发者定制功能的方式(没有深入了解,如果有说错请方便斧正) 流程 其实Spring的拦截器使用挺方便的,实现org.aopalliance.intercept.MethodInterceptor接口中的invoke方法,在方法中实现想要的逻辑.然后在Spring配置文件中注入它就