面试疑难点解析——Java数据库开发(四)

简介: 无法缩短内存与磁盘间的读取的延迟,这个时候该怎么办?缓存与数据如何保持同步?本文为你详细解答。

7月9日 19:00-21:30 阿里云开发者社区首场“Offer 5000”直播开启!14位团队技术大牛在线招人,更有《阿里云技术面试红宝书》助你拿下Offer!戳下图或链接马上投递简历:
图片无法显
点击图片或戳我查看详情和投简历

缓存问题


对于整个电脑而言,它有一个自己的固定状态:如果要读取数据,流程是将硬盘上的内容直接加载到内存里,而后再通过内存进行读取。因为硬盘上所保存的都是物理上的二进制数据。

如果你的电脑只是你一个人使用,那么没有任何问题,如果多人使用,你就会发现电脑变得像蜗牛跑步一样慢。你一个人在使用,慢一点或许感觉不到,一旦换到公网上,一群用户要进行数据读取,问题就出现了,所有的操作如果通过数据库查询得到(物理磁盘上),那么速度就会非常慢。例如一个查询需要60毫秒的时间,如果人一多就会成指数倍增长,效率会非常低。

如何减少这种操作所带来的延迟时间的增长呢?

有人提出,不使用普通的硬盘(物理磁盘),全部换固态硬盘。然而,使用固态硬盘虽然速度可以提升,但价格也相对高,且不实用。

无法缩短内存与磁盘间的读取的延迟,这个时候该怎么办?

解决方案是不读取硬盘上的内容,速度就会非常快了。这种做法有三种实现模式:

1.利用文件(CMS系统,这个系统的特点是把所有要读的数据都生成静态文件,静态页面的加载速度很快);

2.直接使用内存作为缓存,也就是将所读取进来的数据保存在内存里面(考虑数据的实效问题);

3.使用缓存数据库,缓存数据库有Redis、Memcached。

**对于内存缓存而言,有两种常用的组件:
-oscache(主要在页面上使用)
-ehcache(在一些开发框架中出现**)

缓存的本质是减少物理磁盘的读取时间,直接读内存,因而还需要进行合理的内存管理。

缓存与数据同步


使用缓存的核心意义在于减少数据库的操作,缓存和数据库之间有一定的内容差异。

如果要求尽可能保持缓存和数据库同步,那么需要思考以下几个问题:
1.你的缓存是否为数据库专用的缓存?
在所有的ORMapping设计组件之中都会存在有EHCache缓存组件,这个缓存组件主要目的是帮助用户减少数据库的处理操作,一般这样的缓存都会有自己的回收算法,比如:FIFO、软引用,弱引用。这些算法只是保证缓存中不需要的内容被及时清理干净。如果一直被使用,那么将被一直保留,并且这一操作只能通过明确的代码进行释放。

2.你的缓存是否在进行分布式或反向代理操作时使用的?
例如:你的系统里面配置了N多个Tomcat(web容器),这些web容器需要统一为所有的用户服务,为了操作方便可以将图片或视频等内容暂时保存在自己本地服务器上,一般保存在本地服务器上的数据都可以进行手工清空处理。

3.你的缓存是否采用了缓存数据库完成?
Memcached、Redis,这个里面数据保存的内容往往不会是显示的数据,对于缓存的数据库,里面保存的内容往往都是一些高并发的数据信息统计,对于这些信息统计处理操作,往往会结合大数据的开发工具完成,或者在进行集群设计的时候使用缓存数据库进行更加方便的协调处理操作,保存分布式服务器上的公共数据。例如:session。

更多专业知识,面试技巧就在面试一点通,持续更新中……
感谢浏览~
本内容来源于[阿里云大学-Java面试技巧
](https://developer.aliyun.com/course/1660)

相关文章
|
7月前
|
存储 缓存 NoSQL
Redis常见面试题全解析
Redis面试高频考点全解析:从过期删除、内存淘汰策略,到缓存雪崩、击穿、穿透及BigKey问题,深入原理与实战解决方案,助你轻松应对技术挑战,提升系统性能与稳定性。(238字)
|
10月前
|
存储 关系型数据库 数据库
附部署代码|云数据库RDS 全托管 Supabase服务:小白轻松搞定开发AI应用
本文通过一个 Agentic RAG 应用的完整构建流程,展示了如何借助 RDS Supabase 快速搭建具备知识处理与智能决策能力的 AI 应用,展示从数据准备到应用部署的全流程,相较于传统开发模式效率大幅提升。
附部署代码|云数据库RDS 全托管 Supabase服务:小白轻松搞定开发AI应用
|
9月前
|
存储 安全 测试技术
Python面试题精选及解析
本文详解Python面试中的六大道经典问题,涵盖列表与元组区别、深浅拷贝、`__new__`与`__init__`、GIL影响、协程原理及可变与不可变类型,助你提升逻辑思维与问题解决能力,全面备战Python技术面试。
495 1
|
7月前
|
安全 前端开发 Java
《深入理解Spring》:现代Java开发的核心框架
Spring自2003年诞生以来,已成为Java企业级开发的基石,凭借IoC、AOP、声明式编程等核心特性,极大简化了开发复杂度。本系列将深入解析Spring框架核心原理及Spring Boot、Cloud、Security等生态组件,助力开发者构建高效、可扩展的应用体系。(238字)
|
8月前
|
算法 Java
50道java集合面试题
50道 java 集合面试题
|
7月前
|
监控 Java 关系型数据库
面试性能测试总被刷?学员真实遇到的高频问题全解析!
面试常被性能测试题难住?其实考的不是工具,而是分析思维。从脚本编写到瓶颈定位,企业更看重系统理解与实战能力。本文拆解高频面试题,揭示背后考察逻辑,并通过真实项目训练,帮你构建性能测试完整知识体系,实现从“会操作”到“能解决问题”的跨越。
|
8月前
|
存储 JSON 数据建模
鸿蒙 HarmonyOS NEXT端云一体化开发-云数据库篇
云数据库采用存储区、对象类型、对象三级结构,支持灵活的数据建模与权限管理,可通过AGC平台或本地项目初始化,实现数据的增删改查及端侧高效调用。
375 1
|
8月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。

推荐镜像

更多
  • DNS