当前位置: 首页 > news >正文

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 热点数据缓存

相关文章:

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

前言 在高并发系统环境下,jvm本地缓存扮演着至关重要的角色,合理的应用能够使系统响应迅速,提高用户体验感,而分布式缓存redis则存在着网络io,以及流量消耗问题,需要和本地缓存搭配使用,才能使…...

Monica

在 《long long ago》中,我论述了on是一个刚出生的孩子的脐带连接在其肚子g上的形象,脐带就是long的字母l和字母n,l表脐带很长,n表脐带曲转冗余和连接之性,on表一,是孩子刚诞生的意思,o是身体&a…...

国产数据库中读写分离实现机制

在数据库高可用架构下会存在1主多备的部署,备节点可以根据业务场景分发一部分流量以充分利用资源,并减轻主库的压力,因此在数据库的功能上需要读写分离来实现。 充分利用备节点的资源,提升业务的吞吐量;防止运维等非业…...

kubernetes部署dashboard

kubernetes部署dashboard 1. 简介 Dashboard 是基于网页的 Kubernetes 用户界面。 你可以使用 Dashboard 将容器应用部署到 Kubernetes 集群中,也可以对容器应用排错,还能管理集群资源。 你可以使用 Dashboard 获取运行在集群中的应用的概览信息&#…...

FPGA早鸟课程第二弹 | Vivado 设计静态时序分析和实际约束

在FPGA设计领域,时序约束和静态时序分析是提升系统性能和稳定性的关键。社区推出的「Vivado 设计静态时序分析和实际约束」课程,旨在帮助工程师们掌握先进的设计技术,优化设计流程,提高开发效率。 课程介绍 关于课程 权威认证&…...

STM32项目分享:家庭环境监测系统

目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 1.PCB图 2.PCB板打样焊接图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片: 哔哩哔哩视频链接: https://www.bilibili.…...

华为HCIP Datacom H12-821 卷5

1.单选题 下列哪种工具不能被 route-policy 的 apply 子句直接引用? A、IP-Prefix B、tag C、community D、origin 正确答案: A 解析: 因route-policy工具中, apply 后面跟的是路由的相关属性。 但是ip-prefix是用来匹配路由的工具。 2.单选题...

Mongodb数据库基本操作

本文为在命令行模式下Mongodb数据库的基本操作整理。 目录 数据库操作 创建数据库 查看所有数据 查看当前数据库 删除数据库 断开连接 查看命令api 集合操作 查看当前数据库下集合 创建集合 删除当前数据库中的集合 文档操作 插入文档 insertOne()方法 insertMa…...

【机器学习】基于Softmax松弛技术的离散数据采样

1.引言 1.1.离散数据采样的意义 离散数据采样在深度学习中起着至关重要的作用,它直接影响到模型的性能、泛化能力、训练效率、鲁棒性和解释性。 首先,采样方法能够有效地平衡数据集中不同类别的样本数量,使得模型在训练时能够更均衡地学习…...

.NET+Python量化【1】——环境部署和个人资金账户信息查询

前言:量化资料很少,.NET更少。那我就来开个先河吧~ 以下是使用QMT进行量化开发的环境部署和基础信息获取有关操作。 1、首先自己申请券商的QMT权限,此步骤省略。 2、登陆QMT,选择极简模式,或者独立交易模式之类的。会进…...

洛谷 P10584 [蓝桥杯 2024 国 A] 数学题(整除分块+杜教筛)

题目 思路来源 登录 - Luogu Spilopelia 题解 参考了两篇洛谷题解&#xff0c;第一篇能得出这个式子&#xff0c;第二篇有比较严格的复杂度分析 结合去年蓝桥杯洛谷P9238&#xff0c;基本就能得出这题的正确做法 代码 #include<bits/stdc.h> #include<iostream&g…...

深入讲解C++基础知识(一)

目录 一、基本内置类型1. 类型的作用2. 分类3. 整型3.1 内存描述及查询3.2 布尔类型 —— bool3.3 字符类型 —— char3.4 其他整型 4. 有符号类型和无符号类型5. 浮点型6. 如何选择类型7. 类型转换7.1 自动类型转换7.2 强制类型转换7.3 类型转换总结 8. 类型溢出8.1 注意事项 …...

Python爬虫实战:批量下载网站图片

1.获取图片的url链接 首先&#xff0c;打开百度图片首页&#xff0c;注意下图url中的index 接着&#xff0c;把页面切换成传统翻页版&#xff08;flip&#xff09;&#xff0c;因为这样有利于我们爬取图片&#xff01; 对比了几个url发现&#xff0c;pn参数是请求到的数量。…...

使用 JavaScript 获取电池状态

