请教一个 SpringJPA+Hibernate+QueryDSL 的问题

查看 122|回复 7
作者:DreamSaddle   
项目有 1200 张表,对应 1200 个实体,项目每次启动的时候会对每个实体进行初始化处理,导致启动很慢;
尝试过使用懒加载的处理方式,但是没有生效,因为项目还用了 redis 。
想请教一下大佬们有啥优化方法吗?

请教, 初始化, querydsl, springjpa

DreamSaddle
OP
  
项目启动后,日志里很多 tor$SharedEntityManagerInvocationHandler : Creating new EntityManager for shared EntityManager invocation ,一直在执行这边的。
sky857412   
应该是 hibernate 的 ddl-auto 的原因吧,没有改实体的时候,启动时可以改成 none
DreamSaddle
OP
  
@sky857412 #2 我调试过,启动的时候应该是会为每个实体的 Repository 生成代理,就是这个过程比较慢,加上项目里实体过多。
zhenjiachen   
在 Repository 上面加 lazy 注解呢?
DreamSaddle
OP
  
@zhenjiachen #4 我有一千多个 Repository 接口呀,肯定不能每个都去加吧。
如果是使用配置来统一实现懒加载,我尝试过,但是没有成功。
我看过说是这个懒加载只支持存在一个数据源的情况下生效,我项目里有用 redis ,好像就是因为这样造成的懒加载不生效的。
DreamSaddle
OP
  
项目启动的时候,相当于每一个 Repository 接口都会走一遍 RepositoryFactoryBeanSupport#afterPropertiesSet() 方法,就是在这个方法最后面判断了 LazyInit ,但是一直不生效。
zhenjiachen   
我想了一下可以有两种办法可以简单实现,1.因为每个 repository 加要加 @Repository 注解,你可以自定义注解同时做到 repository 注解和懒加载。2.可以看看有没有 lazy 接口可以实现,自己在接口使用 default 实现 lazy 接口,然后所有的 repository 接口都基础这个实现了 lazy 接口的 repository 。应该算是相对快速的了。
您需要登录后才可以回帖 登录 | 立即注册

返回顶部