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?

questionAnswers(2)

yourAnswerToTheQuestion