缓存机制总结(JVM内置缓存机制,MyBatis和Hibernate缓存机制,Redis缓存)

一.JVM内置缓存(值存放在JVM缓存中)

  我们可以先了解一下Cookie,Session,和Cache

    Cookie:当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cookie 会帮你在网站上所打的文字或是一些选择都纪录下来。当下次你再光临同一个网站,WEB 服务器会先看看有没有它上次留下的 Cookie 资料,有的话,就会依据 Cookie里的内容来判断使用者,送出特定的网页内容给你。具体来说Cookie机制采用的是在客户端保持状态的方案(保存客户浏览器请求服务器页面的请求信息),而Session机制采用的是在服务器端保持状态的方案。

  Cookie存储的数据量受限制,不仅有大小限制,还有个数限制,因此不适合存放大数据。由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端。

    Session:session一般用来保存每一个用户的专有信息,Session缓存信息保存在web服务器当中,并且Session缓存容易丢失,导致数据的不确定性。而且Session不适宜放大量信息,否则会导致服务器性能降低。

    Cache:Cache用于在Http请求期间保存页面或者数据,而且它的使用可以大大的提高整个应用程序的效率。它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后,服务器不是再次处理而是将Cache中保存的数据直接返回给用户,可以看出Cache节省的是时间—服务器处理时间。Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期,应用程序重启将重新创建其实例。

  JVM的内置缓存:

    oscache:oscache 主要是对页面的缓存,可以整页或者指定网页某一部分缓存,同时指定它的过期时间,这样在此时间段里面访问的数据都是一样的

    ehcache:ehcache主要是对数据库访问的缓存,相同的查询语句只需查询一次数据库,从而提高了查询的速度,使用spring的AOP可以很容易实现这一功能

二.MyBatis和Hibernate缓存简单介绍   

  MyBatis一级缓存:MyBatis 默认开启了一级缓存,一级缓存是在SqlSession 层面进行缓存的。SqlSession对象被创建,一级缓存就存在了,如果Session对象关闭或调用清理方法,会导致缓存失效。缓存底层实现就是通过HashMap实现的。

  MyBatis二级缓存:mybatis中的二级缓存是mapper级别的缓存,值得注意的是,不同的mapper通常情况下有不同的namespace,就都有一个二级缓存,也就是说,不同的mapper之间的二级缓存是互不影响的。(MyBatis二级缓存默认使用的是oscache)

  Hibernate一级缓存:session提供了一级缓存的功能,默认总是有效的,应用保存持久化实体、修改持久化实体时,session不会立即将改变提交数据库,而是缓存在当前session,除非显示调用了session的flush()方法或通过close()方法关闭session。通过一级缓存,可以减少应用程序与数据库的交互,提高数据库访问性能。

  Hibernate二级缓存:Hibernate二级缓存是SessionFactory级的缓存。 SessionFactory的缓存分为内置缓存和外置缓存。内置缓存中存放的是SessionFactory对象的一些集合属性包含的数据(映射元素据及预定SQL语句等),对于应用程序来说,它是只读的。外置缓存中存放的是数据库数据的副本,其作用和一级缓存类似.二级缓存除了以内存作为存储介质外,还可以选用硬盘等外部存储设备。二级缓存称为进程级缓存或SessionFactory级缓存,它可以被所有session共享,它的生命周期伴随着SessionFactory的生命周期存在和消亡。(Hibernate二级缓存默认使用的是ehcache)

