《java系统性能优化》--2.高速缓存

上一节。简介了怎样发现性能瓶颈。从这节開始。我会和大家分享我在项目中做的一些性能调优工作。这个系列没有什么顺序可言,认为什么重要。就说说什么。

这节。我们聊缓存。

最開始接触缓存这个词,是学习硬件知识的时候,cpu有缓存,并且还分一级缓存,二级缓存。三级缓存。、

记得以前的以前老师提了一个非常有意思的问题。

问:电脑为什么要有一级缓存,二级缓存……,并且还要有内存,还要有硬盘?

假设你面对这个问题,你怎么回答?

先来看我们的正文,最后再解释。

我们要聊当然不是硬件意义上的缓存,而是应用程序与应用程序之间。或者应用程序与物理资源之间的缓存。

目的是,降低数据訪问的频次,从而提高性能。

缓存的介质通常是内存。所以读写速度非常快。

但假设缓存中存放的数据量非常大时。也会用硬盘作为缓存介质。缓存的实现不只要考虑存储的介质,还要考虑到管理缓存的并发訪问和缓存数据的生命周期。

近期做的TGB项目。我们做了双方面处理:

第一、开启Hibernate二级缓存;

我们系统使用的是JPA,没关系,Hibernate就是JPA的一种实现。我们恰恰是採用了这样的实现。

Hibernate提供了两级缓存,第一级是Session的缓存。因为Session对象的生命周期通常相应一个数据库事务或者一个应用事务,因此它的缓存是事务范围的缓存。第一级缓存是必需的。不同意并且其实也无法比卸除。在第一级缓存中,持久化类的每一个实例都具有唯一的OID。

第二级缓存是一个可插拔的的缓存插件,它是由SessionFactory负责管理。因为SessionFactory对象的生命周期和应用程序的整个过程相应。因此第二级缓存是进程范围或者集群范围的缓存。

这个缓存中存放的对象的松散数据。

第二级对象有可能出现并发问题。因此须要採用适当的并发訪问策略,该策略为被缓存的数据提供了事务隔离级别。缓存适配器用于把详细的缓存实现软件与Hibernate集成。第二级缓存是可选的。能够在每一个类或每一个集合的粒度上配置第二级缓存。

中间提到几个术语。不解释。百度百科吧。

Hibernate的二级缓存策略的一般步骤例如以下:

  1、 条件查询的时候,总是发出一条select * from table_name where …. (选择全部字段)这种SQL语句查询数据库。一次获得全部的数据对象。

  2、把获得的全部数据对象依据ID放入到第二级缓存中。

  3、当Hibernate依据ID訪问数据对象的时候,首先从Session一级缓存中查;查不到,假设配置了二级缓存,那么从二级缓存中查。查不到,再查询数据库,把结果依照ID放入到缓存。

  4、删除、更新、添加数据的时候,同一时候更新缓存。

  Hibernate的二级缓存策略,是针对于ID查询的缓存策略,对于条件查询则毫无作用。为此,Hibernate提供了针对条件查询的Query缓存。

  

Hibernate的Query缓存策略的步骤例如以下:

  1、Hibernate首先依据这些信息组成一个Query Key,Query Key包含条件查询的请求一般信息:SQL, SQL须要的參数,记录范围(起始位置rowStart,最大记录个数maxRows),等。

  2、Hibernate依据这个Query Key到Query缓存中查找相应的结果列表。假设存在,那么返回这个结果列表。假设不存在。查询数据库。获取结果列表,把整个结果列表依据Query Key放入到Query缓存中。

  3、Query Key中的SQL涉及到一些表名。假设这些表的不论什么数据发生改动、删除、添加等操作,这些相关的Query Key都要从缓存中清空。

用了这么长时间,感觉查询缓存作用不大,命中率太低。适合在查询条件固定的地方加入。

怎样开启?太简单。不讲。

第二、在远程调用client加了一层缓存。在服务端加了一层缓存。

