用dw做网站怎么上传到网站上,上海注册公司需要多久,wordpress主题带卡密,安徽蚌埠怀远县建设局网站一级缓存和二级缓存
一级缓存是SqlSession级别的#xff0c;通过同一个SqlSession查询的数据会被缓存#xff0c;下次查询相同的数据#xff0c;就会从一级缓存中直接获取#xff0c;不会从数据库重新查询。一级缓存默认是开启 使一级缓存失效的四种情况#xff1a; 11.1…一级缓存和二级缓存
一级缓存是SqlSession级别的通过同一个SqlSession查询的数据会被缓存下次查询相同的数据就会从一级缓存中直接获取不会从数据库重新查询。一级缓存默认是开启 使一级缓存失效的四种情况 11.1、不同的SqlSession对应不同的一级缓存。 Testpublic void testGetEmpById(){SqlSession sqlSession1 SqlSessionUtil.getSqlSession();System.out.println(sqlSession1);SqlSession sqlSession2 SqlSessionUtil.getSqlSession();System.out.println(sqlSession2);EmpMapper empMapper1 sqlSession1.getMapper(EmpMapper.class);Emp emp1 empMapper1.getEmpById(1);System.out.println(emp1);System.out.println(-----------------------------------);EmpMapper empMapper2 sqlSession2.getMapper(EmpMapper.class);Emp emp2 empMapper2.getEmpById(1);System.out.println(emp2);} 2、同一个SqlSession但是查询条件不同。
3、同一个SqlSession两次查询之间执行了任何一次增删改操作 Emp emp1 empMapper.getEmpById(1);System.out.println(emp1);empMapper.insertEmp(new Emp(null,小张,23,男));Emp emp2 empMapper.getEmpById(1);System.out.println(emp2); 4、同一个SqlSession两次查询之间手动清空了缓存 //手动清空一级缓存
sqlSession.clearCache(); 11.2、MyBatis的二级缓存
二级缓存是SqlSessionFactory级别的通过同一个SqlSessionFactory创建的SqlSession查询的结果都会被缓存下次查询相同的数据就会从二级缓存中直接获取不会从数据库重新查询。二级缓存默认是不开启的
二级缓存开启的条件
在核心配置文件中设置全局配置属性cacheEnabled”true” ,默认为true。所以不需要设置在映射文件中设置标签cache/二级缓存必须在SqlSession关闭之后生效查询的数据所转换的实体类类型必须实现序列化的接口 public class Emp implements Serializable Testpublic void testCache() throws IOException {InputStream inputStream Resources.getResourceAsStream(mybatis-config.xml);SqlSessionFactoryBuilder sqlSessionFactoryBuilder new SqlSessionFactoryBuilder();SqlSessionFactory sqlSessionFactory sqlSessionFactoryBuilder.build(inputStream);/*sqlSession1和sqlSession2都是sqlSessionFactory创建的*/SqlSession sqlSession1 sqlSessionFactory.openSession(true);EmpMapper empMapper1 sqlSession1.getMapper(EmpMapper.class);Emp emp1 empMapper1.getEmpById(1);System.out.println(emp1);sqlSession1.close();System.out.println(-----------------------);SqlSession sqlSession2 sqlSessionFactory.openSession(true);EmpMapper empMapper2 sqlSession2.getMapper(EmpMapper.class);Emp emp2 empMapper2.getEmpById(1);System.out.println(emp2);sqlSession2.close();} Cache Hit Ratio二级缓存命中率不为0说明程序直接从二级缓存中获取了数据
使二级缓存失效的情况
两次查询之间执行了任意的增删改会使一级和二级缓存同时失效 11、3二级缓存的相关配置
在mapper配置文件中添加的cache标签可以设置一些属性
①eviction属性缓存回收策略默认的是 LRU。
LRULeast Recently Used – 最近最少使用的移除最长时间不被使用的对象。
FIFOFirst in First out – 先进先出按对象进入缓存的顺序来移除它们。
SOFT – 软引用移除基于垃圾回收器状态和软引用规则的对象。
WEAK – 弱引用更积极地移除基于垃圾收集器状态和弱引用规则的对象。
②flushInterval属性刷新间隔单位毫秒
默认情况是不设置也就是没有刷新间隔缓存仅仅调用语句时刷新
③size属性引用数目正整数代表缓存最多可以存储多少个对象太大容易导致内存溢出
④readOnly属性只读 true/false
true只读缓存会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。
false读写缓存会返回缓存对象的拷贝通过序列化。这会慢一些但是安全因此默认是false。
11.4、mybatis缓存查询的顺序
先查询二级缓存因为二级缓存中可能会有其他程序已经查出来的数据可以拿来直接使用。
如果二级缓存没有命中再查询一级缓存
如果一级缓存也没有命中则查询数据库
SqlSession关闭之后一级缓存中的数据会写入二级缓存
11.5整合第三方的缓存EhCache
11.5.1添加依赖 !-- Mybatis EHCache整合包 --dependencygroupIdorg.mybatis.caches/groupIdartifactIdmybatis-ehcache/artifactIdversion1.2.1/version/dependency!-- slf4j日志门面的一个具体实现 --dependencygroupIdch.qos.logback/groupIdartifactIdlogback-classic/artifactIdversion1.2.3/version/dependency
11.5.2各jar的功能 jar包名称 作用 mybatis-ehcache Mybatis和EHCache的整合包 ehcache EHCache核心包 slf4j-api SLF4J日志门面包 logback-classic 支持SLF4J门面接口的一个具体实现 11.5.3创建EHCache配置文件ehcache.xml ?xml version1.0 encodingutf-8 ?ehcache xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:noNamespaceSchemaLocation../config/ehcache.xsd!-- 磁盘保存路径 --diskStore pathD:\qingcheng\ehcache/defaultCachemaxElementsInMemory1000maxElementsOnDisk10000000eternalfalseoverflowToDisktruetimeToIdleSeconds120timeToLiveSeconds120diskExpiryThreadIntervalSeconds120memoryStoreEvictionPolicyLRU/defaultCache/ehcache 11.5.4设置二级缓存的类型 cache typeorg.mybatis.caches.ehcache.EhcacheCache/cache 11.5.5加入logback日志
存在SLF4J时作为简易日志的log4j将失效此时需要借助SLF4J的具体实现logback来打印日志创建logback的配置文件logback.xml
?xml version1.0 encodingUTF-8?
configurationspringProperty scopecontext namelogName sourcelogging.file.name defaultValuelog.log /!--定义日志文件的存储地址--property nameLOG_HOME value${logName} /!--格式化输出%d表示日期%thread表示线程名%-5level级别从左显示5个字符宽度%msg日志消息%n是换行符--property nameLOG_PATTERN value%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n /!-- 控制台输出 --appender nameconsole classch.qos.logback.core.ConsoleAppenderencoderpattern${LOG_PATTERN}/pattern/encoder/appender!-- 输出到日志文件 --appender nameFILE classch.qos.logback.core.rolling.RollingFileAppenderfile${LOG_HOME}/filerollingPolicy classch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy!--日志文件输出的文件名--FileNamePattern${LOG_HOME}.%d{yyyy-MM-dd}.%i/FileNamePatternMaxHistory30/MaxHistoryMaxFileSize50MB/MaxFileSize/rollingPolicyencoderpattern${LOG_PATTERN}/pattern/encoder/appender!-- 自定义logger --logger namecom.dispart leveldebug additivityfalseappender-ref refconsole //logger!--sql语句执行输出--logger nameorg.apache.ibatis leveldebug additivityfalseappender-ref refconsole //loggerroot levelinfo additivityfalseappender-ref refconsole //root
/configuration
11.5.6EHCache配置文件说明 属性名 是否必须 作用 maxElementsInMemory 是 在内存中缓存的element的最大数目 maxElementsOnDisk 是 在磁盘上缓存的element的最大数目若是0表示无穷大 eternal 是 设定缓存的elements是否永远不过期。如果为true则缓存的数据始终有效如果为false那么还要根据timeToIdleSeconds、timeToLiveSeconds判断 overflowToDisk 是 设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上 timeToIdleSeconds 否 当缓存在EhCache中的数据前后两次访问的时间超过timeToIdleSeconds的属性取值时这些数据便会删除默认值是0,也就是可闲置时间无穷大 timeToLiveSeconds 否 缓存element的有效生命期默认是0.,也就是element存活时间无穷大 diskSpoolBufferSizeMB 否 DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区 diskPersistent 否 在VM重启的时候是否启用磁盘保存EhCache中的数据默认是false。 diskExpiryThreadIntervalSeconds 否 磁盘缓存的清理线程运行间隔默认是120秒。每个120s相应的线程会进行一次EhCache中数据的清理工作 memoryStoreEvictionPolicy 否 当内存缓存达到最大有新的element加入的时候移除缓存中element的策略。默认是LRU最近最少使用可选的有LFU最不常使用和FIFO先进先出 11.5.7 测试还用之前的测试方法即可