xemplo de trabalho do cache do 2º nível do Hibernate 3.6.2 com o JPA
O título obviamente afirma: Não consigo fazer o cache de segundo nível funcionar para o JPA2 / Hibernate 3.6.
Eu tenho tentado muitos truques para fazê-lo funcionar. Mas só estou conseguindo ter o cache de consultas funcionando. Embora o Hibernate crie os caches (nome da instância), eles são ignorados. Mesmo os erros não são registrados. Talvez seja uma incompatibilidade de versão. Eu tentei alguns outros sem resultado. E não sinto mais a tarefa de tentar todas as permutações. : -P
Estou fazendo a pergunta aqui, pois algumas pessoas parecem tê-la funcionando (cujos exemplos eu tentei também). Talvez eles possam identificar o erro óbvio que estou cometend
Agradecemos antecipadamente a quem me ajudar! : -)
persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="foo" transaction-type="RESOURCE_LOCAL">
<shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
<properties>
<property name="javax.persistence.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:derby:/opt/db/foo;create=true"/>
<property name="javax.persistence.jdbc.user" value="foo"/>
<property name="javax.persistence.jdbc.password" value="bar"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.DerbyDialect"/>
<property name="hibernate.hbm2ddl.auto" value="create"/>
<property name="hibernate.cache.region.factory_class" value="net.sf.ehcache.hibernate.SingletonEhCacheRegionFactory"/>
<property name="hibernate.cache.use_second_level_cache" value="true"/>
<property name="hibernate.cache.use_query_cache" value="true"/>
</properties>
</persistence-unit>
pom.xml
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>3.6.3.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.0-api</artifactId>
<version>1.0.0.Final</version>
</dependency>
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache-core</artifactId>
<version>2.4.2</version>
JMX setup
Desta forma, posso verificar o uso dos caches. Os caches são criados (um para cada entidade) e os dois caches de consulta também estão lá. Os últimos estão se enchendo muito rápido. Mas nenhum dos caches exibe erros ou ocorrências. Nem mesmo a consulta armazena em cache.
ManagementService.registerMBeans( CacheManager.getInstance(), ManagementFactory.getPlatformMBeanServer(), true, true, true, true, true )
Os caches da entidade são ignorados. Eles devem conter pelo menos as entidades que são salvas no banco de dados. Ou sendo recuperado com consultas. Nada se move para l
Código Java de exemplo
EntityManager entityManager = Persistence.createEntityManagerFactory("foo").createEntityManager();
entityManager.getTransaction.begin();
entityManager.merge(bar);
entityManager.getTransaction.commit();
Query query = entityManager.createQuery("select b from Bar p where b.name = :name");
query.setParameter("name", "fooBar");
query.setHint("org.hibernate.cacheable","true");
query.getSingleResult();
A mesclagem funciona - porque há dados no banco de dados. E a descoberta funciona porque estou recebendo objetos com IDs gerados.
s entidades consultadas são indexadas no banco de dado
WHODUNNIT?