使用AOP。我们写了一些Interceptor。缓存一些常常使用的查询条件。即相应的数据。

思路非常easy:

1、给EJB的实现类加入拦截器

2、拦截器推断查询方法的返回值是否已在缓存中,假设在则直接返回。否则调用EJB的方法。并将返回值放到缓存中,然后将结果返回

你可能要问。数据同步的问题。你是怎样解决的?

当EJB运行了增删改方法后,缓存中的数据就变成了脏数据。须要清空缓存

相同是用一个拦截器来解决,不同的是。这个拦截器是加入在EJB增删改方法上的

牵扯到跨系统调用。A系统怎样告诉B系统。你须要的数据已经改了,你要清理自己本地的缓存了呢?

1、在系统A创建一个JMS Topic。起名CacheTopic

2、当系统A运行增删改方法后。向CacheTopic中发一条消息,告诉他,数据改了,要清缓存了。

3、在系统B在自己的server中部署Message Driven Bean。监听CacheTopic中的消息,收到消息后清空本地缓存

另外,对于特别经常使用的Webservice调用,我们会把其代理对象缓存起来。不用每次都去解析wsdl,动态生成。

回到文章开头的那个问题。

我的回答是:提高数据交换速度等等一堆。

但老师就一句话:性价比,这就是商业。

细致琢磨一下,发现自己还是太嫩了。假设不过为了提快速度,干脆都用一级缓存算了,为什么不用?性价比,钱!

相同的道理。既然缓存能够提高效率,我们把系统全部用到查询的地方都用上缓存吧。

错,缓存假设乱用,事半功倍。有些数据常常改动。有些数据八百年也不查一回,有些数据跟钱有关系,不容有不论什么闪失,等等,这些数据,加缓存,纯粹是费力不讨好。非常少改动的数据,同意偶尔并发或者不会被并发訪问(改动)的数据,一些不是非常重要的数据,等等。就能够尝试加缓存。

开篇之所以说这个小故事。是为了提醒大家不要进入思维里的想当然,要权衡利弊看得失。

性能上有说不完的话题,下节,我们接着聊。

版权声明:本文博客原创文章。博客,未经同意,不得转载。

时间: 2024-11-01 21:22:53

《java系统性能优化》--2.高速缓存的相关文章

JAVA性能优化的五种方式

一,JAVA性能优化之设计优化 设计优化处于性能优化手段的上层.它往往须要在软件开发之前进行.在软件开发之前,系统架构师应该就评估系统可能存在的各种潜在问题和技术难点,并给出合理的设计方案,因为软件设计和系统架构对软件总体设计质量有决定性的影响.所以,设计调优对系统的性能影响也是最大的,假设说,代码优化.JVM优化都是对系统微观层次的"量"的优化,那设计优化就是对系统"质"的优化. 设计优化的一大显著特征是:它能够规避某一个组件的性能问题,而是改良组件的实现;比方:

《java系统性能调优》--1.发现瓶颈

