今天做项目的时候,遇到了一个巨坑,我们的项目是spring boot 为架构! 然而我在做一个查询的时候,数据少还好,当我一次性查个几百条数据的时候,数据库就崩溃了.直接报数据库连接断掉,后来百度后发现是session的问题:
之前代码:
@Autowired private EntityManagerFactory entityManagerFactory;
public Session getSession() { Session session = entityManagerFactory.unwrap(SessionFactory.class).openSession(); return session; }
发现用了session中openSession..................
openSession与getCurrentSession的区别
1. openSession 从字面上可以看得出来,是打开一个新的session对象,而且每次使用都是打开一个新的session,假如连续使用多次,则获得的session不是同一个对象,并且使用完需要调用close方法关闭session。
2. getCurrentSession ,从字面上可以看得出来,是获取当前上下文一个session对象,当第一次使用此方法时,会自动产生一个session对象,并且连续使用多次时,得到的session都是同一个对象,这就是与openSession的区别之一,简单而言,getCurrentSession 就是:如果有已经使用的,用旧的,如果没有,建新的。
发现了问题,我迅速将openSession改为getCurrentSession,这下肯定没问题...............(看来是我想多了) 直接访问就报错,一个头两个大,说的好像是找不到session的错误,然后又是一顿百度,询问大佬.找了大半天,发现了一个配置的问题:
原配置:
spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate4.SpringSessionContext
改后的配置:
spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate5.SpringSessionContext
发现问题没有,4和5的区别,具体的我也不清楚为什么会这样,反正问题解决了,能够及时的释放连接,不会导致数据库崩溃了.....开心!但是如果有大佬知道什么原因,还请大佬们不惜赐教!!!小弟感激不尽