java本地缓存(map,Guava,echcache,caffeine)优缺点,以及适用场景

前言

在高并发系统环境下,jvm本地缓存扮演着至关重要的角色,合理的应用能够使系统响应迅速,提高用户体验感,而分布式缓存redis则存在着网络io,以及流量消耗问题,需要和本地缓存搭配使用,才能使系统请求更快,下面我们分别介绍一下四种本地缓存

ConcurrentHashMap (Java 标准库)

介绍
ConcurrentHashMap 是 Java 标准库中的线程安全的哈希表实现,它支持并发访问和修改。通过锁分段机制(segment locking)实现高并发访问,允许多个线程并发地读取和写入。

优点
线程安全:内部实现了细粒度的锁,允许高并发访问。
简单易用:Java 标准库类,无需额外依赖。
性能优越:适用于高并发场景,读写性能较好。
缺点
缺少高级功能:没有内置的过期策略、最大容量控制、缓存统计等高级功能。
没有持久化:数据仅存在于内存中,程序结束后数据丢失。
适用场景
简单的缓存需求,例如会话缓存、短期数据缓存等。
高并发环境下的基本缓存使用

Guava Cache

介绍
Guava 是 Google 提供的一个开源 Java 库,其中的 Cache 类提供了一个轻量级的本地缓存实现,支持各种缓存策略。

优点
简单易用:API 设计简洁明了,易于使用。
灵活配置:支持多种缓存策略,如基于时间、基于大小的过期和自动刷新。
高效:适用于中等规模的缓存需求,性能良好。
缺点
功能有限:不支持持久化和分布式缓存,仅限于本地内存缓存。
依赖库:需要引入 Guava 库。
适用场景
中等规模的应用程序,适合需要灵活过期策略的缓存需求。
缓存配置较简单,不需要持久化存储

Ehcache

介绍
Ehcache 是一个广泛使用的开源 Java 缓存库,功能丰富,支持多种缓存策略,并且可以持久化到磁盘,还提供高可用性和分布式缓存支持。

优点
功能丰富:支持多种缓存策略、持久化到磁盘、分布式缓存等高级功能。
高度可配置:提供丰富的配置选项,能精细调整缓存行为。
持久化支持:数据可以持久化到磁盘,适合长期数据缓存需求。
与 Spring 和 Hibernate 集成良好:提供与这些框架的无缝集成。
缺点
配置复杂:配置选项繁多,初学者需要一定的学习成本。
性能开销:功能丰富带来的性能开销,不适合极高性能要求的场景。
适用场景
企业级应用,需要高级功能如持久化、分布式缓存、复杂缓存策略的场景。
与 Spring 和 Hibernate 集成的项目,缓存数据库查询结果、会话数据等

Caffeine

介绍
Caffeine 是一个高性能的 Java 缓存库,由 Google 的 Guava Cache 发展而来,提供更高效的缓存实现和更多的配置选项。

优点
高性能:Caffeine 在并发性能和缓存效率上表现卓越。
灵活配置:支持多种缓存策略,如基于时间的过期、基于引用的过期、大小限制等。
主动驱逐:支持基于权重的主动驱逐策略,适合高频访问的缓存场景。
良好的统计信息:提供丰富的缓存统计信息,便于监控和调优。
缺点
无持久化:不支持持久化存储,数据仅存在于内存中。
依赖库:需要引入 Caffeine 库。
适用场景
高并发、高性能要求的应用,如 Web 应用中的热点数据缓存。
需要灵活配置缓存策略但不需要持久化存储的场景

总结对比

缓存库优点缺点适用场景
ConcurrentHashMap线程安全、简单易用、性能优越、Java 标准库缺少高级功能、没有持久化简单的高并发缓存需求,如会话缓存、短期数据缓存
Guava简单易用、灵活配置、高效、Google 维护功能有限、不支持持久化和分布式缓存中等规模的应用,需要灵活过期策略的缓存需求
Ehcache功能丰富、持久化支持、高度可配置、与 Spring 和 Hibernate 集成良好配置复杂、性能开销相对较大需要高级功能的企业级应用,如持久化、分布式缓存
Caffine高性能、灵活配置、主动驱逐、良好的统计信息无持久化、依赖库高并发、高性能要求的应用,如 Web 热点数据缓存

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/29216.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习算法 —— K近邻(KNN分类)

🌟欢迎来到 我的博客 —— 探索技术的无限可能! 🌟博客的简介(文章目录) 目录 KNN的介绍和应用KNN的介绍1) KNN建立过程2) 类别的判定KNN的优点KNN的缺点KNN的应用实战KNN分类数据集 —— KNN分类库函数导入数据导入模型训练&可视化原理简析莺尾花数据集 —— KNN分…

微信小程序-API 本地存储