在现代的移动设备和笔记本电脑上&#xff0c;了解电池状态是一项非常有用的功能。使用 JavaScript 可以轻松地获取电池的充电状态、电量百分比等信息。本文将介绍如何使用 JavaScript 访问这些信息&#xff0c;并将其显示在网页上。 1. HTML 结构 首先&#xff0c;我们需要一…...

java—类反射机制

简述 反射机制允许程序在执行期间借助于Reflection API取得任何类的内部信息&#xff08;如成员变量&#xff0c;构造器&#xff0c;成员方法等&#xff09;&#xff0c;并能操作对象的属性及方法。反射机制在设计模式和框架底层都能用到。 类一旦加载&#xff0c;在堆中会产生…...

浏览器-服务器架构 (BS架构) 详解

目录 前言1. BS架构概述1.1 BS架构的定义1.2 BS架构的基本原理 2. BS架构的优势2.1 客户端简化2.2 易于更新和维护2.3 跨平台性强2.4 扩展性高 3. BS架构的劣势3.1 网络依赖性强3.2 安全性问题3.3 用户体验局限 4. BS架构的典型应用场景4.1 企业内部应用4.2 电子商务平台4.3 在…...

微型操作系统内核源码详解系列五(四):cm3下svc启动任务

系列一&#xff1a;微型操作系统内核源码详解系列一&#xff1a;rtos内核源码概论篇&#xff08;以freertos为例&#xff09;-CSDN博客 系列二&#xff1a;微型操作系统内核源码详解系列二&#xff1a;数据结构和对象篇&#xff08;以freertos为例&#xff09;-CSDN博客 系列…...

筛质数(暴力法、埃氏筛、欧拉筛)

筛质数&#xff08;暴力法、埃氏筛、欧拉筛&#xff09; 暴力法 思路分析&#xff1a; 直接双for循环来求解质数 如果不设置标记只是简单地执行了break会导致内部循环(由j控制)而不是立即打印i或者跳过它。如果打印语句写到内部循环中&#xff0c;也会导致每个 非素数也被打…...

使用USI作为主SPI接口

代码; lcd_drive.c //***************************************************************************** // // File........: LCD_driver.c // // Author(s)...: ATMEL Norway // // Target(s)...: ATmega169 // // Compiler....: AVR-GCC 3.3.1; avr-libc 1.0 // // D…...

AI播客下载:Eye on AI(AI深度洞察)

"Eye on A.I." 是一档双周播客节目&#xff0c;由长期担任《纽约时报》记者的 Craig S. Smith 主持。在每一集中&#xff0c;Craig 都会与在人工智能领域产生影响的人们交谈。该播客的目的是将渐进的进步置于更广阔的背景中&#xff0c;并考虑发展中的技术的全球影响…...

Flink 窗口触发器

参考&#xff1a; NoteWarehouse/05_BigData/09_Flink(1).md at main FGL12321/NoteWarehouse GitHub Flink系列 9. 介绍 Flink 窗口触发器、移除器和延迟数据等 | hnbian https://github.com/kinoxyz1/bigdata-learning-notes/blob/master/note/flink/Window%26%E6%97%B6…...

Java面试题:解释线程间如何通过wait、notify和notifyAll方法进行通信

在 Java 中&#xff0c;线程间的通信可以通过 wait()、notify() 和 notifyAll() 这三个方法实现。这些方法是 Java 线程 Thread 类的一部分&#xff0c;它们与 synchronized 关键字一起使用&#xff0c;以实现线程间的协调。 基本概念 wait()&#xff1a;当一个线程执行到 wa…...

【机器学习 复习】第9章 降维算法——PCA降维

一、概念 1.PCA &#xff08;1&#xff09;主成分分析&#xff08;Principal ComponentAnalysis&#xff0c;PCA&#xff09;一种经典的线性降维分析算法。 &#xff08;2&#xff09;原理&#xff0c;这里以二维转一维为例&#xff0c;原来的平面变成了一条直线 这是三维变二…...

Ubuntu系统docker gpu环境搭建

Ubuntu系统dockergpu环境搭建 安装步骤前置安装安装指定版本的依赖包用docker官方脚本安装Docker-ce添加稳定仓库和GPG秘钥更新源 安装docker安装nvidia-docker2重启docker服务阿里云镜像加速 相关命令网络 docker常用命令镜像容器 docker相关问题解决方案使用wsl时docker的容器…...

网络安全-如何设计一个安全的API(安全角度)

目录 API安全概述设计一个安全的API一个基本的API主要代码调用API的一些问题 BasicAuth认证流程主要代码问题 API Key流程主要代码问题 Bearer auth/Token auth流程 Digest Auth流程主要代码问题 JWT Token流程代码问题 Hmac流程主要代码问题 OAuth比较自定义请求签名身份认证&…...

