ConcurrentHashMap实现缓存功能

java 复制代码
public class CacheUtil<K, V>{
    private final ConcurrentHashMap<K, CacheEntry<V>> cache = new ConcurrentHashMap<>();
    private final long ttl; // 缓存过期时间,单位:毫秒

    // 缓存条目类
    private static class CacheEntry<V> {
        V value;
        long expirationTime;

        CacheEntry(V value, long ttl) {
            this.value = value;
            this.expirationTime = System.currentTimeMillis() + ttl;
        }

        boolean isExpired() {
            return System.currentTimeMillis() > expirationTime;
        }
    }

    public CacheUtil(long ttl) {
        this.ttl = ttl; // 设置缓存的过期时间
    }

    // 添加缓存
    public void put(K key, V value) {
        cache.put(key, new CacheEntry<>(value, ttl));
    }

    // 获取缓存
    public V get(K key) {
        CacheEntry<V> entry = cache.get(key);
        if (entry == null || entry.isExpired()) {
            // 如果条目不存在或已过期,则移除并返回 null
            cache.remove(key);
            return null;
        }
        return entry.value;
    }

    // 清除缓存
    public void remove(K key) {
        cache.remove(key);
    }

    // 清空整个缓存
    public void clear() {
        cache.clear();
    }

    // 检查缓存是否存在
    public boolean containsKey(K key) {
        return cache.containsKey(key) && !cache.get(key).isExpired();
    }
}
java 复制代码
@Component
public class DingDingJobAlarm implements JobAlarm {
// 创建一个缓存工具,设置 TTL 为 一天
    private final CacheUtil<String, List<XxlJobGroup>> cache = new CacheUtil<>(60 * 1000 * 60 * 24);

@Override
    public boolean doAlarm(XxlJobInfo info, XxlJobLog jobLog) {
String redisKey = "spy:xxljob:group:info";

try {

List<XxlJobGroup> xxlJobGroups = cache.get(redisKey);
            if (CollectionUtils.isEmpty(xxlJobGroups) || !cache.containsKey(redisKey)) {
                xxlJobGroups = xxlJobGroupDao.findAll();
                cache.put(redisKey, xxlJobGroups);
            }


}catch (Exception e) {
            log.error("xxlJob系统发送钉钉消息异常=", e);
        }
}

}

xxlJobGroups 就是我的目标数据

java 复制代码
package com.xxl.job.admin.core.model;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

/**
 * Created by xuxueli on 16/9/30.
 */
public class XxlJobGroup {

    private int id;
    private String appname;
    private String title;
    private int addressType;        // 执行器地址类型:0=自动注册、1=手动录入
    private String addressList;     // 执行器地址列表,多地址逗号分隔(手动录入)
    private Date updateTime;

    // registry list
    private List<String> registryList;  // 执行器地址列表(系统注册)
    public List<String> getRegistryList() {
        if (addressList!=null && addressList.trim().length()>0) {
            registryList = new ArrayList<String>(Arrays.asList(addressList.split(",")));
        }
        return registryList;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getAppname() {
        return appname;
    }

    public void setAppname(String appname) {
        this.appname = appname;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public int getAddressType() {
        return addressType;
    }

    public void setAddressType(int addressType) {
        this.addressType = addressType;
    }

    public String getAddressList() {
        return addressList;
    }

    public Date getUpdateTime() {
        return updateTime;
    }

    public void setUpdateTime(Date updateTime) {
        this.updateTime = updateTime;
    }

    public void setAddressList(String addressList) {
        this.addressList = addressList;
    }

}
相关推荐
不惑_3 小时前
Redis与MySQL双写一致性的缓存模式
redis·mysql·缓存
是丝豆呀4 小时前
清理pip和conda缓存
缓存·conda·pip
想做白天梦8 小时前
多级反馈队列
java·windows·算法
北笙··13 小时前
Redis慢查询分析优化
数据库·redis·缓存
p-knowledge13 小时前
redis的三种客户端
数据库·redis·缓存
积水成江13 小时前
Redis相关面试题
数据库·redis·缓存
瓜牛_gn15 小时前
redis详细教程(4.GEO,bitfield,Stream)
数据库·redis·缓存
瓜牛_gn18 小时前
redis详细教程(5.AOP和RDB持久化)
数据库·redis·缓存
一心赚狗粮的宇叔18 小时前
java web调试时清理当前网址的缓存
java·前端·笔记·后端·缓存
会写代码的孙悟空19 小时前
windows下解决端口被占用,但是找不到占用端口的应用程序;以一种访问权限不允许的方式做了一个访问套接字的尝试;搜索可用端口
运维·网络·windows