Hibernate性能优化

Jun 07, 2016 pm 02:50 PM
hibernate 최적화 원래의 성능

本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-141.html (1)大量分页查询时,及时session.clear(),可能导致内存溢出; 大集合遍历:如寻找敏感词汇; 注:内存泄漏,Java本身不会内存泄漏,但是Java调用的底层C会内存泄

本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-141.html

(1)大量分页查询时,及时session.clear(),可能导致内存溢出;
大集合遍历:如寻找敏感词汇;
 注:内存泄漏,Java本身不会内存泄漏,但是Java调用的底层C会内存泄漏。
(2)1+N问题:(典型面试题)
 一个实体A关联着另一个实体B,查询所有的实体A时,原本一条sql语句就可完成,结果后面却多了N条查询各个A关联的实体B的查询语句的问题,影响性能。
 解决办法:A. 实体B设置为LAZY;
           B.BatchSize多次单条查询合并成少次的多条查询,减少sql次数;
           C.join fetch:设置外连接,把后面要查询的也一起查出来,减少查询次数。
(3)BatchSize多次单条查询合并成少次的多条查询,减少sql次数。
(4)List的Iterator:
   A.List:Query查询到的List是直接一条sql查询所有结果;
   B.Iterator:只查询表的最小主键,接下来每访问一条才发送一条sql语句查询具体的记录,但是Iterator使用了Hibernate的缓存,同一个session查询两次,底层sql只发送一次而已,它会自己去缓存中查询结果是否已经有了,减少sql查询次数。
(5)一级缓存、二级缓存、查询缓存(面试题)
   A.一级缓存:session中的缓存,查询过一次之后的同一个session下再次查询会从缓存中查询;
   B.二级缓存:SessionFactory级别的缓存,可以跨越session,Hibernate没有实现,需要使用第三方二级缓存实现,默认EHCache,需要EHCache和Logging的jar;
     a.打开二级缓存:Hibernate主配置文件设置打开缓存并指定二级缓存实现类;
        @Cache注解:标注需要缓存到二级缓存的实体Entity;
        Ehcache.xml:EHCache二级缓存的配置文件,可设置多个缓存配置,根据
        name选择设置的属性配置;
     b.适用二级缓存:经常访问、改动不大、数量有限;
     c.load、iterator默认使用二级缓存,list有往二级缓存加数据但是查询时不使用;
     d.query若要使用二级缓存,需要打开查询缓存,
        true
        setCachable(true);指明Query打开二级缓存;
     e.缓存算法:LRU最近最少使用、FIFO(先进先出)、LFU(最近最不常使用)
   C.查询缓存:特殊的二级缓存,专门用于查询操作;
(6)二级缓存使用步骤:
   A.导入ehcache的jar和commons-logging的jar;
   B.类路径加入ehcache的配置文件,里面配置缓存配置;
   C.hibernate的全局配置文件配置开启二级缓存;
   D.标签设置要开启二级缓存的实体类;
   E.:usage设置缓存策略,region设置要使用的EHCache配置选项,include设置是否缓存该实体所关联的关联实体。
(7)事务并发处理(面试):
事务基础知识见JDBC笔记;
  A. 悲观锁:解决不可重复读,load添加第三个参数设置;
悲观地认为别人总想着影响自己,直接加锁,防止别人的影响;
  B. 乐观锁:解决多人同时修改,程序中实现;
乐观地认为别人不会来影响自己,加一个记录版本号的属性,@Version,事务开始时检查版本号,到真正要修改时再检查版本号,若版本号不变,则正确执行,版本号变了说明被影响了,报错;
(8)一定要设置连接池!!!
(9)一定注意数据库的全表查询是禁止的,关联关系的多方直接不延迟也是禁止的,Hibernate会把整个表加入内存和一级缓存,很容易导致内存溢出。

本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/blog/8/8-141.html

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

다양한 Java 프레임워크의 성능 비교 다양한 Java 프레임워크의 성능 비교 Jun 05, 2024 pm 07:14 PM

다양한 Java 프레임워크의 성능 비교

C++ 프로그램 최적화: 시간 복잡도 감소 기술 C++ 프로그램 최적화: 시간 복잡도 감소 기술 Jun 01, 2024 am 11:19 AM

C++ 프로그램 최적화: 시간 복잡도 감소 기술

PHP 배열 키 값 뒤집기: 다양한 방법의 성능 비교 분석 PHP 배열 키 값 뒤집기: 다양한 방법의 성능 비교 분석 May 03, 2024 pm 09:03 PM

PHP 배열 키 값 뒤집기: 다양한 방법의 성능 비교 분석

C++에서 멀티스레드 프로그램의 성능을 최적화하는 방법은 무엇입니까? C++에서 멀티스레드 프로그램의 성능을 최적화하는 방법은 무엇입니까? Jun 05, 2024 pm 02:04 PM

C++에서 멀티스레드 프로그램의 성능을 최적화하는 방법은 무엇입니까?

C++와 다른 언어의 성능 비교 C++와 다른 언어의 성능 비교 Jun 01, 2024 pm 10:04 PM

C++와 다른 언어의 성능 비교

벤치마크를 사용하여 Java 기능의 성능을 평가하는 방법은 무엇입니까? 벤치마크를 사용하여 Java 기능의 성능을 평가하는 방법은 무엇입니까? Apr 19, 2024 pm 10:18 PM

벤치마크를 사용하여 Java 기능의 성능을 평가하는 방법은 무엇입니까?

PHP 배열을 객체로 변환하면 성능에 어떤 영향이 있나요? PHP 배열을 객체로 변환하면 성능에 어떤 영향이 있나요? Apr 30, 2024 am 08:39 AM

PHP 배열을 객체로 변환하면 성능에 어떤 영향이 있나요?

Golang의 난수 생성기 성능은 얼마나 좋나요? Golang의 난수 생성기 성능은 얼마나 좋나요? Jun 01, 2024 pm 09:15 PM

Golang의 난수 생성기 성능은 얼마나 좋나요?

See all articles