微积分-导数1(导数与变化率)

切线 要求与曲线 C C C相切于 P ( a , f ( a ) ) P(a, f(a)) P(a,f(a))点的切线&#xff0c;我们可以在曲线上找到与之相近的一点 Q ( x , f ( x ) ) Q(x, f(x)) Q(x,f(x))&#xff0c;然后求出割线 P Q PQ PQ的斜率&#xff1a; m P Q f ( x ) − f ( a ) x − a m_{PQ} \…...

最新PHP仿猪八戒任务威客网整站源码/在线接任务网站源码

资源介绍 老规矩&#xff0c;截图为亲测&#xff0c;前后台显示正常&#xff0c;细节功能未测&#xff0c;有兴趣的自己下载。 PHP仿猪八戒整站源码下载&#xff0c;phpmysql环境。威客开源建站系统&#xff0c;其主要交易对象是以用户为主的技能、经验、时间和智慧型商品。经…...

Windows安装配置jdk和maven

他妈的远程连接不上公司电脑&#xff0c;只能在家重新配置一遍&#xff0c;在此记录一下后端环境全部配置 Windows安装配置JDK 1.8一、下载 JDK 1.8二、配置环境变量三、验证安装 Windows安装配置Maven 3.8.8一、下载安装 Maven并配置环境变量二、设置仓库镜像及本地仓库三、测…...

电子SOP实施(MQTT协议)

架构图 服务与程序 用docker启动mqtt broker(服务器) 访问&#xff1a;http://192.168.88.173:18083/#/dashboard/overview 用户名&#xff1a;admin 密码&#xff1a;*** 消息发布者(查找sop的url地址&#xff0c;发布出去) 修改url&#xff0c;重新发布消息 import ran…...

【Unity导航系统】Navigation组件的概念及其使用示例

Unity中的NavMeshObstacle组件是一个用于动态障碍物的组件&#xff0c;它可以实时地影响导航网格&#xff08;NavMesh&#xff09;。当游戏对象附加了NavMeshObstacle组件时&#xff0c;它可以在AI进行路径规划时被识别为障碍物&#xff0c;从而让AI避开这些动态变化的障碍。 …...

金融街做网站的公司/重要新闻今天8条新闻

首先下载React 的安装包&#xff0c;可以到官网下载。也可以使用React Demos 已经自带 React 源码&#xff0c;不用另外安装&#xff0c;只需把这个库拷贝到硬盘中使用。 &#xff08;可参考http://www.ruanyifeng.com/blog/2015/03/react.html 此网址的具体操作&#xff09; 1…...

个人网站做支付接口/百度小说搜索风云排行榜

文章目录摘 要&#xff1a;关键词&#xff1a;ZigBee 、语音识别、智能家居、传感器0.引言1.概述2&#xff0e;系统总体设计2.1系统组成2、系统使用流程3、开发环境2.2系统传感器构成2.3系统数据库设计3&#xff0e;系统详细设计与实现4&#xff0e;系统测试结果5&#xff0e;总…...

国外做ic的网站/太原seo网站排名

为什么80%的码农都做不了架构师&#xff1f;>>> 一、什么是VLAN VLAN(Virtual LAN)&#xff0c;翻译成中文是“虚拟局域网”。LAN可以是由少数几台家用计算机构成的网络&#xff0c;也可以是数以百计的计算机构成的企业网络。VLAN所指的LAN特指使用路由器分割的网络…...

新加坡室内设计公司排名/优化网站推广网站

Hadoop2.7.3 之 CLI 操作一、常用命令二、管理员命令说明&#xff1a; 熟悉使用hadoop的命令行来操作hdfs 一、常用命令 二、管理员命令 查看当前分布式文件系统的状态 hdfs dfsadmin -report查看当前分布式文件系统的安全模式状态 hdfs dfsadmin -safemode get将当前分布式文…...

怎么创建网站 免费滴/sem代运营托管公司

快速排序 对于n个数的输入数组来说&#xff0c;快速排序是一种最坏情况时间复杂度为O(n2)的排序算法&#xff0c;虽然最坏情况时间复杂度很差&#xff0c;但是快速排序通常是实际排序中最好的选择&#xff0c;因为它的平均性能非常好&#xff1a;它的期望时间复杂度是O(nlgn)&a…...

wordpress 慢/人力资源短期培训班

他&#xff0c;三岁因小儿麻痹症而落下终身残疾&#xff0c;没有进过正规大学的校门&#xff0c;二十多岁在一个街道小厂当技术员&#xff0c;三十八岁之前还不知道电脑为世间何物。就是这个无论从哪个角度说&#xff0c;都从未受到社会眷顾的"弃儿"&#xff0c;却成…...