修改Hosts不生效的一个场景-web(转)

Update:

  • 如果浏览器使用了代理工具,修改 Hosts 也不会生效。这里是因为,浏览器会优先考虑代理工具(如添加 pac 文件、SwitchySharp等)的代理,建议调试的时候先关闭这些代理。
  • 使用 pac 文件代理有的时候部分文件的代理不生效,应该是 pac 对应的代理服务器上,做了部分处理。
  • 部分浏览器也有 DNS 缓存,如 chrome(chrome://dns),这是为什么重启浏览器也不生效的原因,一般设定时间为 60s (如 Firefox)。
  • 浏览器有DNS缓存,系统也会存在 DNS 缓存,有的时候即便在 chrome://dns 清空了浏览器 DNS 缓存,依然不生效,是因为系统 DNS 缓存还未刷新,刷新方式可以看这篇文章


相信很多同学都在使用 SwitchHosts/iHosts/Gas Mask 等 Hosts 管理工具,当然也有人直接修改 /etc/hosts 或者 system32/drivers/etc/hosts 文件,而经常遇到的疑问是:咿,刚才不是修改并且保存了么,为何 Chrome 浏览器还不生效呢?

  • 有人说重启下浏览器就好了,
  • 有人说清空下缓存 DNS(chrome://net-internals/#DNS)就好了,
  • 有人说隐私模式下打开就好了,
  • 有人说等一分钟吧...

结果就是,进入隐私模式的都好了,重启、清空缓存DNS和等一分钟的同学还在继续纠结中。。。

上面提到的三个工具,SwitchHosts/iHosts/Gas Mask,其实也只有 iHosts 生效了(Mac下)。

开发过程中我们会无数次的切换 Hosts,如果不知道原理,我们在测试的时候还是很心惊胆战的=_=||

修改Hosts不生效的根本原因

因为服务器设置了 keep-alive !次要原因是存在浏览器 DNS 缓存和系统 DNS 缓存。

> Keep-alive 相关文档

服务器在响应头设置了 Connection: keep-alive (一般的网页都会设置 keep-alive,保持长连接,避免多次连接产生网络消耗)之后,客户端会跟服务器保持长连接,只要长连接不断开,页面在请求的时候就不会重新解析域名!

我们可以这样来测试:

  1. 打开一个你至少两分钟没有打开的浏览器(你也可以关闭掉你的浏览器,然后重新打开,记得把所有的 tab 都关了,除了当前 tab ^_^)
  2. 在 hosts 添加 127.0.0.1 www.taobao.com
  3. 新开 tab,打开 www.taobao.com,是不是进不去了 <这里说明 hosts 修改生效了>
  4. 注释掉刚才hosts修改,# 127.0.0.1 www.taobao.com ,再打开 www.taobao.com,很好,正常打开了 <这里说明 hosts 修改也生效了>
  5. 去掉注释符,127.0.0.1 www.taobao.com ,再打开 www.taobao.com,依然可以访问!!!
  6. Chrome 中进入 chrome://net-internals/#sockets,,可以看到淘宝首页中很多域名都是与服务器保持着长连接,点击上方的 close idle sockets 按钮,可以关闭所有的长连接
  7. 此时,再去访问 www.taobao.com,是不是进不去了!

为何一些修改可以让 “Hosts 生效”

1. 重启浏览器

重启浏览器之后,所有的连接(包括长连接)都会断开,自然就生效了

2. 隐私模式打开

因为隐私模式下不会复用 TCP 连接,新开连接的时候,会重新解析 DNS 域名,自然也生效了

3. iHosts 管理器在 Mac 下生效

因为我在 Windows 下测试过,貌似没有立即生效。问了 iHosts 的作者@必隆,他告诉我,在修改 hosts 文件的时候,会重启网络服务,这个时候必然会断开所有的 TCP 连接(重启网络服务,差不多相当于先断网再联网...)

4. 修改之后,等一会儿...

“等一会儿”,要稍微等久一点,keep-alive 的默认设置是 120s,开发者也有可能增大或者减小这个配置,所以“等一会儿”也是很伤神的=。 =

看到这里,你对其中的原理是否有所了解了呢?

http://www.cnblogs.com/hustskyking/p/hosts-modify.html

 

时间: 2024-10-31 16:17:51

修改Hosts不生效的一个场景-web(转)的相关文章

修改hosts不生效怎么办?

  好多朋友修改好了hosts,保存之后发现没有生效,这是为什么哪?其实这里有一个DNS cache的概念,一般朋友们比较容易忽视.那么,小编讲一下,修改hosts之后,如何立即生效. 方法一:清空DNS缓存 1.打开命令提示符,输入ipconfig /flushdns 2.命令执行完毕,发现刚才修改的hosts已经生效了. 方法二:修改注册表 1.打开注册表编辑器,定位到HKeyCurrentUserSOFTWAREMicrosoftWindowsCurrentVersionInternet

maven 多 web 工程 怎么自动合并到 一个 主web 工程 且修改文件 自动更新修改

问题描述 maven 多 web 工程 怎么自动合并到 一个 主web 工程 且修改文件 自动更新修改 如题所属: maven 多 web 工程 怎么自动合并到 一个 主web 工程 且修改文件 自动更新修改,等于在一个web project 部署多个web 开发

修改hosts的host mapping不生效解决

在windows xp环境下,修改hosts,添加我的新host mapping,如下: 192.168.128.33 master 保存并退出后 执行ping 192.168.128.33 ,可以ping通 但执行ping master,死活都不通 最后请高人指点,找到方法解决,mark下. 1. 打开本地连接->Internet protocol version 4(TCP/IPv4)->Advanced->Wins tab 2. 选中Enable LMHOSTS lookup前面的

《深入理解Nginx:模块开发与架构解析》一2.4 用HTTP核心模块配置一个静态Web服务器

2.4 用HTTP核心模块配置一个静态Web服务器 静态Web服务器的主要功能由ngx_http_core_module模块(HTTP框架的主要成员)实现,当然,一个完整的静态Web服务器还有许多功能是由其他的HTTP模块实现的.本节主要讨论如何配置一个包含基本功能的静态Web服务器,文中会完整地说明ngx_http_core_module模块提供的配置项及变量的用法,但不会过多说明其他HTTP模块的配置项.在阅读完本节内容后,读者应当可以通过简单的查询相关模块(如ngx_http_gzip_f

域名-修改hosts文件时遇到的问题

问题描述 修改hosts文件时遇到的问题 修改hosts文件时,若域名是单个,比如web,就可以, 若是web.hah.hah 就不能访问了.不知道什么情况,求大神啊. 我是在tomcat中部署项目测试的.地址为: http://web1:8080/WebDemo/index.jsp plus:我确定不是网上大多数说的缓存问题.因为我试过,web1改为web2立马就可以,但加点后就不可以. 跪求大神解答. 解决方案 楼主应该把你的整个配置文件贴出来啊,大家才好帮你定位问题啊 解决方案二: 在你的

如何用PHP来实现一个动态Web服务器_php实例

要是现实一个 web 服务器,那么就需要大概了解 web 服务器的运行原理.先从静态的文本服务器开始,以访问 web 服务器的1.html为例 1.客户端通过发送一个 http 请求到服务器,如果服务器监听的端口号是9002,那么在本机自身测试访问的地址就是http://localhost:9002/1.html. 2.服务器监听着9002端口,那么在收到请求了请求之后,就能从 http head 头中获取到请求里需要访问的 uri 资源在web 目录中的位置. 3.服务器读取需要访问的资源文件

Win7系统修改hosts时提示没有权限的方法

解决Windows 7系统修改hosts时提示没有权限的方法,一个有三个步骤: 1.进入hosts文件的目录,C:WINDOWSsystem32driversetc,将hosts文件copy一份出来,放在除该目录下的任意地方(例如桌面等) 2.修改你copy出来的hosts文件,修改后保存即可.此时不会出现权限的问题. 3.将上一步修改的hosts文件复制到C:WINDOWSsystem32driversetc目录下,替换原来的hosts文件即可.

学习Flash制作《黑色故事》里的一个场景

前言 我们看到鸟儿在天上飞,花草随风飘动,水里鱼儿畅游,老者蹒跚踱步,孩子们嬉戏玩耍,,,,,所有这一切,我们的眼睛都准确无误地把它们捕捉,经过大脑的计算分析,之后我们发现这些物体都按照自己的规律运动着,它们的运动是那么的不同,只因为它们都有着自己的特性.如果眼睛看到这些物体不按自己的规律运动j就会向我们报告:"发现异常情况"--现实中你不可能看到鱼儿在天上飞----这是神话,老人们穿房越脊上窜下蹦-----那是武侠,让肥猪象猴子一样奔跑-----那猪必须疯狂减肥,一头驴突然对我说&q

win7快速修改hosts和service文件

  win7的用户权限管理比较严格,默认情况下你是无法直接修改hosts和service这样的文件,提示无权限.网上有很多教程,讲解如何获取管理员或文件权限,如果你只是想修改类似这样的文件,不用动那么大的干戈,一个小小的动作就行. [操作方法]:复制hosts.service文件系统文件夹之外的其他地方,任意编辑器修改->保存,再paste回去覆盖掉系统同名文件,done.