HHH-7943 Added support for ehcache and infinispan strategies and OSGi
services. Numerous ehcache and infinispan CL fixes.
This commit is contained in:
parent
9d134955c4
commit
489ee4a734
|
@ -28,24 +28,28 @@ import java.util.Map;
|
||||||
import org.hibernate.boot.registry.StandardServiceInitiator;
|
import org.hibernate.boot.registry.StandardServiceInitiator;
|
||||||
import org.hibernate.boot.registry.selector.spi.StrategySelector;
|
import org.hibernate.boot.registry.selector.spi.StrategySelector;
|
||||||
import org.hibernate.cache.spi.RegionFactory;
|
import org.hibernate.cache.spi.RegionFactory;
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
import org.hibernate.internal.CoreMessageLogger;
|
||||||
|
import org.hibernate.internal.util.config.ConfigurationHelper;
|
||||||
import org.hibernate.service.spi.ServiceRegistryImplementor;
|
import org.hibernate.service.spi.ServiceRegistryImplementor;
|
||||||
|
import org.jboss.logging.Logger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initiator for the {@link RegionFactory} service.
|
* Initiator for the {@link RegionFactory} service.
|
||||||
*
|
*
|
||||||
* @author Hardy Ferentschik
|
* @author Hardy Ferentschik
|
||||||
|
* @author Brett Meyer
|
||||||
*/
|
*/
|
||||||
public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFactory> {
|
public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFactory> {
|
||||||
|
|
||||||
|
private static final CoreMessageLogger LOG = Logger.getMessageLogger( CoreMessageLogger.class,
|
||||||
|
RegionFactoryInitiator.class.getName() );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Singleton access
|
* Singleton access
|
||||||
*/
|
*/
|
||||||
public static final RegionFactoryInitiator INSTANCE = new RegionFactoryInitiator();
|
public static final RegionFactoryInitiator INSTANCE = new RegionFactoryInitiator();
|
||||||
|
|
||||||
/**
|
|
||||||
* Property name to use to configure the full qualified class name for the {@code RegionFactory}
|
|
||||||
*/
|
|
||||||
public static final String IMPL_NAME = "hibernate.cache.region.factory_class";
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Class<RegionFactory> getServiceInitiated() {
|
public Class<RegionFactory> getServiceInitiated() {
|
||||||
return RegionFactory.class;
|
return RegionFactory.class;
|
||||||
|
@ -54,18 +58,32 @@ public class RegionFactoryInitiator implements StandardServiceInitiator<RegionFa
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings({ "unchecked" })
|
@SuppressWarnings({ "unchecked" })
|
||||||
public RegionFactory initiateService(Map configurationValues, ServiceRegistryImplementor registry) {
|
public RegionFactory initiateService(Map configurationValues, ServiceRegistryImplementor registry) {
|
||||||
final Object setting = configurationValues.get( IMPL_NAME );
|
boolean useSecondLevelCache = ConfigurationHelper.getBoolean( AvailableSettings.USE_SECOND_LEVEL_CACHE,
|
||||||
return registry.getService( StrategySelector.class ).resolveDefaultableStrategy(
|
configurationValues, true );
|
||||||
RegionFactory.class,
|
boolean useQueryCache = ConfigurationHelper.getBoolean( AvailableSettings.USE_QUERY_CACHE, configurationValues );
|
||||||
setting,
|
|
||||||
NoCachingRegionFactory.INSTANCE
|
RegionFactory regionFactory;
|
||||||
);
|
|
||||||
|
// The cache provider is needed when we either have second-level cache enabled
|
||||||
|
// or query cache enabled. Note that useSecondLevelCache is enabled by default
|
||||||
|
if ( useSecondLevelCache || useQueryCache ) {
|
||||||
|
final Object setting = configurationValues.get( AvailableSettings.CACHE_REGION_FACTORY );
|
||||||
|
regionFactory = registry.getService( StrategySelector.class ).resolveDefaultableStrategy(
|
||||||
|
RegionFactory.class, setting, NoCachingRegionFactory.INSTANCE );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
regionFactory = NoCachingRegionFactory.INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.debugf( "Cache region factory : %s", regionFactory.getClass().getName() );
|
||||||
|
|
||||||
|
return regionFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Map legacy names unto the new corollary.
|
* Map legacy names unto the new corollary.
|
||||||
*
|
*
|
||||||
* todo this shouldn't be public, nor really static. hack for org.hibernate.cfg.SettingsFactory.createRegionFactory()
|
* TODO: temporary hack for org.hibernate.cfg.SettingsFactory.createRegionFactory()
|
||||||
*
|
*
|
||||||
* @param name The (possibly legacy) factory name
|
* @param name The (possibly legacy) factory name
|
||||||
*
|
*
|
||||||
|
|
|
@ -290,9 +290,7 @@ public class SettingsFactory implements Serializable {
|
||||||
settings.setQueryCacheFactory( createQueryCacheFactory( properties, serviceRegistry ) );
|
settings.setQueryCacheFactory( createQueryCacheFactory( properties, serviceRegistry ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
// The cache provider is needed when we either have second-level cache enabled
|
settings.setRegionFactory( serviceRegistry.getService( RegionFactory.class ) );
|
||||||
// or query cache enabled. Note that useSecondLevelCache is enabled by default
|
|
||||||
settings.setRegionFactory( createRegionFactory( properties, ( useSecondLevelCache || useQueryCache ), serviceRegistry ) );
|
|
||||||
|
|
||||||
boolean useMinimalPuts = ConfigurationHelper.getBoolean(
|
boolean useMinimalPuts = ConfigurationHelper.getBoolean(
|
||||||
AvailableSettings.USE_MINIMAL_PUTS, properties, settings.getRegionFactory().isMinimalPutsEnabledByDefault()
|
AvailableSettings.USE_MINIMAL_PUTS, properties, settings.getRegionFactory().isMinimalPutsEnabledByDefault()
|
||||||
|
@ -437,39 +435,6 @@ public class SettingsFactory implements Serializable {
|
||||||
throw new HibernateException( "could not instantiate QueryCacheFactory: " + queryCacheFactoryClassName, e );
|
throw new HibernateException( "could not instantiate QueryCacheFactory: " + queryCacheFactoryClassName, e );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static RegionFactory createRegionFactory(Properties properties, boolean cachingEnabled, ServiceRegistry serviceRegistry) {
|
|
||||||
String regionFactoryClassName = RegionFactoryInitiator.mapLegacyNames(
|
|
||||||
ConfigurationHelper.getString(
|
|
||||||
AvailableSettings.CACHE_REGION_FACTORY, properties, null
|
|
||||||
)
|
|
||||||
);
|
|
||||||
if ( regionFactoryClassName == null || !cachingEnabled) {
|
|
||||||
regionFactoryClassName = DEF_CACHE_REG_FACTORY;
|
|
||||||
}
|
|
||||||
LOG.debugf( "Cache region factory : %s", regionFactoryClassName );
|
|
||||||
try {
|
|
||||||
try {
|
|
||||||
return (RegionFactory) serviceRegistry.getService( ClassLoaderService.class )
|
|
||||||
.classForName( regionFactoryClassName )
|
|
||||||
.getConstructor( Properties.class )
|
|
||||||
.newInstance( properties );
|
|
||||||
}
|
|
||||||
catch ( NoSuchMethodException e ) {
|
|
||||||
// no constructor accepting Properties found, try no arg constructor
|
|
||||||
LOG.debugf(
|
|
||||||
"%s did not provide constructor accepting java.util.Properties; attempting no-arg constructor.",
|
|
||||||
regionFactoryClassName
|
|
||||||
);
|
|
||||||
return (RegionFactory) serviceRegistry.getService( ClassLoaderService.class )
|
|
||||||
.classForName( regionFactoryClassName )
|
|
||||||
.newInstance();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch ( Exception e ) {
|
|
||||||
throw new HibernateException( "could not instantiate RegionFactory [" + regionFactoryClassName + "]", e );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//todo remove this once we move to new metamodel
|
//todo remove this once we move to new metamodel
|
||||||
public static RegionFactory createRegionFactory(Properties properties, boolean cachingEnabled) {
|
public static RegionFactory createRegionFactory(Properties properties, boolean cachingEnabled) {
|
||||||
// todo : REMOVE! THIS IS TOTALLY A TEMPORARY HACK FOR org.hibernate.cfg.AnnotationBinder which will be going away
|
// todo : REMOVE! THIS IS TOTALLY A TEMPORARY HACK FOR org.hibernate.cfg.AnnotationBinder which will be going away
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.cache.ehcache;
|
package org.hibernate.cache.ehcache;
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
@ -205,6 +206,14 @@ abstract class AbstractEhcacheRegionFactory implements RegionFactory {
|
||||||
if ( url == null ) {
|
if ( url == null ) {
|
||||||
url = AbstractEhcacheRegionFactory.class.getResource( configurationResourceName );
|
url = AbstractEhcacheRegionFactory.class.getResource( configurationResourceName );
|
||||||
}
|
}
|
||||||
|
if ( url == null ) {
|
||||||
|
try {
|
||||||
|
url = new URL( configurationResourceName );
|
||||||
|
}
|
||||||
|
catch ( MalformedURLException e ) {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if ( LOG.isDebugEnabled() ) {
|
if ( LOG.isDebugEnabled() ) {
|
||||||
LOG.debugf(
|
LOG.debugf(
|
||||||
|
|
|
@ -89,13 +89,7 @@ public class EhCacheRegionFactory extends AbstractEhcacheRegionFactory {
|
||||||
manager = new CacheManager( configuration );
|
manager = new CacheManager( configuration );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
URL url;
|
URL url = loadResource( configurationResourceName );
|
||||||
try {
|
|
||||||
url = new URL( configurationResourceName );
|
|
||||||
}
|
|
||||||
catch (MalformedURLException e) {
|
|
||||||
url = loadResource( configurationResourceName );
|
|
||||||
}
|
|
||||||
final Configuration configuration = HibernateEhcacheUtils.loadAndCorrectConfiguration( url );
|
final Configuration configuration = HibernateEhcacheUtils.loadAndCorrectConfiguration( url );
|
||||||
manager = new CacheManager( configuration );
|
manager = new CacheManager( configuration );
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,6 +48,7 @@ public class StrategyRegistrationProviderImpl implements StrategyRegistrationPro
|
||||||
RegionFactory.class,
|
RegionFactory.class,
|
||||||
EhCacheRegionFactory.class,
|
EhCacheRegionFactory.class,
|
||||||
"ehcache",
|
"ehcache",
|
||||||
|
EhCacheRegionFactory.class.getName(),
|
||||||
EhCacheRegionFactory.class.getSimpleName(),
|
EhCacheRegionFactory.class.getSimpleName(),
|
||||||
// legacy impl class name
|
// legacy impl class name
|
||||||
"org.hibernate.cache.EhCacheRegionFactory"
|
"org.hibernate.cache.EhCacheRegionFactory"
|
||||||
|
@ -59,6 +60,7 @@ public class StrategyRegistrationProviderImpl implements StrategyRegistrationPro
|
||||||
RegionFactory.class,
|
RegionFactory.class,
|
||||||
SingletonEhCacheRegionFactory.class,
|
SingletonEhCacheRegionFactory.class,
|
||||||
"ehcache-singleton",
|
"ehcache-singleton",
|
||||||
|
SingletonEhCacheRegionFactory.class.getName(),
|
||||||
SingletonEhCacheRegionFactory.class.getSimpleName(),
|
SingletonEhCacheRegionFactory.class.getSimpleName(),
|
||||||
// legacy impl class name
|
// legacy impl class name
|
||||||
"org.hibernate.cache.SingletonEhCacheRegionFactory"
|
"org.hibernate.cache.SingletonEhCacheRegionFactory"
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
|
<blueprint default-activation="eager"
|
||||||
|
xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
|
||||||
|
<bean id="strategyRegistrationProvider" class="org.hibernate.cache.ehcache.StrategyRegistrationProviderImpl"/>
|
||||||
|
<service ref="strategyRegistrationProvider" interface="org.hibernate.boot.registry.selector.StrategyRegistrationProvider"/>
|
||||||
|
|
||||||
|
</blueprint>
|
|
@ -1,5 +1,6 @@
|
||||||
package org.hibernate.cache.infinispan;
|
package org.hibernate.cache.infinispan;
|
||||||
|
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -388,8 +389,18 @@ public class InfinispanRegionFactory implements RegionFactory {
|
||||||
String configLoc = ConfigurationHelper.getString(
|
String configLoc = ConfigurationHelper.getString(
|
||||||
INFINISPAN_CONFIG_RESOURCE_PROP, properties, DEF_INFINISPAN_CONFIG_RESOURCE);
|
INFINISPAN_CONFIG_RESOURCE_PROP, properties, DEF_INFINISPAN_CONFIG_RESOURCE);
|
||||||
ClassLoader classLoader = ClassLoaderHelper.getContextClassLoader();
|
ClassLoader classLoader = ClassLoaderHelper.getContextClassLoader();
|
||||||
InputStream is = FileLookupFactory.newInstance().lookupFileStrict(
|
InputStream is;
|
||||||
|
try {
|
||||||
|
is = FileLookupFactory.newInstance().lookupFileStrict(
|
||||||
configLoc, classLoader);
|
configLoc, classLoader);
|
||||||
|
}
|
||||||
|
catch ( FileNotFoundException e ) {
|
||||||
|
// In some environments (ex: OSGi), hibernate-infinispan may not
|
||||||
|
// be in the app CL. It's important to also try this CL.
|
||||||
|
classLoader = this.getClass().getClassLoader();
|
||||||
|
is = FileLookupFactory.newInstance().lookupFileStrict(
|
||||||
|
configLoc, classLoader);
|
||||||
|
}
|
||||||
ParserRegistry parserRegistry = new ParserRegistry(classLoader);
|
ParserRegistry parserRegistry = new ParserRegistry(classLoader);
|
||||||
ConfigurationBuilderHolder holder = parserRegistry.parse(is);
|
ConfigurationBuilderHolder holder = parserRegistry.parse(is);
|
||||||
|
|
||||||
|
|
|
@ -47,6 +47,7 @@ public class StrategyRegistrationProviderImpl implements StrategyRegistrationPro
|
||||||
RegionFactory.class,
|
RegionFactory.class,
|
||||||
InfinispanRegionFactory.class,
|
InfinispanRegionFactory.class,
|
||||||
"infinispan",
|
"infinispan",
|
||||||
|
InfinispanRegionFactory.class.getName(),
|
||||||
InfinispanRegionFactory.class.getSimpleName()
|
InfinispanRegionFactory.class.getSimpleName()
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -56,6 +57,7 @@ public class StrategyRegistrationProviderImpl implements StrategyRegistrationPro
|
||||||
RegionFactory.class,
|
RegionFactory.class,
|
||||||
JndiInfinispanRegionFactory.class,
|
JndiInfinispanRegionFactory.class,
|
||||||
"infinispan-jndi",
|
"infinispan-jndi",
|
||||||
|
JndiInfinispanRegionFactory.class.getName(),
|
||||||
JndiInfinispanRegionFactory.class.getSimpleName()
|
JndiInfinispanRegionFactory.class.getSimpleName()
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
org.hibernate.cache.infinispan.StrategyRegistrationProviderImpl
|
|
@ -0,0 +1,10 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
|
<blueprint default-activation="eager"
|
||||||
|
xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
|
||||||
|
<bean id="strategyRegistrationProvider" class="org.hibernate.cache.infinispan.StrategyRegistrationProviderImpl"/>
|
||||||
|
<service ref="strategyRegistrationProvider" interface="org.hibernate.boot.registry.selector.StrategyRegistrationProvider"/>
|
||||||
|
|
||||||
|
</blueprint>
|
Loading…
Reference in New Issue