Java手撸一个缓存类似Redis

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: `LocalExpiringCache`是Java实现的一个本地缓存类,使用ConcurrentHashMap存储键值对,并通过ScheduledExecutorService定时清理过期的缓存项。类中包含`put`、`get`、`remove`等方法操作缓存,并有`clearCache`方法来清除过期的缓存条目。初始化时,会注册一个定时任务,每500毫秒检查并清理一次过期缓存。单例模式确保了类的唯一实例。
package com.boot.cache.impl;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

/**
 * @author liu pei
 * @date 2024年01月22日 下午5:01
 * @Description:
 */
public class LocalExpiringCache {
   

    public static void main(String[] args) {
   
        LocalExpiringCache.getInstance().put("","",100);
    }

    protected static final Logger log = LoggerFactory.getLogger(LocalExpiringCache.class);

    /* 定时清理缓存 */
    private static final ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();

    private static Map<String, CacheItem> cache = null;

    private class CacheItem {
   
        private Object value;
        private Long expirationTime;
        public CacheItem(Object value, long expirationTime) {
   
            this.value = value;
            this.expirationTime = expirationTime;
        }

        public Object getValue() {
   
            return value;
        }

        public void setValue(Object value) {
   
            this.value = value;
        }

        public Long getExpirationTime() {
   
            return expirationTime;
        }

        public void setExpirationTime(Long expirationTime) {
   
            this.expirationTime = expirationTime;
        }
    }

    private static class ExpiringCacheHolder {
   
        private static final LocalExpiringCache INSTANCE = new LocalExpiringCache();
    }

    public static final LocalExpiringCache getInstance() {
   
        return LocalExpiringCache.ExpiringCacheHolder.INSTANCE;
    }

    private LocalExpiringCache() {
   
        log.info("正在初始化缓存池.........");

        cache = new ConcurrentHashMap<>();

        // 注册一个定时线程任务,服务启动1秒之后,每隔500毫秒执行一次
        // 定时清理过期缓存 1000 首次执行时间 500 (毫秒)执行周期,5分钟清理一次
        executor.scheduleAtFixedRate(LocalExpiringCache::clearCache, 1000, 1000*50, TimeUnit.MILLISECONDS);
    }


    public void put(String key, Object value, long expirationSecond) {
   
        long expirationTime = System.currentTimeMillis() + expirationSecond * 1000;
        CacheItem item = new CacheItem(value, expirationTime);
        cache.put(key, item);
    }

    public Object get(String key) {
   
        CacheItem item = cache.get(key);
        if (item != null && System.currentTimeMillis() < item.getExpirationTime()) {
   
            return item.getValue();
        }
        return null; // 缓存项已过期或不存在
    }
    public void remove(String key) {
   
        cache.remove(key);
    }
    public void clear() {
   
        cache.clear();
    }
    public boolean containsKey(String key) {
   
        return cache.containsKey(key);
    }
    public boolean isEmpty() {
   
        return cache.isEmpty();
    }
    public int size() {
   
        return cache.size();
    }


    /**
     * 清理过期的缓存数据
     */
    private static void clearCache() {
   
        if (cache.size() <= 0) {
   
            return;
        }
        // 判断是否过期 过期就从缓存Map删除这个元素
        cache.entrySet().removeIf(entry -> entry.getValue().getExpirationTime() != null && entry.getValue().getExpirationTime() < System.currentTimeMillis());
    }
}
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5天前
|
JSON NoSQL Java
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
14 0
|
3天前
|
存储 缓存 NoSQL
Redis多级缓存指南:从前端到后端全方位优化!
本文探讨了现代互联网应用中,多级缓存的重要性,特别是Redis在缓存中间件的角色。多级缓存能提升数据访问速度、系统稳定性和可扩展性,减少数据库压力,并允许灵活的缓存策略。浏览器本地内存缓存和磁盘缓存分别优化了短期数据和静态资源的存储,而服务端本地内存缓存和网络内存缓存(如Redis)则提供了高速访问和分布式系统的解决方案。服务器本地磁盘缓存因I/O性能瓶颈和复杂管理而不推荐用于缓存,强调了内存和网络缓存的优越性。
21 1
|
4天前
|
缓存 NoSQL Redis
深度解析Redis的缓存双写一致性
【4月更文挑战第20天】
28 1
|
5天前
|
缓存 NoSQL 算法
Redis入门到通过之解决Redis缓存击穿、缓存穿透、缓存雪崩
Redis入门到通过之解决Redis缓存击穿、缓存穿透、缓存雪崩
11 0
|
5天前
|
存储 缓存 NoSQL
Redis入门到通关之解决Redis缓存一致性问题
Redis入门到通关之解决Redis缓存一致性问题
19 0
|
5天前
|
存储 缓存 NoSQL
Redis入门到通关之Redis缓存数据实战
Redis入门到通关之Redis缓存数据实战
12 0
|
6天前
|
缓存 NoSQL Redis
软件体系结构 - 缓存技术(7)Redis持久化方法
【4月更文挑战第20天】软件体系结构 - 缓存技术(7)Redis持久化方法
79 14
|
6天前
|
存储 缓存 运维
软件体系结构 - 缓存技术(5)Redis Cluster
【4月更文挑战第20天】软件体系结构 - 缓存技术(5)Redis Cluster
137 10
|
6天前
|
存储 缓存 NoSQL
软件体系结构 - 缓存技术(4)Redis分布式存储
【4月更文挑战第20天】软件体系结构 - 缓存技术(4)Redis分布式存储
37 12
|
1月前
|
缓存 NoSQL 安全
【Redis】缓存穿透
【Redis】缓存穿透
30 0