All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.vip.saturn.job.sharding.entity.ShardingTreeCache Maven / Gradle / Ivy

package com.vip.saturn.job.sharding.entity;

import org.apache.curator.framework.recipes.cache.TreeCache;
import org.apache.curator.framework.recipes.cache.TreeCacheListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.*;

/**
 * @author hebelala
 */
public class ShardingTreeCache {

    private static final Logger logger = LoggerFactory.getLogger(ShardingTreeCache.class);

    private Map treeCacheMap = new HashMap();
    private Map> treeCacheListenerMap = new HashMap>();

    private String getKey(String path, int depth) {
        return path + depth;
    }

    public boolean containsTreeCache(String path, int depth) {
        synchronized (this) {
            return treeCacheMap.containsKey(getKey(path, depth));
        }
    }

    public void putTreeCache(String path, int depth, TreeCache treeCache) {
        synchronized (this) {
            treeCacheMap.put(getKey(path, depth), treeCache);
            treeCacheListenerMap.put(treeCache, new ArrayList());
        }
    }

    public TreeCache putTreeCacheIfAbsent(String path, int depth, TreeCache treeCache) {
        synchronized (this) {
            String key = getKey(path, depth);
            if(!treeCacheMap.containsKey(key)) {
                treeCacheMap.put(key, treeCache);
                treeCacheListenerMap.put(treeCache, new ArrayList());
                return null;
            } else {
                return treeCacheMap.get(key);
            }
        }
    }

    public TreeCacheListener addTreeCacheListenerIfAbsent(String path, int depth, TreeCacheListener treeCacheListener) {
        synchronized (this) {
            TreeCacheListener treeCacheListenerOld = null;
            String key = getKey(path, depth);
            TreeCache treeCache = treeCacheMap.get(key);
            if(treeCache == null) {
                logger.error("The TreeCache is not exists, cannot add TreeCacheListener, path is {}, depth is {}", path, depth);
            } else {
                List treeCacheListeners = treeCacheListenerMap.get(treeCache);
                boolean included = false;
                for(TreeCacheListener tmp : treeCacheListeners) {
                    Class tmpClass = tmp.getClass();
                    Class treeCacheListenerClass = treeCacheListener.getClass();
                    if(tmpClass.equals(treeCacheListenerClass)) {
                        treeCacheListenerOld = tmp;
                        included = true;
                        break;
                    }
                }
                if(included) {
                    logger.error("The TreeCache has already included the instance of listener, will not be added, path is {}, depth is {}, listener is {}", path, depth,  treeCacheListener.getClass());
                } else {
                    treeCacheListeners.add(treeCacheListener);
                    treeCache.getListenable().addListener(treeCacheListener);
                }
            }
            return treeCacheListenerOld;
        }
    }

    public void removeTreeCache(String path, int depth) {
        synchronized (this) {
            String key = getKey(path, depth);
            TreeCache treeCache = treeCacheMap.get(key);
            if(treeCache != null) {
                treeCacheListenerMap.remove(treeCache);
                treeCacheMap.remove(key);
                treeCache.close();
                logger.info("remove TreeCache success, path is {}, depth is {}", path, depth);
            }
        }
    }

    public void shutdown() {
        synchronized (this) {
            Iterator> iterator = treeCacheMap.entrySet().iterator();
            while(iterator.hasNext()) {
                Map.Entry next = iterator.next();
                try {
                    next.getValue().close();
                } catch (Exception e) {
                    logger.error(e.getMessage(), e);
                }
                iterator.remove();
            }
            treeCacheListenerMap.clear();
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy