In meiner Anwendung verwende ich das Hibernate-Core-4.1.8 jar und möchte ein ehCache als 2nd-Level-Cache nehmen. Das Glas, das ich derzeit verwende, ist ehcache-core-2.5.0. Ich habe es in meinen Ordner WebContetn/WEB-INF/lib gestellt und es auch in den Klassenpfad eingefügt.ehcache hibernate 4
Mein hibernate.cfg.xml sieht wie folgt aus:
<hibernate-configuration>
<session-factory>
....
<property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property>
<property name="hibernate.cache.use_second_level_cache">true</property>
<property name="hibernate.cache.use_query_cache">true</property>
</session-factory>
</hibernate-configuration>
die ehcache.xml die im JavaResources/src-Ordner abgelegt wird:
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="ehcache.xsd" updateCheck="true"
monitoring="autodetect" dynamicConfig="true">
<defaultCache
maxElementsInMemory="100000"
eternal="false"
timeToIdleSeconds="1000"
timeToLiveSeconds="1000"
overflowToDisk="false"
/>
</ehcache>
Wenn meine Anwendung die Klasse org läuft. hibernate.cache.ehcache.EhCacheRegionFactory nicht gefunden wird:
java.lang.ClassNotFoundException: Could not load requested class : org.hibernate.cache.ehcache.EhCacheRegionFactory
at org.hibernate.service.classloading.internal.ClassLoaderServiceImpl$1.findClass(ClassLoaderServiceImpl.java:99)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:264)
at org.hibernate.service.classloading.internal.ClassLoaderServiceImpl.classForName(ClassLoaderServiceImpl.java:138)
at org.hibernate.cfg.SettingsFactory.createRegionFactory(SettingsFactory.java:444)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:275)
at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2283)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2279)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1748)
at creator.controllers.MyFactory.<clinit>(MyFactory.java:18)
at creator.controllers.SchoolDAO.getList(SchoolDAO.java:98)
.....
nach dem Hinzufügen Ihr Glas sowie die Feinarbeiten slf4-api-1.7.2 scheint es (von http zu verlangen: // www.slf4j.org/download.html) zum Projekt :) danke! – chris
+1 Stimme für die Lösung meines Problems auch. –
jetzt funktioniert es auch für mich –