com.hazelcast.hibernate.instance.HazelcastInstanceLoader Maven / Gradle / Ivy
/*
* Copyright 2020 Hazelcast Inc.
*
* Licensed under the Hazelcast Community License (the "License"); you may not use
* this file except in compliance with the License. You may obtain a copy of the
* License at
*
* http://hazelcast.com/hazelcast-community-license
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
package com.hazelcast.hibernate.instance;
import com.hazelcast.config.Config;
import com.hazelcast.config.XmlConfigBuilder;
import com.hazelcast.core.Hazelcast;
import com.hazelcast.core.HazelcastInstance;
import com.hazelcast.hibernate.CacheEnvironment;
import com.hazelcast.internal.config.ConfigLoader;
import com.hazelcast.internal.util.StringUtil;
import com.hazelcast.logging.ILogger;
import com.hazelcast.logging.Logger;
import org.hibernate.cache.CacheException;
import java.io.IOException;
import java.util.Properties;
/**
* A factory implementation to build up a {@link HazelcastInstance}
* implementation using {@link Hazelcast}.
*/
class HazelcastInstanceLoader implements IHazelcastInstanceLoader {
private static final ILogger LOGGER = Logger.getLogger(IHazelcastInstanceFactory.class);
private HazelcastInstance instance;
private Config config;
private boolean shutDown;
private String existingInstanceName;
@Override
public void configure(final Properties props) {
String instanceName = CacheEnvironment.getInstanceName(props);
if (!StringUtil.isNullOrEmptyAfterTrim(instanceName)) {
LOGGER.info("Using existing HazelcastInstance [" + instanceName + "].");
this.existingInstanceName = instanceName;
} else {
String configResourcePath = CacheEnvironment.getConfigFilePath(props);
if (!StringUtil.isNullOrEmptyAfterTrim(configResourcePath)) {
try {
this.config = ConfigLoader.load(configResourcePath);
} catch (IOException e) {
LOGGER.warning("IOException: " + e.getMessage());
}
if (config == null) {
throw new CacheException("Could not find configuration file: " + configResourcePath);
}
} else {
this.config = new XmlConfigBuilder().build();
}
}
this.shutDown = CacheEnvironment.shutdownOnStop(props, (instanceName == null));
}
@Override
public HazelcastInstance loadInstance() throws CacheException {
if (existingInstanceName != null) {
instance = Hazelcast.getHazelcastInstanceByName(existingInstanceName);
if (instance == null) {
throw new CacheException("No instance with name [" + existingInstanceName + "] could be found.");
}
} else {
instance = Hazelcast.newHazelcastInstance(config);
}
return instance;
}
@Override
public void unloadInstance() throws CacheException {
if (instance == null) {
return;
}
if (!shutDown) {
LOGGER.warning(CacheEnvironment.SHUTDOWN_ON_STOP + " property is set to 'false'. "
+ "Leaving current HazelcastInstance active! (Warning: Do not disable Hazelcast "
+ CacheEnvironment.HAZELCAST_SHUTDOWN_HOOK_ENABLED + " property!)");
return;
}
try {
instance.getLifecycleService().shutdown();
instance = null;
} catch (Exception e) {
throw new CacheException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy