如何在Nginx与Apache设置静态资源缓存教程

admin3年前主机评测164

如何在Nginx与Apache设置静态资源缓存教程?

通常网站由动态和静态两种资源构成,其动态资源一般为PHP、ASP、ASP.net、JAVA等程序,而静态资源一般是图片、样式文件(CSS)、JS代码文件等。由于静态资源在一般情况下是很少变更的,所以在WEB服务器中可以通过设置客户端的缓存时间来达到节省网络带宽及提高效率的目的。一般来说,图片文件、CSS样式文件、JS代码文件推荐设置的缓存时间可以为一年,这也是PageSpeed Insights推荐的。

Nginx设置静态资源缓存的方法

Nginx虚拟主机配置文件中的Server块中添加以下代码:

location ~ .*/.(gif|jpg|jpeg|png|bmp|swf|WebP)$

{

expires 365d;

error_log /dev/null;

access_log off;

}

location ~ .*/.(js|css)?$

{

expires 365d;

error_log /dev/null;

access_log off;

}

注意,以上代码需插入在Server块中,也就是server{…….}的 } 之前。

expires 365d;的意思就是将该类型的文件缓存时间设置为365天,expires的具体语法如下:

expires 60s; #缓存60秒

expires 10m; #缓存10分钟

expires 12h; #缓存12小时

expires 30d; #缓存30天

设置完成后,重启Nginx即生效。

Apache设置静态资源缓存

Apache设置缓存之前,需先开启LoadModule expires_module modules/mod_expires.so模块,编辑Apache的”httpd.conf”,找到这么一行:

#LoadModule expires_module modules/mod_expires.so

将该行前面的”#”字号删除,保存,重新启动Apache生效。

然后在主机配置文件中加入以下代码(示例):

ExpiresActive On

ExpiresDefault A86

ExpiresByType image/x-icon A31536000

ExpiresByType application/x-javascript A31536000

ExpiresByType text/css “access plus 30 days”

ExpiresByType image/gif A31536000

ExpiresByType image/png A31536000

ExpiresByType image/jpeg A31536000

ExpiresByType text/plain A31536000

ExpiresByType application/x-shockwave-flash A31536000

ExpiresByType video/x-flv A31536000

ExpiresByType application/pdf A604800

ExpiresByType text/html A900

其中A31536000就是31536000 秒,相当于一年。或者也可以写成:”access plus 365 days”,如下示例:

ExpiresActive On

ExpiresDefault A86

ExpiresByType image/x-icon “access plus 365 days”

ExpiresByType application/x-javascript “access plus 365 days”

ExpiresByType text/css “access plus 365 days”

ExpiresByType image/gif “access plus 365 days”

ExpiresByType image/png “access plus 365 days”

ExpiresByType image/jpeg “access plus 365 days”

ExpiresByType text/plain “access plus 365 days”

ExpiresByType application/x-shockwave-flash “access plus 365 days”

ExpiresByType video/x-flv “access plus 365 days”

ExpiresByType application/pdf A604800

ExpiresByType text/html A900

保存,重新启动Apache生效。

验证缓存设置是否生效

在Chrome或Edge浏览器中,访问某.png文件Url(已设置缓存时间为一年),然后按F12查看该文件的Headers信息,可以看到如下图:

浏览器中查看Headers信息

可以看到cache-control中的最大缓存时间为:31536000秒(一年),这就代表设置成功了。

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

香港云互联:大动作推出免费网站空间,免费虚拟主机速来领取

香港云互联是一家专注做云主机近二十年的服务商,主要提供全能虚拟主机、高配虚机、云服务器等服务。现推出免费网站空间,有需要的朋友抓紧时间领取免费虚拟主机空间了。领取免费空间须知:进入香港云互联官网1、免...

Bluehost:超大带宽大流量美国/香港站群服务器,129/256个IP,仅799元/月起

bluehost怎么样?bluehost提供超大带宽大流量美国/香港站群服务器,129/256个IP,仅799元/月起!Bluehost中国提供专业的美国主机、美国云虚拟主机、香港虚拟主机、美国服务器...

ftp传输文件

FTP传输文件简介FTP全称为文件传输协议(File Transfer Protocol)是用于在计算机之间传输文件的标准协议。FTP通常用于网站搭建、文件备份、软件升级等方面它通过TCP/IP协议进...

监听器控制程序lsnrctl跟踪trace file的示例分析

监听器控制程序lsnrctl跟踪tracefile的示例分析在Oracle数据库中,监听器是一个非常重要的组件。本文将介绍如何使用lsnrctl来跟踪tracefile,并分析一个示例。首先,我们需要...

怎么租一个好的香港服务器

如何租用好的香港服务器在今天的互联网时代香港已成为全球一流的国际商业中心也是许多企业和公司选择在此建立在线业务的理想之地。寻找最佳的香港服务器是一项非常重要的任务它必须能够满足您的所有策略所需的性能、...

宝塔面板免费版和专业版

宝塔面板免费版宝塔面板是一款功能强大的服务器管理面板可帮助用户轻松管理云服务器和网站。在宝塔面板的帮助下用户可以快速搭建、部署和管理各种类型的网站包括WordPress、PHP、Java等。宝塔面板的...