935090232@qq.com
2021-10-25 2151a5efbac31c1f6a1b2563ccb352170aa48c9c
新增本地缓存
1 files added
2 files modified
155 ■■■■ changed files
zq-erp/src/main/java/com/matrix/system/common/actions/DeveloperAction.java 4 ●●●● patch | view | raw | blame | history
zq-erp/src/main/java/com/matrix/system/common/init/LocalCache.java 116 ●●●● patch | view | raw | blame | history
zq-erp/src/test/java/com/matrix/LocalCacheTest.java 35 ●●●●● patch | view | raw | blame | history
zq-erp/src/main/java/com/matrix/system/common/actions/DeveloperAction.java
@@ -3,7 +3,7 @@
import com.matrix.core.constance.MatrixConstance;
import com.matrix.core.pojo.AjaxResult;
import com.matrix.core.web.BaseAction;
import com.matrix.system.common.init.InitWebContainer;
import com.matrix.system.common.init.LocalCache;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
@@ -76,7 +76,7 @@
    @RequestMapping("/getLocalCache")
    public @ResponseBody AjaxResult getLocalCache(String key) {
        Object cache=InitWebContainer.getLocalCache(key);
        Object cache= LocalCache.get(key);
        return AjaxResult.buildSuccessInstance(cache);
    }
zq-erp/src/main/java/com/matrix/system/common/init/LocalCache.java
@@ -1,73 +1,135 @@
package com.matrix.system.common.init;
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import com.matrix.core.tools.LogUtil;
import java.util.Date;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.*;
public class LocalCache {
    /*
     * 清理线程运行状态 0 未启动,1 已启动
     */
    private static int CLEAR_THREAD_STATUS = 0;
    private static ConcurrentMap<String,Value> localCache=new ConcurrentHashMap(60);
    private static ConcurrentMap<String, Value> localCache = new ConcurrentHashMap(60);
    /**
     * 获取本地缓存
     *
     * @param key
     * @param <T>
     * @return
     */
    public static <T> T get(String key){
        return (T)localCache.get(key);
    public static <T> T get(String key) {
        return (T) localCache.get(key);
    }
    /**
     * 保存一个本地缓存
     *
     * @param key
     * @param value
     */
    public static void save(String key,Object value){
        if(null!=localCache.put(key,value)){
            LogUtil.debug("覆盖原有缓存{}",key);
    public static void save(String key, Object value) {
        if (null != localCache.put(key, buildValue(value))) {
            LogUtil.debug("覆盖原有缓存{}", key);
        }
    }
    public static void save(String key,Object value,long timeOut){
        if(null!=localCache.put(key,value)){
            LogUtil.debug("覆盖原有缓存{}",key);
    /**
     * 设置含过期时间的缓存
     *
     * @param key
     * @param value
     * @param timeOut 毫秒
     */
    public static void save(String key, Object value, long timeOut) {
        if (null != localCache.put(key, buildValue(value, timeOut))) {
            LogUtil.debug("覆盖原有缓存{}", key);
        }
        startClearThread();
    }
    /**
     * 清理过期对象
     */
    private synchronized static void startClearThread() {
        if (CLEAR_THREAD_STATUS == 0) {
            ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
                    .setNameFormat("demo-pool-%d").build();
            ExecutorService singleThreadPool = new ThreadPoolExecutor(1, 1,
                    0L, TimeUnit.MILLISECONDS,
                    new LinkedBlockingQueue<Runnable>(1), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
            singleThreadPool.execute(() -> {
                CLEAR_THREAD_STATUS = 1;
                while (true) {
                    try {
                        Set<Map.Entry<String, Value>> entries = localCache.entrySet();
                        Iterator<Map.Entry<String, Value>> iterator = entries.iterator();
                        while (iterator.hasNext()) {
                            Map.Entry<String, Value> next = iterator.next();
                            if (next.getValue().timeOut == 0) {
                                continue;
                            }
                            boolean isTimeOut = (System.currentTimeMillis() - next.getValue().createTime) > next.getValue().timeOut;
                            if (isTimeOut) {
                                Value removed = localCache.remove(next.getKey());
                                LogUtil.debug("清除过期对象:{}", removed.value);
                            }
                        }
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        LogUtil.error("清理缓存线程异常停止", e);
                        CLEAR_THREAD_STATUS = 0;
                    }
                }
            });
        }
    }
    private static Value buildValue(Object value) {
        return buildValue(value, 0);
    }
    private static Value buildValue(Object value, long timeOut) {
        Value instances = new Value();
        instances.createTime = System.currentTimeMillis();
        instances.value = value;
        instances.timeOut = timeOut;
        return instances;
    }
    /**
     * 缓存对象
     */
     class Value{
    static class Value {
        /**
         * 过期时间,0 表示不过期
         * 过期时间,0 表示不过期,单位毫秒
         */
      private long timeOut=0;
        private long timeOut = 0;
        /**
         * 缓存值
         */
      private Object value;
        private Object value;
        /**
         * 缓存创建时间
         */
      private long createTime;
        private long createTime;
      public static Value build(String value,long timeOut){
          Value instances=new Value();
          instances.createTime=System.currentTimeMillis();
          instances.value=value;
          instances.timeOut=timeOut;
          return instances;
      }
    }
zq-erp/src/test/java/com/matrix/LocalCacheTest.java
New file
@@ -0,0 +1,35 @@
/**
 * projectName: zq-erp
 * fileName: LocalCacheTest.java
 * packageName: com.matrix
 * date: 2021-10-25 14:03
 * copyright(c) 2021 http://www.hydee.cn/ Inc. All rights reserved.
 */
package com.matrix;
import com.matrix.system.common.init.LocalCache;
import org.junit.Assert;
import org.junit.Test;
import java.io.IOException;
/**
 * @version: V1.0
 * @author: JiangYouYao
 * @className: LocalCacheTest
 * @packageName: com.matrix
 * @description: LocalCache
 * @data: 2021-10-25 14:03
 **/
public class LocalCacheTest {
    @Test
    public void testNoticeTask() throws IOException, InterruptedException {
        LocalCache.save("name","jyy",1000*3);
        System.out.println("放入对象");
        Assert.assertNotNull(LocalCache.get("name"));
        Thread.sleep(1000*5);
        Assert.assertNull(LocalCache.get("name"));
    }
}