apache mod_expires与mod_headers文件缓存与mod_deflate压缩输出

发布时间:2020-01-25编辑:脚本学堂
本文介绍下,在apache服务器中,使用mod_expires与mod_headers模块实现文件缓存,以及mod_deflate压缩输出的实现方法,有需要的朋友参考下。

一,使用mod_deflate module 压缩输出(启动gzip)
开启mod_deflate
 

复制代码 代码示例:
sudo a2enmod deflate 
sudo /etc/init.d/apache2 restart 

在httpd.conf中添加
 

复制代码 代码示例:
<IfModule mod_deflate.c> 
#单独设置需要压缩的类型 
AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css 
AddOutputFilterByType DEFLATE application/x-javascript 
</IfModule> 

如果默认所有输出都需要压缩,只排除部分。
 

复制代码 代码示例:
<IfModule mod_deflate.c> 
SetOutputFilter DEFLATE #插入过滤器,gzip所有输出 
 
#设置不压缩的类型 
SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary 
SetEnvIfNoCase Request_URI .(?:exe|t?gz|zip|bz2|sit|rar)$ no-gzip dont-vary 
SetEnvIfNoCase Request_URI .(?:pdf|doc)$ no-gzip dont-vary 
</IfModule> 

二,使用Apache mod_expires 与 mod_headers模块实现文件缓存

1)、开启 mod_expires 与mod_headers
 

复制代码 代码示例:
sudo a2enmod expires 
sudo a2enmod headers 
sudo /etc/init.d/apache2 restart 

2)、使用用mod_expires,在httpd.conf中添加:
 

复制代码 代码示例:
<IfModule mod_expires.c> 
ExpiresActive on #开启 
ExpiresDefault A300 #默认 
ExpiresByType text/html A300 
ExpiresByType text/css A2592000 # 30天 
ExpiresByType image/gif A2592000 
ExpiresByType image/jpeg A2592000 
ExpiresByType application/x-javascript A2592000 
</IfModule> 

3)、使用mod_headers,在httpd.conf中添加:
 

复制代码 代码示例:
<IfModule mod_headers.c> 
<FilesMatch ".(ico|pdf|flv|jpg|jpeg|png|gif|js|css|swf)$"> 
Header set Cache-Control "max-age=604800, public" 
</FilesMatch> 
<FilesMatch ".(xml|txt)$"> 
Header set Cache-Control "max-age=18000, public, must-revalidate" 
</FilesMatch> 
<FilesMatch ".(html|htm|php)$"> 
Header set Cache-Control "max-age=3600, must-revalidate" 
</FilesMatch> 
</IfModule> 

3.Cache-Control说明:
网页的缓存是由 HTTP消息头中的“Cache-control”来控制的,常见取值有private、no-cache、max-age、must- revalidate等,默认为private。
其作用根据不同的重新浏览方式分为以下几种情况:
1)、打开新窗口
    值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器
    而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:
    Cache-control: max-age=5(表示当访问此网页后的5秒内再次访问不会去服务器)

2)、在地址栏回车
    值为private或must-revalidate则只有第一次访问时会访问服务器,以后就不再访问。
    值为no-cache,那么每次都会访问。
    值为max-age,则在过期之前不会重复访问。

3)、按后退按扭
    值为private、must-revalidate、max-age,则不会重访问,
    值为no-cache,则每次都重复访问

4)、按刷新按扭
    无论为何值,都会重复访问

Cache-Control(常规标头,HTTP1.1)

.public:(仅为响应标头)   
响应:告知任何途径的缓存者,可以无条件的缓存该响应.

.private(仅为响应标头)   
响应:告知缓存者(据我所知,是指用户代理,常见浏览器的本地缓存.用户也是指,系统用户.但也许,不应排除,某些网关,可以识别每个终端用户的情况),只针对单个用户缓存响应. 且可以具体指定某个字段.如private –“username”,则响应头中,名为username的标头内容,不会被共享缓存.

.no-cache:   
请求: 告知缓存者,必须原原本本的转发原始请求,并告知任何缓存者,别直接拿你缓存的副本,糊弄人.你需要去转发我的请求,并验证你的缓存(如果有的话).对应名词:端对端重载.   
响应: 允许缓存者缓存副本.那么其实际价值是,总是强制缓存者,校验缓存的新鲜度.一旦确认新鲜,则可以使用缓存副本作为响应. no-cache,还可以指定某个包含字段,比如一个典型应用,no-cache=Set-Cookie. 这样做的结果,就是告知缓存者,对于Set-Cookie字段,你不要使用缓存内容.而是使用新滴.其他内容则可以使用缓存.

.no-store:   
请求:告知,请求和响应都禁止被缓存.(也许是出于隐私考虑)   
响应:同上.

.max-age:   
请求:强制响应缓存者,根据该值,校验新鲜性.即与自身的Age值,与请求时间做比较.如果超出max-age值,则强制去服务器端验证.以确保返回一个新鲜的响应.其功能本质上与传统的Expires类似,但区别在于Expires是根据某个特定日期值做比较.一但缓存者自身的时间不准确.则结果可能就是错误的.而max-age,显然无此问题. Max-age的优先级也是高于Expires的.
响应:同上类似,只不过发出方不一样.

.max-stale:   
请求:意思是,我允许缓存者,发送一个,过期不超过指定秒数的,陈旧的缓存.   
响应:同上.

.must-revalidate(仅为响应标头)   
响应:意思是,如果缓存过了新鲜期,则必须重新验证.而不是试图返回一个不在新鲜期的缓存.与no-cache的区别在于,no-cache,完全无视新鲜期的概念.总是强制重新验证.理论上,must-revalidate更节省流量,但相比no-cache,可能并不总是那么精准.因为即使缓存者,认为是新鲜的,也不能保证服务器端没有做过更新.如果缓存者是一个缓存代理服务器,如果其试图重新验证时,无法连接上原始服务器,则也不允许返回一个不新鲜的,缓存中的副本.而是必须返回一个504 Gateway timeout.

.proxy-revalidate(仅为响应标头)   
响应:限制上与must-revalidate类似.区别在于受体的范围.proxy-revalidate,是要排除掉用户代理的缓存的.即,其规则并不应用于用户代理的本地缓存上.

.min-fresh(仅为请求标头)   
请求:告知缓存者,如果当前时间加上min-fresh的值,超了该缓存的过期时间.则要给我一个新的.其实个人觉得,其功能上有点和max-age类似.但是更大的是语义上的区别.

.only-if-cached:(仅为请求标头)   
请求:告知缓存者,我希望内容来自缓存,我并不关心被缓存响应,是否是新鲜的.

.s-maxage(仅为响应标头)   
响应:与max-age的唯一区别是,s-maxage仅仅应用于共享缓存.而不引用于用户代理的本地缓存,等针对单用户的缓存. 另外,s-maxage的优先级要高于max-age..cache-extension (cache-extension是一个泛化的代称.它指所有自定义,或者说扩展的,指令,客户端和服务器端都可以自定义扩展Cache-Control相关的指令.)    那么,实际上我们可以这样 Cache-Control:max-age=300, custom-directive = xxx, public. 这样我们就定义了一个被统称为cache-extension的扩展指令.该指令如果对应的客户端或服务器端,不认识,就会忽略掉.

.no-transform    
请求:告知代理,不要更改媒体类型,比如jpg,被你改成png.   
响应:同上.