一般属于用户的 ISP 提供商或者本地局域网控制,但是它同样会在用户使用的计算机上产
生缓存。DNS 信息会保留在操作系统的 DNS 缓存中(微软 Windows 系统中 DNS Client
Service)。大多数浏览器有独立于操作系统以外的自己的缓存。由于浏览器有自己的缓存
记录,因此在一次请求中它不会受到操作系统的影响。
Internet Explorer 默认情况下对 DNS 查找记录的缓存时间为 30 分钟,它在注册表中的键
值为 DnsCacheTimeout。Firefox 对 DNS 的查找记录缓存时间为 1 分钟,它在配置文件中的
选项为 network.dnsCacheExpiration(Fasterfox 把这个选项改为了 1 小时)。
当客户端中的 DNS 缓存都为空时(浏览器和操作系统都为空),DNS 查找的次数和页
面中主机名的数量相同。这其中包括页面中 URL、图片、脚本文件、样式表、Flash 对象
等包含的主机名。减少主机名的数量可以减少 DNS 查找次数。
减少主机名的数量还可以减少页面中并行下载的数量。减少 DNS 查找次数可以节省响
应时间,但是减少并行下载却会增加响应时间。我的指导原则是把这些页面中的内容分割
成至少两部分但不超过四部分。这种结果就是在减少 DNS 查找次数和保持较高程度并行下
载两者之间的权衡了。
3、避免跳转
跳转是使用 301 和 302 代码实现的。下面是一个响应代码为 301 的 HTTP 头:
HTTP/1.1 301 Moved Permanently
Location: http://example.com/newuri
Content-Type: text/html
浏览器会把用户指向到 Location 中指定的 URL。头文件中的所有信息在一次跳转中都
是必需的,内容部分可以为空。不管他们的名称,301 和 302 响应都不会被缓存除非增加
一个额外的头选项,如 Expires 或者 Cache-Control 来指定它缓存。<meat />元素的刷新标签
和 JavaScript 也可以实现 URL 的跳转,但是如果你必须要跳转的时候,最好的方法就是使
用标准的 3XXHTTP 状态代码,这主要是为了确保“后退”按钮可以正确地使用。
但是要记住跳转会降低用户体验。在用户和 HTML 文档中间增加一个跳转,会拖延页
面中所有元素的显示,因为在 HTML 文件被加载前任何文件(图像、Flash 等)都不会被
下载。
有一种经常被网页开发者忽略却往往十分浪费响应时间的跳转现象。这种现象发生在当
URL 本该有斜杠 (/)却 被忽略 掉时。 例如,当 我们要 访问 http://astrology.yahoo.com/
astrology 时 , 实 际 上 返 回 的 是 一 个 包 含 301 代 码 的 跳 转 , 它 指 向 的
是 http://astrology.yahoo.com/astrology/ (注意末尾的斜杠)。在 Apache 服务器中可以使用
Alias 或者 mod_rewrite 或者 the DirectorySlash 来避免。
连接新网站和旧网站是跳转功能经常被用到的另一种情况。这种情况下往往要连接网站
的不同内容然后根据用户的不同类型(如浏览器类型、用户账号所属类型)来进行跳转。
使用跳转来实现两个网站的切换十分简单,需要的代码量也不多。尽管使用这种方法对于
开发者来说可以降低复杂程度,但是它同样降低用户体验。一个可替代方法就是如果两者
在同一台服务器上时使用 Alias 和 mod_rewrite 和实现。如果是因为域名的不同而采用跳转,
评论0
最新资源