三.Redis缓存 (重点)

  简介:Redis缓存一般是在service层开启,如果缓存中有数据,请求就不用再进入dao层,也不用再次与数据库连接,能减轻服务器压力,提高性能。(查询内存比查询数据库效率更高)

  应用:

    分布式锁

    session共享

    token生成

    验证码

    ......

  Redis安装(Linux):

    1.在官网上下载Linux版本的Redis(链接https://redis.io/download)

    

    2.在Linux的/usr/local中创建redis文件夹mkdir redis(一般第三方软件放在/usr/local中),上传文件到该文件夹中(securityCRT中输入rz命令即可)

    3.解压文件,并进入解压后的文件夹中,执行make命令,完毕后可以查看该文件夹中的目录如下

      

    4.可以进入src文件夹中,执行./redis-server即可启动redis,例如(注意这种方式启动redis 使用的是默认配置)

      

    5.可以通过启动参数告诉redis使用指定配置文件来启动

./redis-server ../redis.conf

    6.修改redis.conf配置(先退出redis)

      找到redis.conf文件:

        1.注释以下绑定的主机地址 # bind 127.0.0.1

        2. daemonize设置为yes

        3.设置密码requirepass 123456

    7.再次启动redis(在src目录中可以通过后台启动方式 redis-cli -h host -p port -a password,如果不后台启动,会显示如步骤4的界面,就无法进行其他与redis无关的操作),例如:

./redis-cli -h 127.0.0.1 -p 6379 -a "123456"

    如果能ping通,则说明启动成功(这里可能是密码太简单了)

      

    8.远程连接redis (这里使用的是RedisClient),如下所示

    

  Redis基本数据类型:

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

原文地址:https://www.cnblogs.com/ywb-articles/p/10656239.html

时间: 2024-10-13 12:48:30

缓存机制总结(JVM内置缓存机制,MyBatis和Hibernate缓存机制,Redis缓存)的相关文章

jvm内置锁synchronized不能被中断

很久没看技术书籍了,今天看了一下<七周七并发模型>前面两章讲的java,写的还是有深度的.看到了一个有demo,说jvm内置锁synchronized是不能被中断的.照着书上写了个demo,验证了一下,是不能被中断 /** * @Author: * @Description: jdk内置锁不能被中断 * @Date: Created in : 2018/10/4 下午11:34 **/ public class Uninterruptible { private static final Ob

具体解释Hibernate中的二级缓存

1.前言 这篇博客再前几篇博客的基础上来解说一下.Hibernate中的二级缓存.二级缓存是属于SessionFactory级别的缓存机制. 第一级别的缓存是Session级别的缓存,是属于事务范围的缓存,由Hibernate管理,一般无需进行干预.第二级别的缓存是SessionFactory级别的缓存.是属于进程范围的缓存. 2.Hibernate二级缓存 1.分类 二级缓存也分为了两种 内置缓存:Hibernate自带的,不可卸载,通常在Hibernate的初始化阶段,Hibernate会把

详解Hibernate中的二级缓存

1.前言 这篇博客再前几篇博客的基础上来讲解一下,Hibernate中的二级缓存,二级缓存是属于SessionFactory级别的缓存机制.第一级别的缓存是Session级别的缓存,是属于事务范围的缓存,由Hibernate管理,一般无需进行干预.第二级别的缓存是SessionFactory级别的缓存,是属于进程范围的缓存. 2.Hibernate二级缓存 1.分类 二级缓存也分为了两种 内置缓存:Hibernate自带的,不可卸载,通常在Hibernate的初始化阶段,Hibernate会把映

hibernate一级和二级缓存介绍

一级缓存Hibernate缓存包括两大类:Hibernate一级缓存和Hibernate二级缓存Hibernate一级缓存又称为"Session的缓存",它是内置的,不能被卸载(不能被卸载的意思就是这种缓存不具有可选性,必须有的功能,不可以取消session缓在第一级缓存中,持久化类的每个实例都具有唯一的OID存 .在缓存中的对象,具有持久性,session对象负责管理.一级缓存的优点是使用同一个session对象多次查询同一个数据对象,仅对数据库查询一次例如:session.load

物联网架构成长之路(11)-Redis缓存主从复制

1. 说明 在我的物联网平台框架框架中,会用到Redis这个中间件.作为EMQ权限认证的缓存.https://www.cnblogs.com/think-in-java/p/5123884.html 2. 编译&运行 1 wget http://download.redis.io/releases/redis-4.0.6.tar.gz 2 make && make test && make PREFIX=/home/user/workspace/redis inst

分布式Redis缓存串讲(一)

互联网应用的基石 现在流量稍微大些的网站,都会采取Redis.基于Redis的内存缓存特性,可以大幅度降低数据库的访问量,大大提升了网站的并发能力,充当数据库的削量先锋.既然Redis这么重要,我们从它的官方介绍来完整的了解下它的能力,知己知彼,才能更运用自如. Redis官方介绍 Redis是一个开源(BSD协议),内存解构存储,可以用作数据库,缓存和消息代理.它支持诸如字符串(strings),哈希散列(hashs),列表(lists),集合(sets),带有范围查询的排序集(sorted

内置函数:输入输出,input、print以及\r的作用

input: name1 = input('请输入姓名:')#输入的字符串传给name1 print(name1)#打印输入的字符串 print: def print(self, *args, sep=' ', end='\n', file=None): # known special case of print """ print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False) file: 默认是输出

[Redis]c# redis缓存辅助类

using NServiceKit.Redis; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace H5.Utility { /// <summary> /// 分布式缓存 /// </summary> public static class RedisCache { private

相约98-与你畅谈:MyBtis内置缓存机制

在实际的项目开发中,通常对数据库的查询性能要求很高,而mybatis提供了查询缓存来缓存数据,从而达到提高查询性能的要求. mybatis的查询缓存分为一级缓存和二级缓存,一级缓存是SqlSession级别的缓存,二级缓存时mapper级别的缓存,二级缓存是多个SqlSession共享的. mybatis通过缓存机制减轻数据压力,提高数据库性能. 查看个人笔记:http://note.youdao.com/noteshare?id=80eda2335aa3c7605116c24ac6e03b48