性能啊!性能! 之所以想写写性能调优,也是有感于我们的项目,我们采用一些手段使得系统性能上升了一个台阶,总是需要把这点经验沉淀一下.随着工作的深入,关于系统性能的事肯定还有很多,也算是通过这个系列文章做做笔记.优化可能包括应用级别的优化,也可能包括代码级别的优化. "要进行优化,先得找到性能瓶颈!" 忘记是从哪里看到了这句话,但总算切中要害. 但在找性能瓶颈之前,我们总要先对系统性能有一个概念. 如何在不购买新硬件的条件下完成更多的工作?何时才真正需要添加硬件(更多的内存,更快的磁盘.

Java 程序优化 (读书笔记)

--From : JAVA程序性能优化 (葛一鸣,清华大学出版社,2012/10第一版) 1. java性能调优概述 1.1 性能概述 程序性能: 执行速度,内存分配,启动时间, 负载承受能力. 性能指标: 执行时间,CPU时间,内存分配,磁盘吞吐量,网络吞吐量,响应时间. 优化策略: 木桶原理,优化性能瓶颈. 1.2 性能调优的层次 设计调优, 代码调优, JVM调优, 数据库调优, 操作系统调优. 2. 设计优化 2.1 善用设计模式 单例模式: 对于巨大对象,节省创建对象的时间空间: 代理

工作之:Java性能优化之创建对象

1.Java 性能优化之创建对象对于每个java程序员都知道怎样创建对象,但是你知道怎样创建才能提高应用的性能呢?你知道创建对象的应用规则吗?(1).要尽量避免在循环体中创建对象.(2).尽量及时使对象符合垃圾回收标准.(3).不要采用过深的继承层次.(4).访问本地变量优于访问类中的变量.例如:Vector v=new Vector();for(int i=0; i<100;i++){Object obj=new Object(); }这样的写法大家都不陌生吧.可是这样会浪费大量的内存空间.正

推荐:Java性能优化系列集锦

Java性能问题一直困扰着广大程序员,由于平台复杂性,要定位问题,找出其根源确实很难.随着10多年Java平台的改进以及新出现的多核多处理器,Java软件的性能和扩展性已经今非昔比了.现代JVM持续演进,内建了更为成熟的优化技术.运行时技术和垃圾收集器.与此同时,底层的硬件平台和操作系统也在演化. 目录: 一.Java性能优化系列之一--设计优化 二.Java性能优化系列之二--程序优化 三.Java性能优化系列之三--并发程序设计详解 四.Java性能优化系列之四--Java内存管理与垃圾回收

Java性能优化之String字符串优化

字符串是软件开发中最重要的对象之一.通常,字符串对象在内存中是占据了最大的空间块,因此如何高效地处理字符串,必将是提高整体性能的关键所在. 1.字符串对象及其特点 Java中八大基本数据类型没有String类型,因为String类型是Java对char数组的进一步封装. String类的实现主要由三部分组成:char数组,offset偏移量,String的长度. String类型有三个基本特点: 不变性 不变性是指String对象一旦生成,则不能再对它进行改变. 不变性的作用在于当一个对象需要被

JAVA性能优化分布式架构和部署

一,JAVA性能优化之设计优化 设计优化处于性能优化手段的上层.它往往须要在软件开发之前进行.在软件开发之前,系统架构师应该就评估系统可能存在的各种潜在问题和技术难点,并给出合理的设计方案,因为软件设计和系统架构对软件总体设计质量有决定性的影响.所以,设计调优对系统的性能影响也是最大的,假设说,代码优化.JVM优化都是对系统微观层次的“量”的优化,那设计优化就是对系统”质”的优化. 设计优化的一大显著特征是:它能够规避某一个组件的性能问题,而是改良组件的实现;比方:组件A通过循环监控不断的检測时

Java性能优化技巧及实战

Java性能优化技巧及实战 关于Java代码的性能优化,是每个javaer都渴望掌握的本领,进而晋升为大牛的必经之路,但是对java的调优需要了解整个java的运行机制及底层调用细节,需要多看多读多写多试,并非一朝一夕之功.本文是近期笔者给公司员工内部做的一个培训,主要讲述在系统压测过程中出现的性能问题,以及如何在编码过程中提升代码的运行效率,需要掌握哪些实战技巧.片子里干货较多,也很具有实操性,因此发文出来,共享给大家(部分数据做了去除公司特征信息,见谅).(PS:由于原文是ppt,因此做了导

java性能优化技巧

一.通用篇 "通用篇"讨论的问题适合于大多数 Java应用. 1.1     new 1.1     new 11..11 不用 nneeww关键词创建类的实例 用new 关键词创建类的实例时,构造函数链中的所有构造函数都会被自动调用.但如 果一个对象实现了Cloneable 接口,我们可以调用它的clone()方法.clone()方法不会调用任 何类构造函数. 在使用设计模式(Design Pattern)的场合,如果用 Factory模式创建对象,则改用clone() 方法创建新的