一.本地存储-同步API 存储 : wx.setStorageSync 获取:wx.getStorageSync 删除:wx.removeStorageSync 清空:wx.clearStorageSync 代码: save(){//存储wx.setStorageSync(id, 1) wx.setStorageSync(obj, {name:"te…

React+TS前台项目实战(十一)-- 全局常用组件提示语可复制Link组件封装

文章目录 前言HighLightLink组件1. 功能分析2. 代码详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇讲的这个组件,是一个用于高亮显示文本并添加可选的跳转链接,提示文本,复制文本的 React 组件 HighLightLink组件 1. 功能分析 &#x…

【交易策略】#22-24 残差资金流强度因子

【交易策略】#22-24 残差资金流强度因子

路由控制和策略路由

文章目录 一、路由控制(1)、前言1.1.1-路由策略 (2)、正反掩码和通配符1.2.1-通配符 (3)、ACL1.3.1-ACL步长1.3.2-步长的作用1.3.3-TCP/UDP端口号 实验1:实验2: 二、前缀列表实验1:2.1.1-前缀列表的表达式2…

【图像分割】DSNet: A Novel Way to Use Atrous Convolutions in Semantic Segmentation

DSNet: A Novel Way to Use Atrous Convolutions in Semantic Segmentation 论文链接:http://arxiv.org/abs/2406.03702 代码链接:https://github.com/takaniwa/DSNet 一、摘要 重新审视了现代卷积神经网络(CNNs)中的atrous卷积…

找工作小项目:day16-重构核心库、使用智能指针(1)

day16-重构核心库、使用智能指针 今天是该项目开源在gthub的最后一天,我这里只是将我自己对于这个项目的理解进行总结,如有错误敬请包含指正,今天会整体理一遍代码,并使用智能指针管理整个项目。 1、common 头文件 定义宏用于…

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda

/usr/bin/ld: 当搜索用于 /lib/i386-linux-gnu/libcuda.so 时跳过不兼容的 -lcuda ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/023dbdeb215b4b4580f7f54706e32af9.pn当使用unsloth做微调时,发现找不到libcuda,很自然想到需要软链接到最新…

线性代数|机器学习-P15矩阵A的低秩变换下的逆矩阵

文章目录 1. 单位矩阵的秩1变换1.1 功能说明1.2 证明 2. 单位矩阵 I n I_n In​的秩k变换3. 一般矩阵A的秩k变换 1. 单位矩阵的秩1变换 1.1 功能说明 假设我们有一个单位矩阵I,列向量u,v那么当我们对单位向量I减去秩为1的矩阵后,其逆等于多少&#xff…

IDEA2023中使用run Dashboard面板?实现批量运行微服务

1、直接点击Add service--->Run Configuration Type---->Spring Boot 2、这样就出现了run Dashboard面板,可同时运行多个工程模块,shift选中所有启动类组命名(Group Configurations) 3、启动所有的项目

自行车在线租赁管理系统

摘 要 新时代是一个快速发展的时代,信息革命正在各个行业蔓延。互联网拉近了 人们的距离,物质生活水平的提高平静地改变了人类消费的观念。人们对自行车 租赁行业的要求越来越高,这对传统的自行车租赁行业来说既是挑战也是机遇。 有必要提高…

selenium 3中等待方式

登录百度 (一) time.sleep(3) 强制等待 ,一般调试的时候用 from selenium import webdriver import time from selenium.webdriver.common.by import Bydriver webdriver.Chrome() #打开浏览器驱动 driver.maximize…

安卓多媒体(音频录播、传统摄制、增强摄制)

本章介绍App开发常用的一些多媒体处理技术,主要包括:如何录制和播放音频,如何使用传统相机拍照和录像,如何截取视频画面,如何使用增强相机拍照和录像。 音频录播 本节介绍Android对音频的录播操作,内容包…

【AI应用探讨】— 字节豆包模型应用场景

目录 内部业务场景 教育行业 医疗领域 金融领域 制造业 用户服务 价格优势 内部业务场景 豆包大模型已在字节跳动内部的50多个业务和场景中得到应用,包括办公智能助手、电商导购、营销创作、编程助手等。它的日均处理能力达到1200亿tokens文本,生…

【Linux】线程(二:线程控制)

本篇文章主要围绕线程控制来进行展开。 主题思路是以create与join两个接口展开。 目录 pthread_create 与 pthread_join:pthread_create:pthread_join: 代码:问题一:主线程与新线程谁先退出?问题二:哪个线程应该最后退出&#xf…

OpenCV读取和显示和保存图像

# 导入 OpenCV import cv2 as cv # 读取图像 image cv.imread(F:\\mytupian\\xihuduanqiao.jpg) # 创建窗口 #显示图像后,允许用户随意调整窗口大小 cv.namedWindow(image, cv.WINDOW_NORMAL) # 显示图像 cv.imshow(image, image)# 将图像保存到文件 success cv…

Centos部署openGauss6.0创新版本,丝滑的体验

作者:IT邦德 中国DBA联盟(ACDU)成员,10余年DBA工作经验, Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主,全网粉丝10万 擅长主流Oracle、MySQL、PG、高斯及Greenplum备份恢复, 安装迁移,性能优化、故障…

同三维T80004EHL-W-4K30 4K HDMI编码器,支持WEBRTC协议

输入:1路HDMI1路3.5音频,1路HDMI环出1路3.5音频解嵌输出 4K30超高清,支持U盘/移动硬盘/TF卡录制,支持WEBRTC协议,超低延时,支持3个点外网访问 1个主流1个副流输出,可定制选配POE供电模块,WEBR…

理解CA-IS3050G高速CAN收发器的CANH和CANL的电压

CA-IS3050G高速CAN收发器符合ISO 11898-2物理层标准。 1、CANH和CANL的电压之和为5V&#xff0c;下图是CA-IS3050G的高速CAN收发器参数&#xff0c;分析如下&#xff1a; 1&#xff09;、总线输出显性电压 2.75V < VCANH <4.5V&#xff0c;负载为60Ω&#xff0c;CANH…

Proxy和definedProperty

1. Proxy 代理 定义: 用于定义基本操作的自定义行为 Proxy修改的是程序默认形为&#xff0c;就形同于在编程语言层面上做修改&#xff0c;属于元编程 元编程 是指某类计算机程序的编写&#xff0c;这类计算机程序编写或者操纵其它程序&#xff08;或者自身&#xff09;作为它…