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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
全局流量管理 GTM,标准版 1个月
简介: 无法缩短内存与磁盘间的读取的延迟,这个时候该怎么办?缓存与数据如何保持同步?本文为你详细解答。

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)

相关文章
|
1天前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
22 7
|
1天前
|
存储 Java 计算机视觉
Java二维数组的使用技巧与实例解析
本文详细介绍了Java中二维数组的使用方法
24 15
|
1天前
|
算法 搜索推荐 Java
【潜意识Java】深度解析黑马项目《苍穹外卖》与蓝桥杯算法的结合问题
本文探讨了如何将算法学习与实际项目相结合,以提升编程竞赛中的解题能力。通过《苍穹外卖》项目,介绍了订单配送路径规划(基于动态规划解决旅行商问题)和商品推荐系统(基于贪心算法)。这些实例不仅展示了算法在实际业务中的应用,还帮助读者更好地准备蓝桥杯等编程竞赛。结合具体代码实现和解析,文章详细说明了如何运用算法优化项目功能,提高解决问题的能力。
23 6
|
1天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
27 6
|
7天前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
99 11
|
1天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
10 2
|
1天前
|
存储 算法 搜索推荐
【潜意识Java】期末考试可能考的高质量大题及答案解析
Java 期末考试大题整理:设计一个学生信息管理系统,涵盖面向对象编程、集合类、文件操作、异常处理和多线程等知识点。系统功能包括添加、查询、删除、显示所有学生信息、按成绩排序及文件存储。通过本题,考生可以巩固 Java 基础知识并掌握综合应用技能。代码解析详细,适合复习备考。
10 4
|
1天前
|
存储 Java
【潜意识Java】期末考试可能考的选择题(附带答案解析)
本文整理了 Java 期末考试中常见的选择题,涵盖数据类型、控制结构、面向对象编程、集合框架、异常处理、方法、流程控制和字符串等知识点。每道题目附有详细解析,帮助考生巩固基础,加深理解。通过这些练习,考生可以更好地准备考试,掌握 Java 的核心概念和语法。
|
6天前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
30 7
|
11天前
|
SQL Java 数据库连接
Java MyBatis 面试题
Java MyBatis相关基础面试题

推荐镜像

更多