免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 9262 | 回复: 12
打印 上一主题 下一主题

[函数] 【求助】神奇的getaddrinfo [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-12 14:39 |只看该作者 |倒序浏览
GCC版本: gcc version 4.4.1
Linux版本:Linux (none) 3.0.8 #3 Wed Apr 10 15:47:48 CST 2013 armv5tejl GNU/Linux

公司的一个网络库里面需要解析域名,于是直接想到了getaddrinfo, 但是发现存在一个非常奇怪的偶现问题:

DNS配置如下:
# cat /etc/resolv.conf
nameserver 202.96.134.134
nameserver 8.8.8.8

如果getaddrinfo正常工作,其基本流程应该是,首先向202.96.134.134发送DNS请求,如果超时无应答,则向8.8.8.8发送DNS请求。

现在发送公司的程序在偶然会出现如下情况:
1. getaddrinfo 既没有向 202.96.134.134 发送DNS报文,也没有向8.8.8.8发送DNS报文,而是直接快速返回失败,错误码“EAI_NONAME   -2    NAME or SERVICE is unknown ”,造成DNS解析失败。

2. 或者getaddrinfo没有向 202.96.134.134 ,而是直接向8.8.8.8发送DNS(就像是检测出202不可用一样,但是抓包没有任何去往该处的报文)。

更奇怪的是,在相同平台上,使用测试程序,即最简单的调用getaddrinfo的程序,竟然没有问题,即两个不同程序都是调用getaddrinfo,表现出的现象不一样。

有没有朋友对这个有经验?

论坛徽章:
0
2 [报告]
发表于 2013-09-12 14:40 |只看该作者
自己顶!!

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
3 [报告]
发表于 2013-09-12 14:43 |只看该作者
没用过, 帮顶~~

论坛徽章:
0
4 [报告]
发表于 2013-09-12 14:44 |只看该作者
folklore 发表于 2013-09-12 14:43
没用过, 帮顶~~

谢谢:wink:

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
5 [报告]
发表于 2013-09-12 14:49 |只看该作者
说明是程序bug, 还怀疑什么.

论坛徽章:
0
6 [报告]
发表于 2013-09-12 14:54 |只看该作者
回复 5# linux_c_py_php
一个原子操作的接口,如果认为是程序BUG,最有可能就是入参有问题,但是我们都有打印,如果出现问题的时候打印的入参是没有问题的;
另外如果是程序BUG,如现象2,还是无法解释的。


   

论坛徽章:
0
7 [报告]
发表于 2013-09-12 14:55 |只看该作者
大神在哪里

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
8 [报告]
发表于 2013-09-12 15:09 |只看该作者
回复 1# yangpinglaji001


    应该和本地的DNS缓冲有关系,你用的什么DNS缓冲DNSMASQ还是nscd。如果关掉缓存或者清空缓存的话应该会有相同的结果。

论坛徽章:
0
9 [报告]
发表于 2013-09-12 15:11 |只看该作者
回复 8# myworkstation
怎么关闭?缓冲的操作是针对不同程序的吗?

   

论坛徽章:
0
10 [报告]
发表于 2013-09-12 15:14 |只看该作者
回复 8# myworkstation
如果是DNS缓存,测试程序应该也会受影响吧?
另外检查了下,系统没有DNS缓存,(嵌入式系统,海思提供的编译链)

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP