1、应用级缓存

缓存简介:

          让数据  更 接近  使用者;

          目的 让访问速度更快;

          工作机制:从缓存读取数据,如果没有,再从慢速设备读取实际数据  并 同步到缓存;

            eg:CPU读取数据:CPU--->L1/L2/L3--->内存--->磁盘;

              maven: 本地仓--->中央仓--->远程仓;

缓存命中率:

          从缓存读取次数 / 总读取次数(缓存+磁盘);

          非常重要的监控指标,监控此指标看缓存是否工作良好;

缓存回收策略:

          a,基于空间

          b,基于容量

          c,基于时间

              TTL(Time To Live):存活期,从创建开始  到  到期 的时间段;

              TTI(Time To Idle):空闲期,缓存多久没被访问 即失效;

基于Java对象引用:

              a,软引用:

              b,弱引用:

回收算法:

              使用基于空间、容量的缓存  会使用一定的算法移除旧数据:

                  FIFO:先进先出

                  LRU(Least Recently Used):使用距离现在最久的那个被移除; 

                  LFU(Least Frequently Used):使用频率最低的被移除;

Java缓存类型:

        I、概述

            Guava Cache

                只提供堆缓存,小巧灵活,性能最好;

            Ehcahe

                提供了 堆缓存、堆外缓存、磁盘缓存、分布式缓存;

                缺陷:API不完善;

            Map DB

                嵌入式Java数据库引擎 和 集合框架;

                提供了Maps、Sets、Lists、Queues、Bitmaps支持,还支持ACID事务、增量备份,支持堆缓存、堆外缓存、磁盘缓存; 

          a, 堆缓存:

              存储在堆内存种,避免序列化,可以使用Guava Cahce、Ehcache、Map DB实现;

          b, 堆外缓存:

              存储在堆外内存,需要序列化,使用Ehcache、Map DB实现;

          c, 磁盘缓存:

              存储在磁盘上,JVM重启数据还存在,可以使用Ehcache、Map DB实现;

          d, 分布式缓存:

              以上为进程内缓存、磁盘缓存;

              如果存在多JVM会有一些问题:单机容量、数据一致性、缓存命中率低;

              可考虑使用分布式缓存实现:eg:redis实现分布式缓存:

        II、案例

          a,多级缓存

             先查找堆缓存、没有再查找磁盘缓存,Map DB实现:

 

2、HTTP缓存

    2.1、简介:

         浏览器缓存:

    2.2、如何在Java应用层控制浏览器缓存:

           

3、多级缓存

    3.1、

 

4、连接池、线程池

    4.1、池化 :通过  复用技术  提升性能;