curl_exec和wget执行太慢,IPv6惹的祸
frameborder="0" hspace="0" marginheight="0" marginwidth="0" scrolling="no" tabindex="0" vspace="0" width="100%" id="I0_1444046955254" name="I0_1444046955254" src="https://apis.google.com/u/0/se/0/_/+1/fastbutton?usegapi=1&size=small&hl=zh-CN&origin=http%3A%2F%2Fwww.lovelucy.info&url=http%3A%2F%2Fwww.lovelucy.info%2Fcurl-exec-wget-slow-due-to-ipv6.html&gsrc=3p&ic=1&jsh=m%3B%2F_%2Fscs%2Fapps-static%2F_%2Fjs%2Fk%3Doz.gapi.zh_CN.lJp_o5_jaQM.O%2Fm%3D__features__%2Fam%3DAQ%2Frt%3Dj%2Fd%3D1%2Ft%3Dzcms%2Frs%3DAGLTcCPeaE03SZD63Me-NUymILvMPBYu3g#_methods=onPlusOne%2C_ready%2C_close%2C_open%2C_resizeMe%2C_renderstart%2Concircled%2Cdrefresh%2Cerefresh&id=I0_1444046955254&parent=http%3A%2F%2Fwww.lovelucy.info&pfname=&rpctoken=37782941" data-gapiattached="true" title="+1" style="margin: 0px; padding: 0px; position: static; top: 0px; width: 70px; border-style: none; left: 0px; visibility: visible; height: 15px;">
3,904 次围观今天在使用 php 的 curl 函数时,发现需要等待大概 5 秒才能得到结果,实在是太慢了。而同样一个 url 使用浏览器访问,则立刻可以获得页面。后来又发现,即使不用 php,使用 Linux 下的原生命令 wget 去获取网页,也很慢。这真是太奇怪了,看上去不是程序的原因,而是网络设置的问题了。
执行 wget 时可以明显看到,阻塞发生在 DNS 域名解析的部分。
我使用的是开发环境,域名解析到一个内部 IP 上。奇怪的是,我使用 ping www.myproject.com 却很快可以获得 IP 地址并返回 ICMP 报文。为什么 wget 的 DNS 解析会这么慢呢?
Google 到 StackOverflow 上面也有很多人提这个问题,有说是 reverse DNS 反向域名解析的问题,有说要在 host 文件中添加那个域名……都无法解决我的问题。百思不得其解之际,突然想到上周是 IPv6 日,我们运维发过一封邮件说公司网络已经全部 enable IPv6 了。会不会是这个原因呢?按照这个线索去查,果然,豁然开朗了。
瞬间就返回了结果。看来是运维没有帮我们为这个域名绑定一个 IPv6 的地址,整个网络升级后,默认会优先解析 IPv6,在那个 domain 没有 IPv6 的情况下,会等待 IPv6 解析失败 timeout 之后才按以前的正常流程去找 IPv4。
对于 PHP curl 来讲,只需要加上下面一句即可解决延迟问题:
现在很多服务器都开启了 IPv6 却没有路由,无法真正工作,反而导致一些不可预料的问题。深切地体会到 IPv6 路漫漫啊……