面试疑难点解析——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)

相关文章
|
8月前
|
机器学习/深度学习 JSON Java
Java调用Python的5种实用方案:从简单到进阶的全场景解析
在机器学习与大数据融合背景下,Java与Python协同开发成为企业常见需求。本文通过真实案例解析5种主流调用方案,涵盖脚本调用到微服务架构,助力开发者根据业务场景选择最优方案,提升开发效率与系统性能。
1961 0
|
8月前
|
Java
Java的CAS机制深度解析
CAS(Compare-And-Swap)是并发编程中的原子操作,用于实现多线程环境下的无锁数据同步。它通过比较内存值与预期值,决定是否更新值,从而避免锁的使用。CAS广泛应用于Java的原子类和并发包中,如AtomicInteger和ConcurrentHashMap,提升了并发性能。尽管CAS具有高性能、无死锁等优点,但也存在ABA问题、循环开销大及仅支持单变量原子操作等缺点。合理使用CAS,结合实际场景选择同步机制,能有效提升程序性能。
|
8月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
587 100
|
8月前
|
存储 JSON 数据建模
鸿蒙 HarmonyOS NEXT端云一体化开发-云数据库篇
云数据库采用存储区、对象类型、对象三级结构,支持灵活的数据建模与权限管理,可通过AGC平台或本地项目初始化,实现数据的增删改查及端侧高效调用。
423 1
|
7月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
8月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
8月前
|
安全 Java API
Java SE 与 Java EE 区别解析及应用场景对比
在Java编程世界中,Java SE(Java Standard Edition)和Java EE(Java Enterprise Edition)是两个重要的平台版本,它们各自有着独特的定位和应用场景。理解它们之间的差异,对于开发者选择合适的技术栈进行项目开发至关重要。
1431 1
|
7月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
Java 开发工具 git
Java开发初级6.24.3
5.在Git使用过程中,进行Git配置的操作命令是哪个() A. config B. config -g C. config -a D. git config 相关知识点: 在git中,经常使用git config 命令用来配置git的配置文件,git配置级别主要有:仓库级别 local 【优先级最高】、用户级别 global【优先级次之】、系统级别 system【优先级最低】 正确答案:D 10.RDBMS是什么? A. Rela Database Management Systems B. Relational Database Management Systems C. Relation
280 0
|
SQL 前端开发 JavaScript
Java开发初级6.24.2
3.Java网站src/main/java目录保存的是什么资源? A. Java源代码文件 B. 测试代码 C. JavaScript、CSS等文件 D. 图片资源 正确答案:A 4.什么是索引Index? A. SQL数据库里的表管理工具 B. SQL数据库里的查询工具 C. SQL数据库里的目录工具 D. SQL数据库用来加速数据查询的特殊的数据结构 正确答案:D
347 0

推荐镜像

更多
  • DNS