/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.component.cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.config.Configuration;
import org.apache.camel.support.ServiceSupport;
import org.apache.camel.util.ReflectionHelper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public abstract class CacheManagerFactory extends ServiceSupport {
private static final Logger LOG = LoggerFactory.getLogger(CacheManagerFactory.class);
private CacheManager cacheManager;
public synchronized CacheManager getInstance() {
if (cacheManager == null) {
cacheManager = createCacheManagerInstance();
// always turn off ET phone-home
LOG.debug("Turning off EHCache update checker ...");
Configuration config = cacheManager.getConfiguration();
try {
// need to set both the system property and bypass the setUpdateCheck method as that can be changed dynamically
System.setProperty("net.sf.ehcache.skipUpdateCheck", "true");
ReflectionHelper.setField(config.getClass().getDeclaredField("updateCheck"), config, false);
LOG.info("Turned off EHCache update checker. updateCheck={}", config.getUpdateCheck());
} catch (Throwable e) {
// ignore
LOG.warn("Error turning off EHCache update checker. Beware information sent over the internet!", e);
}
}
return cacheManager;
}
/**
* Creates {@link CacheManager}.
* <p/>
* The default implementation is {@link DefaultCacheManagerFactory}.
*
* @return {@link CacheManager}
*/
protected abstract CacheManager createCacheManagerInstance();
@Override
protected void doStart() throws Exception {
}
@Override
protected synchronized void doStop() throws Exception {
// only shutdown cache manager if no longer in use
// (it may be reused when running in app servers like Karaf)
if (cacheManager != null) {
int size = cacheManager.getCacheNames().length;
if (size <= 0) {
LOG.info("Shutting down CacheManager as its no longer in use");
cacheManager.shutdown();
cacheManager = null;
} else {
LOG.info("Cannot stop CacheManager as its still in use by {} clients", size);
}
}
}
}