Apache PHP利用HTTP缓存协议原理解析及应用

原文:http://www.phpx.com/tech/php/2009-01-29/286.html

下面是截取得apache返回客户端的头
            ---------
            Last-Modified: Fri, 26 Jan 2007 01:53:34 GMT
            ETag: "3f9f640-318-cb9f8380"
            ---------
            搜索引擎之所以喜欢静态文件是因为有这两个标识,可以判断文件是否更新过
            二、PHP等动态页面
            由于php是动态生成的,它的内容是不能根据php程序的时间来确定最后修改日期,所以默认php返回客户端的时候补包含任何缓存控制,要想利用好缓存就必须了解缓存机制,和理减少b,s的交互,缩减带宽流量,减轻服务器负担...好处多多f
            三、缓存控制的具体含义f
            先解释一下本人经过测试理解的这几个标签的含义
            Cache-Control:指定请求和响应遵循的缓存机制。在请求消息或响应消息中设置Cache-Control并不会修改另一个消息处理过程中的缓存处理过程。请求时的缓存指令包括no-cache、no-store、max-age、max-stale、min-fresh、only-if-cached,响应消息中的指令包括public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age。各个消息中的指令含义如下:
            Public指示响应可被任何缓存区缓存。
            Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
            no-cache指示请求或响应消息不能缓存
            no-store用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。
            max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
            min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
            max-stale指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。
            php用法:
            在输出之前用header(),(如果使用ob_start()可以将header放在程序任意地方)
            header('Cache-Control: max-age=8');
            max-age=8表示最大生存期8秒,超过8秒浏览器必须去服务器重新读取,这个时间是以用户的读取页面开始计时的,而Expires是绝对时间。
            Expires:缓存过期的绝对时间,如果过了它指定的那个时间点,浏览器就不认缓存了,要去服务器重新请求一份最新的。
            Last-Modified:文档的最后修改时间,它的妙用就是:1
            如果是静态文件,客户端会发上来它缓存里的时间,apache会来比对,如果发现没有修改就直接返回一个头,状态码是304,字节数非常少,(高级版本还会增加比较Etag来确定文件是否变化)
            2 php动态文件:
            客户端发上比对时间,php会判断是否修改,如果修改时间相同,就只会返回1024字节,至于为什么返回1024不得而知,如果你的php生成的文件非常大,它也只返回1024,所以比较省带宽,客户端会根据服务器端发过来的修改时间自动从缓存文件里显示。
            注:如果没有Last-Modified头,Cache-Control和Expires也是可以起作用的,但每次请求要返回真实的文件字节数,而不是1024
            四、HOW ?
            静态页面不用去管它了,如果想更好的控制静态页面的缓存,apache有几个模块可以很好的控制,这里不讨论
            php页面:
            这里分两种:1
            不经常改动的页面,类似新闻发布,这类页面的特点:第一次发布之后会有几次改动,随着时间推移基本不会再修改。控制策略应该是:1第一次发布之发送Last-Modified,max-age设定1天,修改过之后更新Last-Modified,max-age时间随着修改次数正常。这样似乎比较繁琐,还要记录修改次数,也可以预计一下下次可能的修改时间用Expires指定到大概时间过期
            php代码:
            //header('Cache-Control: max-age=86400');//缓存一天
            header('Expires: Mon, 29 Jan 2007 08:56:01 GMT');//指定过期时间
            header('Last-Modified: '.gmdate('D, d M Y 01:01:01',$time).'
            GMT');//格林尼治时间,$time是文件添加时候的时间戳
            2 经常改动的页面
            类似bbs,论坛程序,这种页面更新速度比较快,缓存的主要作用是防止用户频繁刷新列表,导致服务器数据库负担,既要保证更新的及时性,也要保证缓存能被利用
            这里一般用Cache-Control来控制,根据论坛的发帖的频率灵活控制max-age。
            header('Cache-Control: max-age=60');//缓存一分钟
            header('Last-Modified: '.gmdate('D, d M Y 01:01:01',$time).'
            GMT');//格林尼治时间,$time是帖子的最后更新时间戳
            五 额外
            1 刷新,转到,强制刷新的区别
            浏览器上有刷新和转到按键,有的浏览器支持用ctrl+F5强制刷新页面,它们的区别是什么?
            转到:用户点击链接就是转到,它完全使用缓存机制,如果有Last-Modified那么不会和服务器通讯,用抓包工具可以查看到发送字节是0byte,如果缓存过期,那么它会执行F5刷新的动作。
            刷新(F5):这种刷新也是根据缓存是否有Last-Modified来决定,如果有会转入304或1024(php),如果没有最后更新时间那么去服务器读取,返回真实文档大小
            强制刷新:完全抛弃缓存机制,去服务器读取最新文档,向服务器发送的header如下
            Cache-Control: no-cache
            2 调试工具
            查看浏览器和服务器交互比较好的工具是httpwatch pro,现在的版本4.1,支持ie7
            还有别的代理抓包工具可以分析,http debugging。没用过,还有tcp抓包工具,2000自带的network
            monitor不过不是专门针对http的比较难用P如何利用HTTP缓存协议原理解析及应用指南

你可能感兴趣的:(Apache PHP利用HTTP缓存协议原理解析及应用)