wget延时5s问题

【问题描述】

项目中遇到一个问题,脚本中有大量的wget命令,DNS配置正常,通过nslookup解析域名速度也很快,但是脚本执行确超时。测试发现每次wget时都有5s的延时。

【原因分析】

1、nslookup默认只解析A地址(也就是ipv4记录),而wget或者curl同时解析A地址和AAAA地址。

2、centos6/7版本的DNS解析过程如下:

(图片来源于网络)

 

 

1 主机从一个随机的源端口,请求 DNS的A 记录,
2 主机从同一个源端口,请求 DNS的AAAA 记录,
3 主机接受dns服务器返回A记录,
4 主机接受 dns服务器返回AAAA记录,

3、上述3、4步的返回顺序不一定。服务器和DNS服务器之间有防火墙的情况下,上述第3步完成后,防火墙认为会话已完成后面的会话被丢弃,5s后dns客户端没有收到结果会重新发起会话。

4、从抓包的内容能清楚的看到nslookup和wget的区别:

nslookup抓包过程

 

 

 wget抓包过程

【解决方法】

 1、需要用到的域名本地解析

 2、在resolv.conf中加入options single-request-reopen配置

 

posted @ 2019-09-16 15:03  ck_koma  阅读(627)  评论(0编辑  收藏  举报