com.glaf.core.cache.CacheFactory.java Source code

Java tutorial

Introduction

Here is the source code for com.glaf.core.cache.CacheFactory.java

Source

/*
 * 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 com.glaf.core.cache;

import java.util.*;
import java.util.concurrent.Callable;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.glaf.core.config.BaseConfiguration;
import com.glaf.core.config.Configuration;
import com.glaf.core.config.CustomProperties;
import com.glaf.core.config.Environment;
import com.glaf.core.config.SystemProperties;
import com.glaf.core.context.ContextFactory;

public class CacheFactory {
    protected static final Log logger = LogFactory.getLog(CacheFactory.class);
    protected static final String DEFAULT_CONFIG = "com/glaf/core/cache/guava/guavacache-context.xml";
    protected static final ConcurrentMap<String, Cache> cacheMap = new ConcurrentHashMap<String, Cache>();
    protected static final List<CacheItem> items = new CopyOnWriteArrayList<CacheItem>();
    protected static Configuration conf = BaseConfiguration.create();
    protected static ExecutorService pool = Executors.newFixedThreadPool(50);
    private static volatile ApplicationContext ctx;
    private static String CACHE_PREFIX = "GLAF_";

    protected static void clearAll() {
        try {
            Cache cache = getCache();
            if (cache != null) {
                for (CacheItem item : items) {
                    cache.remove(item.getKey());
                }
                cache.clear();
            }
            logger.info("cache clear ok.");
        } catch (Exception ex) {
            if (logger.isDebugEnabled()) {
                ex.printStackTrace();
                logger.debug(ex);
            }
        } finally {
            items.clear();
        }
    }

    public static List<CacheItem> getCacheItems() {
        return items;
    }

    public static ApplicationContext getApplicationContext() {
        return ctx;
    }

    public static Object getBean(Object name) {
        if (ctx == null) {
            ctx = reload();
        }
        return ctx.getBean((String) name);
    }

    protected static Cache getCache() {
        String beanId = "cache";
        Cache cache = null;
        if (conf.getBoolean("glaf.cache.useEhCache", false)) {
            logger.debug("use ehcache...");
            cache = ContextFactory.getBean(beanId);
        } else {
            cache = (Cache) getBean(beanId);
        }
        if (cache != null) {
            cacheMap.put(beanId, cache);
        }
        return cache;
    }

    public static String getString(final String key) {
        boolean waitFor = true;
        Callable<String> task = new Callable<String>() {
            @Override
            public String call() throws Exception {
                try {
                    Cache cache = getCache();
                    if (cache != null) {
                        String cacheKey = Environment.getCurrentSystemName() + "_" + CACHE_PREFIX + key;
                        if (SystemProperties.getDeploymentSystemName() != null) {
                            cacheKey = SystemProperties.getDeploymentSystemName() + "_"
                                    + Environment.getCurrentSystemName() + "_" + CACHE_PREFIX + key;
                        }
                        cacheKey = DigestUtils.md5Hex(cacheKey.getBytes());
                        Object value = cache.get(cacheKey);
                        if (value != null) {
                            logger.debug("get object'" + key + "' from cache.");
                            return value.toString();
                        }
                    }
                } catch (Exception ex) {
                    if (logger.isDebugEnabled()) {
                        ex.printStackTrace();
                        logger.debug(ex);
                    }
                }
                return null;
            }
        };

        try {
            Future<String> result = pool.submit(task);
            long start = System.currentTimeMillis();
            // ?
            if (waitFor) {
                while (true) {
                    if (System.currentTimeMillis() - start > 2000) {
                        break;
                    }
                    if (result.isDone()) {
                        return result.get();
                    }
                }
            }
        } catch (Exception e) {
            logger.error(e);
        }

        return null;
    }

    public static void put(final String key, final String value) {
        try {
            Cache cache = getCache();
            if (cache != null && key != null && value != null) {
                String cacheKey = Environment.getCurrentSystemName() + "_" + CACHE_PREFIX + key;
                if (SystemProperties.getDeploymentSystemName() != null) {
                    cacheKey = SystemProperties.getDeploymentSystemName() + "_" + Environment.getCurrentSystemName()
                            + "_" + CACHE_PREFIX + key;
                }
                cacheKey = DigestUtils.md5Hex(cacheKey.getBytes());
                int limitSize = conf.getInt("cache.limitSize", 1024000);// 1024KB
                if (value.length() < limitSize) {
                    cache.put(cacheKey, value);
                    CacheItem item = new CacheItem();
                    item.setName(key);
                    item.setKey(cacheKey);
                    item.setLastModified(System.currentTimeMillis());
                    item.setSize(value.length());
                    items.add(item);
                }
            }
        } catch (Exception ex) {
            if (logger.isDebugEnabled()) {
                ex.printStackTrace();
                logger.debug(ex);
            }
        }
    }

    protected static ApplicationContext reload() {
        try {
            if (null != ctx) {
                Cache cache = getCache();
                if (cache != null) {
                    items.clear();
                    cache.clear();
                }
                ctx = null;
            }

            String configLocation = DEFAULT_CONFIG;

            if (CustomProperties.getString("sys.cache.context") != null) {
                configLocation = CustomProperties.getString("sys.cache.context");
            }

            ctx = new ClassPathXmlApplicationContext(configLocation);
            logger.info("################# CacheFactory ##############");
            logger.info("cache config: " + configLocation);
            return ctx;
        } catch (Exception ex) {
            if (logger.isDebugEnabled()) {
                ex.printStackTrace();
                logger.debug(ex);
            }
            throw new CacheException("can't reload cache", ex);
        }
    }

    public static void remove(String key) {
        try {
            Cache cache = getCache();
            if (cache != null) {
                String cacheKey = Environment.getCurrentSystemName() + "_" + CACHE_PREFIX + key;
                if (SystemProperties.getDeploymentSystemName() != null) {
                    cacheKey = SystemProperties.getDeploymentSystemName() + "_" + Environment.getCurrentSystemName()
                            + "_" + CACHE_PREFIX + key;
                }
                cacheKey = DigestUtils.md5Hex(cacheKey.getBytes());
                cache.remove(cacheKey);
                items.remove(new CacheItem(cacheKey));
            }
        } catch (Exception ex) {
            if (logger.isDebugEnabled()) {
                ex.printStackTrace();
                logger.debug(ex);
            }
        }
    }

    protected static void shutdown() {
        try {
            Cache cache = getCache();
            if (cache != null) {
                items.clear();
                cache.clear();
            }
        } catch (Exception ex) {
            if (logger.isDebugEnabled()) {
                ex.printStackTrace();
                logger.debug(ex);
            }
        }
    }

}