如何正确使用缓存技术

缓存技术是用来提升程序运行性能的常见手段,如你所见, 阿里巴巴、新浪微博、美团网等互联网龙头企业都是用缓存技术来提升自己家网站的性能。然而,任何事物都有两面性, 缓存技术使用得当带来的好处自然不言而喻, 但是如果使用不当, 产生的副作用也够让人喝一壶的。

我们写服务器程序时,使用缓存的目的无非就是减少数据库访问次数降低数据库的压力和提升程序的响应时间, 然而根据具体的使用场景又可以派生出无数种情况, 比如说

程序频繁读取数据库, 但是查询获得的结果却总是相同的,这部分相同的结果是不是可以放入缓存 ?

获得查询结果要进行复杂的运算,非常消耗时间, 运算结果是不是可以放入缓存 ?

有一些在网站每个页面都需要使用的数据, 比如说用户数据, 是不是可以放入缓存 ?

还有另外不胜枚举等等各种情况,概括起来就是那些变化不那么频繁, 从源头读取又显得耗费资源和性能的数据, 是不是都应该放入缓存 ?

既然身为行业技术风向标的淘宝、美团、新浪里面的技术大牛们都在使用缓存技术, 那么咱们自然也得跟上他们的脚步。 然而不知道大家有没有听到有这样一种流传甚广说法:“在选择一样东西前,请先问一下自己,我喜欢吗? 我适合吗?我需要吗?”, 具体到我们在工作中选择使用某种技术,喜欢其实不应该是左右我们选择某项技术的关键, 而合适和需要才是我们应该详细考虑的。 这个道理自然也适合于是否使用缓存技术上面。

通常来讲,狭义上的缓存仅指一些缓存软件, 如memcached或redis; 而广义上缓存不仅包括缓存软件, 程序的内存空间、static变量、磁盘文件、甚至数据库自身, 只要能用来放置临时数据提升程序性能的都可以称之为缓存。

我们在使用缓存技术提高程序性能时应该不仅仅把缓存的范围局限于狭义的缓存技术, 而应该从广义的缓存技术集合中, 结合自身程序的特点选择一种合适的缓存模式。 比如说用户信息数据,就算全都放session之中也未尝不可, 难不成用户数据会有几十上百兆不成;比如说复杂的查询结果临时放置的位置,新建一个表存放或存储在磁盘文件中亦可;比如说需要频繁读取的结果 , 如果是使用Java之类的语言, 那么放在一个static变量中也可以解决问题;以上这些都是缓存技术的应用实践。

有的同学可能会提出质疑,为什么我们非要搞这么多的花样?直接使用缓存软件不是都能解决上面这些问题吗? 然而并不是, 因为我们在享受缓存软件带来的好处的同时,却往往忽略它带来的副作用,而这些副作用在程序的开发的初期阶段往往是不会显现出来的, 到了开发后期或者部署上线至生产环境时,问题才有可能暴露出来。 举一个例子来侧面说明下

假如我们开发一个非常简单的网站应用程序,只有少量的简单数据需要存储,那么应该选择什么作为我们存储数据的介质? 关系数据库或者xml文件? 答案很显然, xml文件存储方案显然要优于关系数据库。 我们使用数据库存储数据, 那么势必需要在服务器安装数据库软件, 新建访问用户, 而且同样的事情在开发环境和生产环境都需要做一遍, 跟环境相关的东西如数据库地址、用户名、密码之类都还都需要存储在某个配置文件中, 一来二去问题就变得相对复杂了。 而存储在xml中就简单的多了, 直接在项目中建个目录存储文件就行了, 至于xml的编程接口那是任何一种技术的标准配置,根本不用自己去实现。 这样把程序部署至线上环境会方便的多, 不用考虑各种环境依赖问题。 而使用关系数据库, 对于这类简单的项目就是拿着牛刀去杀鸡,真正的威力发挥不出来, 还把问题搞的复杂 。

在某些情况下, 缓存软件和上面例子中的关系数据库其实扮演的是同一个角色 ,缓存软件真正的威力没有发挥出来, 却把程序搞的相对复杂,这不是得不偿失的做法吗?

因此, 在决定使用缓存软件前, 一定先确定上面所提的广义的缓存都没有办法满足需求了,届时再使用缓存软件才能将它能发挥的价值最大化,或可抵消使用它带来的副作用。

时间: 2024-10-21 15:00:03

如何正确使用缓存技术的相关文章

前端缓存技术一:使用ETags减少Web应用带宽和负载

介绍 最近,大众对于REST风格应用架构表现出强烈兴趣,这表明Web的优雅设计开始受到人们的注意.现在,我们逐渐理解了"3W架构(Architecture of the World Wide Web)"内在所蕴含的可伸缩性和弹性,并进一步探索运用其范式的方法.本文中,我们将探究一个可被Web开发者利用的.鲜为人知的工具,不引人注意的"ETag响应头(ETag Response Header)",以及如何将它集成进基于Spring和Hibernate的动态Web应用,

