ETag.jpg
ETag.jpg

ETag全称EntityTags,HTTP协议规格说明中定义“ETag”为“被请求变量的实体值”。我们也可以把ETag理解为是一个客户端与服务器关联的记号。这个记号告诉客户端,当前网页在上次请求之后是否有发生变化,当发生变化时,ETag的值重新计算,并返回200状态码。如果没有变化,返回304状态码。从而不会重新加载整个页面信息。

下面将介绍如何在Apache/Nginx/IIS服务器上启用ETag。

Apache

Apache根据配置文件中的配置来设置 Etag 值,默认的 Apache 的 FileEtag 设置为:

FileEtagINode Mtime Size

也就是根据这三个属性来生成 Etag 值,他们之间通过一些算法来实现,并输出成 hex 的格式,相邻属性之间用-分隔,比如:"2e681a-6-5d044840",这里面的三个段,分别代表了INode,MTime,Size根据算法算出的值的 Hex 格式,可以改变 Apache 的 FileEtag 设置,比如设置成 FileEtagSize,那么得到的 Etag 可能为:"6",设置了几个段,Etag 值就有几个段。

详细配置

步骤1

在要启用ETag的目录下增加.htaccess文件并在其中增加一行:

FileETag MTime Size

如图:

085801442457344.png
085801442457344.png

以覆盖默认的 Innode MTime Size 的 ETag,因为默认的 ETag 使用到的 Innode 会导致相同的文件在分布式服务器上产生的 ETag 不同。

步骤2

如果.htacces文件已经存在,请确保要启用ETag的目录/.htacces文件中没有FileETagNone。如果存在FileETag None,请删去该行。

检查没有用mod_headers将 ETag 除去,即 httpd.conf 文件中没有出现下面的语句,

LoadModule headers_module modules/mod_headers.so 
Header unset ETag

099591442457343.png
099591442457343.png

如果出现如图情况,请删除 Headerunset ETag 这一行。

步骤3

重新启动httpd,就启用ETag了。

Nginx

步骤1

确认Nginx版本,命令:

Nginx安装目录/sbin/nginx–v

089551442457343.png
089551442457343.png

版本为1.7.3及更高,继续步骤2;版本为1.7.3以下,1.3.3及以上,进行步骤3;版本为1.3.3以下,不支持ETag,请升级您的Nginx。

步骤2

确认没有关闭ETag:打开Nginx的配置文件nginx.conf(默认位置Nginx安装目录/conf/),确保其中没有出现etagoff;,下图为出现的情况,请将此行删除。

099881442457340.png
099881442457340.png

确认没有使用ngx_headers_more清除ETag头:同样在配置文件中不能出现如下语句的任意一句,如果出现请将其删除。

091721442457344.png
091721442457344.png

重新启动Nginx,就启用ETag功能了。

步骤3

查看是否开启了gzip,且是否和etag出现冲突,出现冲突去步骤4,没有去步骤2。

打开Nginx的配置文件nginx.conf(默认位置Nginx安装目录/conf/),其中出现gzip on;语句证明开启了gzip,如图

061911442457341.png
061911442457341.png

开启gzip时,可能与etag出现冲突,用浏览器多次请求此网站的静态元素,如果只返回200,不返回304,证明存在冲突,请去步骤4;没有冲突去步骤2

步骤4

请关闭gzip,即将上一步中的gzip on;改为gzip off然后去步骤2

若不想关闭gzip,并要开启ETag,同时仍要坚持使用当前的Nginx版本,只能修改源码并重新编译。
下载此版本安装包并解压,将其目录下的 src/http/modules/ngx_http_gzip_filter_module.c
文件打开并删除或注释 ngx_http_clear_etag(r); 这行代码。

如下图:

017681442457343.png
017681442457343.png

如果没有找到ngx_http_clear_etag(r);而是发现ngx_http_weak_etag(r);如下图,证明此 Nginx 没有gzip和etag冲突的问题,不必进行任何修改。

092721442457344.png
092721442457344.png

重新编译源码安装Nginx,解决这个冲突,然后去步骤2。

IIS

IIS7是默认开启ETag的,如果没有ETag,请按以下步骤设置。

打开Internet Information Services (IIS) Manager,如图双击HTTP响应头部(HTTPResponse Headers)

031411442457341.png
031411442457341.png

选择No Grouping标签,在空白处右键选择Add。

032701442457343.png
032701442457343.png

设置Name为ETag,Value为双引号

088241442457341.png
088241442457341.png

配置web.config:­

<system.webServer>
略
  ...
       <httpProtocol>
           <customHeaders>
                <add name="ETag"value="&quot;&quot;" />
           </customHeaders>
       </httpProtocol>
  ...
略
</system.webServer>

完成。

017071442457342.png
017071442457342.png