Не удается настроить JPA с ehcache - PullRequest
5 голосов
/ 25 января 2011

Я пытался настроить JPA с ehcache, но пока безуспешно. Конфигурации, которые я делаю:

  • persistence.xml

    <persistence-unit name="customDatabase">
      <jta-data-source>jdbc/oracleXE_DS</jta-data-source>
      <class>com.td.waw.cse.entities.Product</class>
      <properties>
                       <property name="openjpa.Log" value="DefaultLevel=TRACE, Runtime=INFO, Tool=INFO, SQL=TRACE"/>
               <property name="openjpa.QueryCache" value="net.sf.ehcache.openjpa.datacache.EhCacheQueryCache"/>
       <property name="openjpa.DataCacheManager" value="net.sf.ehcache.openjpa.datacache.EhCacheDataCacheManager"/>
       <property name="openjpa.DataCache" value="net.sf.ehcache.openjpa.datacache.EhCacheDataCache"/>
       <property name="openjpa.RemoteCommitProvider" value="net.sf.ehcache.openjpa.datacache.NoOpRemoteCommitProvider"/>
    </properties>
    
  • ehcache.xml

    <ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:noNamespaceSchemaLocation="ehcache.xsd"
             updateCheck="true" monitoring="autodetect"
             dynamicConfig="true" >
        <defaultCache
        maxElementsInMemory="1000"
        eternal="false"
        timeToIdleSeconds="300"
        timeToLiveSeconds="600"
        overflowToDisk="false"
        memoryStoreEvictionPolicy="LRU"
        />
    
        <!-- OpenJPA data cache -->
        <cache name="openjpa"
        maxElementsInMemory="5000"
        eternal="false"
        timeToIdleSeconds="300"
        timeToLiveSeconds="600"
        overflowToDisk="false"
        memoryStoreEvictionPolicy="LRU"
        />
    
        <!-- OpenJPA query cache -->
        <cache name="openjpa-querycache"
        maxElementsInMemory="1000"
        eternal="false"
        timeToIdleSeconds="300"
        timeToLiveSeconds="600"
        overflowToDisk="false"
        memoryStoreEvictionPolicy="LRU"
        />
    </ehcache>
    
  • Product.java

    @Entity
    @Table(name="PRODUCT")
    @NamedQueries({@NamedQuery(name="getAllProducts", query = "select products from Product products")})
    public class Product implements Serializable {}
    

Я не получаю никаких исключений, но я не могу видеть, как работает ehcache, как что-то конкретное для ehcache, напечатанного в журналах. Буду очень признателен, если кто-то может помочь в этом.

Ответы [ 2 ]

4 голосов
/ 24 августа 2011

Добавьте следующие свойства в файле persistence.xml:

<property name="openjpa.QueryCache" value="ehcache"/>
<property name="openjpa.DataCacheManager" value="ehcache"/>

Добавьте следующие файлы в classpath: ehcache-core-2.4.4.jar, ehcache-openjpa-0.2.0.jar и slf4j-api-1.6.1.jar.

Вот и все.

Jar Загрузки:

Ссылки

0 голосов
/ 26 января 2011

DataNucleus отлично работает с EHCache, с конфигурацией, указанной здесь http://www.datanucleus.org/products/accessplatform_2_2/jpa/cache.html#ehcache Он будет печатать сообщения журнала о кеше L2 при каждом обращении к нему. Вы не упоминаете своего провайдера JPA.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...