2011-01-25 26 views
5

JPA'yı ehcache ile yapılandırmaya çalışıyorum ama şimdiye kadar başarı yok. i yaptığım yapılandırmaları aşağıdaki gibidir:ehcache ile JPA yapılamıyor

  • 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 {} 
    

Hiç bir istisna alamıyorum, ancak ehcache'yi günlüklerde basılmış olan ehcache'ye özel bir şey olarak göremedim. Birisi buna yardımcı olabilirse gerçekten çok memnun olurum.

+0

yığın taşması _not_ bir forumdur, göndermek etmeyiniz Sorunuzdaki sorunu çözmeyen bir cevap. Kendinize uzun kod snippet'leri gönderiyorsanız, _question_ öğenizin bir parçası olmalıdır. Birkaç cevabını kaldırdım. –

cevap

4

persistence.xml aşağıdaki özellikleri ekleyin:

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

sınıf yolunda aşağıdaki kavanoz ekleyin: ehcache-core-2.4.4.jar, ehcache-openjpa-0.2.0.jar ve slf4j-api-1.6.1.jar.

Hepsi bu kadar.

Kavanoz indirme:

Kaynaklar