分布式缓存技术redis学习系列(三)——redis高级应用(主从、事务与锁、持久化)

上文<详细讲解redis数据结构(内存模型)以及常用命令>介绍了redis的数据类型以及常用命令,本文我们来学习下redis的一些高级特性. 回到顶部 安全性设置 设置客户端操作秘密 redis安装好后,默认情况下登陆客户端和使用命令操作时不需要密码的.某些情况下,为了安全起见,我们可以设置在客户端连接后进行任何操作之前都要进行密码验证.修改redis.conf进行配置. [[email protected] ~]# vi /usr/local/redis/etc/redis.conf ###

分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装

redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssdb,mongodb等.既可以把redis理解为理解为缓存技术,因为它的数据都是缓存在内从中的:也可以理解为数据库,因为redis可以周期性的将数据写入磁盘或者把操作追加到记录文件中.而我个人更倾向理解为缓存技术,因为当今互联网应用业务复杂.高并发.大数据的特性,正是各种缓存技术引入最终目的. 关于r

Redis缓存技术学习系列之邂逅Redis

??作为一个反主流的开发者,在某种程度上,我对传统关系型数据库一直有点"讨厌",因为关系型数据库实际上和面向对象思想是完全冲突的,前者建立在数学集合理论的基础上,而后者则是建立在软件工程基本原则的基础上.虽然传统的ORM.序列化/反序列化在一定程度上解决了这种冲突,但是软件开发中关于使用原生SQL语句还是使用ORM框架的争论从来没有停止过.可是实际的业务背景中,是完全无法脱离数据库的,除非在某些特定的场合下,考虑到信息安全因素而禁止开发者使用数据库,在主流技术中数据库是一个非常重要的组

(转)java缓存技术,记录

http://blog.csdn.net/madun/article/details/8569860 最近再ITEYE上看到关于讨论JAVA缓存技术的帖子比较多,自己不懂,所以上网大概搜了下,找到一篇,暂作保存,后面如果有用到可以参考.此为转贴,帖子来处:http://cogipard.info/articles/cache-static-files-with-jnotify-and-ehcache 介绍 JNotify:http://jnotify.sourceforge.net/,通过JNI

硬盘缓存技术DiskLruCache技术&lt;笔记&gt;

防止多图OOM的核心解决思路就是使用LruCache技术,但LruCache只是管理了内存中图片的存储与释放,如果图片从内存中被移除的话,那么又需要从网络上重新加载一次,这显然非常耗时.因此Google又提供了一套硬盘缓存的解决方案:DiskLruCache(非Google官方编写,但获得官方认证).一般来说新闻类App从网络获取到数据后都会存入到本地缓存中,因此即使手机在没有网络的情况下依然能够加载出以前浏览过的新闻.使用的缓存技术自然是DiskLruCache.以网易新闻为例,它的Andro

PHP 缓存技术

PHP缓存包括PHP编译缓存和PHP数据缓存两种. PHP是一种解释型语言,属于边编译边运行的那种.这种运行模式的优点是程序修改很方便,但是运行效率却很低下. PHP编译缓存针对这种情况做改进处理,使得PHP语言只要运行一次,就可以把程序的编译结果缓存起来. PHP编译缓存: 目前最常见的PHP编译缓存工具有:APC,Accelerator,xcache(国产)等. PHP是一种解释型语言,在PHP语言执行代码的时候,需要下面两步: 1.编译过程.PHP读取文件,并编译该文件,然后生成能够在Ze

ASP.NET 缓存技术分析

缓存功能是大型网站设计一个很重要的部分.由数据库驱动的Web应用程序,如果需要改善其性能,最好的方法是使用缓存功能.可能的情况下尽量使用缓 存,从内存中返回数据的速度始终比去数据库查的速度快,因而可以大大提供应用程序的性能.毕竟现在内存非常便宜,用空间换取时间效率应该是非常划算的.尤 其是对耗时比较长的.需要建立网络链接的数据库查询操作等. 对于web页面的缓存,WebForm与ASP.NET MVC有不同的语法.在WebForm中, <%@ OutputCache Duration="6

PHP缓存技术

全页面静态化缓存也就是将页面全部生成html静态页面,用户访问时直接访问的静态页面,而不会去走php服务器解析的流程.此种方式,在CMS系统中比较常见,比如dedecms:一种比较常用的实现方式是用输出缓存:Ob1.全页面静态化缓存也就是将页面全部生成html静态页面,用户访问时直接访问的静态页面,而不会去走php服务器解析的流程.此种方式,在CMS系统中比较常见,比如dedecms:一种比较常用的实现方式是用输出缓存:Ob_start()******要运行的代码*******$content