首页 > 技术文章 > Java缓存

lynn16 2019-04-13 18:06 原文

  • 外存
    • 也就是我们经常说的外存储器,指除计算机内存及CPU缓存意外的存储器,此类存储器一般断电后仍能保存数据。
  • 内存
    • 内存是计算机中重要的部件之一,它是与CPU进行沟通的桥梁。
    • 计算机中所有程序的运行都是在内存中进行的,因此内存的性能对计算机的影响很大。
    • 内存也被称为内存储器,其作用是用于暂时存放CPU中的运算数据,以及与硬盘等外部存储器交换的数据。
    • 只要计算机在运行中,CPU就会把需要的数据调到内存中进行运算,当运算完成后CPU再将结果传送出来,内存的运行也决定了计算机的稳定运行,此类存储器一般断电后数据就会被清空。
  • 高速缓存其实缓存就是把一些外存上的数据保存到内存上而已,怎么保存到内存上呢?我们运行的所有程序,里面的变量值都放在内存上,所以说如果想要使一个值放在内存上,实质就是在获取到这个变量后,用一个生存期较长的变量存放你要存放的数据,在Java中一些缓存一般都是通过map集合来做的。
    • 高速缓存是用来协调CPU与主存之间速度差异而设置的。
    • 一般情况下,CPU的工作速度高,但内存的工作速度相对较低,为了解决这个问题,常用使用高速缓存,高速缓存的存取速度介于CPU和主存之间。
    • 系统将一些CPU在几个时间段经常访问的内容存入高速缓存,当CPU需要使用数据时,先在高速缓存中找,如果找到,就不必须访问内存了,找不到时,再找内存。
  • 缓存怎么实现?
    • 简单来讲就是,如果某些资源或者数据会被频繁的使用,而这些资源或数据存储在系统外部,比如数据库、硬盘文件等,那么每次操作这些数据的时候都从数据库或者硬盘上去获取,速度很很慢,会造成性能问题。
    • 一个简答的解决办法就是:把这些数据存到内存里面,每次操作的时候,先到内存里面找,看有没有这些数据,如果有,那么直接使用,如果没有那么就获取它,并设置到缓存中,下一次访问的时候就可以直接从内存中获取了,从而节约大量时间,当然缓存也是一种典型的空间换时间。
    • 在java中最常见的一种实现缓存的方式就是使用Map,基本步骤是:
      • 先到缓存里面查找,看看是否存在需要使用的数据
      • 如果没有找到,那么就创建一个满足需求的数据,然后把这个数据设置回到缓存中,以备下次使用
      • 如果找到了响应的数据,或者是创建了相应的数据,那么就直接使用这个数据。
  • 实现原理
    • 当客户端请求数据时,如果服务端配置了缓存,第一步去缓存里面查找,如果有跳4,没有则往2.
    • 发送jdbc请求数据库查询数据。
    • 将查询到的数据返回给缓存,并存放在缓存中。
    • 将从(缓存|数据库)查询到的数据返回给客户端。

推荐阅读