网站缓存技术
来源:互联网 发布:戏曲伴奏软件 编辑:程序博客网 时间:2024/05/16 23:58
- 一 WHY-缓存为什么存在
- 二 WHAT-缓存是什么
- A 缓存术语
- B 缓存存在位置
- a 客户端缓存-web缓存
- b 服务端缓存-Ehcache与memcached与redis
- 三 HOW-缓存的作用
参考:
网站缓存技术总结( ehcache memcache redis)
缓存、缓存算法和缓存框架简介
Web开发人员需知的Web缓存知识
Caching Tutorial
Web缓存基础:术语、HTTP报头和缓存策略
Java中的缓存技术该如何实现
5个强大的Java分布式缓存框架
一、 WHY-缓存为什么存在
一般情况下,一个网站,或者一个应用,它的一般形式是,浏览器请求应用服务器,应用服务器做一堆计算后再请求数据库,数据库收到请求后再作一堆计算后把数据 返回给应用服务器,应用服务器再作一堆计算后把数据返回给浏览器.这个是一个标准流程.
但是随着互连网的普及,上网的人越来越多,网上的信息量也越来越 多,在这两个越来越多的情况下,我们的应用需要支撑的并发量就越来越多.然后我们的应用服务器和数据库服务器所做的计算也越来越多,但是往往我们的应用服 务器资源是有限的,数据库每秒中接受请求的次数也是有限的(谁叫俺们的硬盘转速有限呢).如果利用有限的资源来提供尽可能大的吞吐量呢,一个办法:减少计 算量,缩短请求流程(减少网络io或者硬盘io),这时候缓存就可以大展手脚了.缓存的基本原理就是打破上图中所描绘的标准流程,在这个标准流程中,任何 一个环节都可以被切断.请求可以从缓存里取到数据直接返回.这样不但节省了时间,提高了响应速度,而且也节省了硬件资源.可以让我们有限的硬件资源来服务 更多的用户.
二、 WHAT-缓存是什么
缓存是“存贮数据(使用频繁的数据)的临时地方,因为取原始数据的代价太大了,所以我可以取得快一些。”
缓存(caching)是一个描述存储可重用资源以便加快后续请求的行为的术语。有许多不同类型的缓存,每种都有其自身的特点,应用程序缓存和内存缓存由于其对特定回复的加速,都很常用。
A. 缓存术语
缓存命中率:
一个缓存的有效性依照缓存的命中率进行度量。它是可以从缓存中得到数据的请求数与所有请求数的比率。缓存命中率高意味着有很高比例的数据可以从缓存中获得。这通常是大多数管理员想要的结果。
失效:
失效是依据过期日期从缓存中移除内容的过程。当内容在原始服务器上已被改变时就必须这样做,缓存中过期的内容会导致客户端发生问题。
缓存算法
FIFO、LRU、LFU
B. 缓存存在位置
- 网站缓存按照存放的地点不同,可以分为客户端缓存、服务端缓存。
a. 客户端缓存-web缓存
- 客户端缓存又可分为:浏览器缓存、网关或代理服务器缓存
网关或代理服务器缓存是将网页缓存中网关服务器上,多用户访问同一个页面时,将直接从网关服务器把页面传送给用户。
浏览器缓存是最靠近用户的缓存,如果启用缓存,用户在访问同一个页面时,将不再从服务器下载页面,而是从本机的缓存目录中读取页面,然后再浏览器中展现这个页面。
不过现在的网站为了保证用户访问到最新的内容,一般很少采用浏览器缓存,取而代之的是更加灵活的服务器缓存。
b. 服务端缓存-Ehcache与memcached与redis
服务端缓存分为:页面缓存、数据缓存、数据库缓存
页面缓存
页面缓存是将动态页面直接生成静态的页面放在服务器端,用户调取相同页面时,静态页面将直接下载到客户端,不再需要通过程序的运行和数据库的访问,大大节约了服务器的负载。
早期的网站很多使用发布系统来完成这个功能,在后台发布时将数据和页面模板整合成静态页面,存放在硬盘中。但这样的缺陷很明显,一是后台的程序的编写很 复杂,二是缓存的控制只能通过人为的方式来控制,这对一些更新十分频繁的网站就是一个噩梦,网站可能在不停的做缓存的删除和重建。当然后来出现了一些自动 更新这些缓存的框架,比如PHP的SMARTY模板技术,可以定义缓存过期的时间,自动去更新这些缓存。这对一些信息发布类网站已经确实适用了。
除了整个页面的缓存技术,还有一种技术叫做“网页片段缓存技术”,将页面的部分而不是全部进行缓存。代表作有ESI cache。数据缓存
Ehcache、memcached、redis
未完。。。
三、 HOW-缓存的作用
未完。。。
- 网站缓存技术
- 网站缓存技术
- 网站缓存技术
- 网站缓存技术
- 网站缓存技术
- 网站缓存技术
- 网站缓存技术
- 网站性能优化 静态缓存技术
- 大型网站架构演变及缓存技术
- 动易swCMS6.5网站的缓存技术分析
- 让网站飞起来02--服务器缓存技术
- 让网站飞起来01---浏览器缓存技术
- 让网站飞起来01---浏览器缓存技术
- 让网站飞起来02--服务器缓存技术
- 网站缓存技术总结( ehcache memcache redis)
- 网站缓存技术 ehcache memcache redis 的比较
- 网站缓存技术总结( ehcache memcache redis)
- .Net网站架构设计(四) 缓存技术
- 【前端笔记】一点点http缓存问题
- 转载 session过期时间
- 了解HashMap的get和put内部的工作原理,需要理解透Java HashMap的原理
- Redis-benchmark测试Redis性能
- hdu5641King's Phone
- 网站缓存技术
- 1010-小朋友排队
- Java中的除
- mysql和oracle的分页
- SimpleAdapter创建ListView
- Java eclipse下 Ant build.xml实例详解 附完整项目源码
- PAT_A 1108. Finding Average (20)
- HDU 5640:King's Cake【几何】
- C++string类型转换为C数组