微信支付api.mch.weixin.qq.com域名解析慢原因是什么问题
发布:smiling 来源: PHP粉丝网 添加日期:2018-10-31 22:54:21 浏览: 评论:0
有朋友在阿里云主机实现微信支付逻辑时,发现api.mch.weixin.qq.com的解析实在是太慢了。
因此出现了手动修改/etc/hosts的情况,当然了,哪天微信支付要是换个机房肯定要挂。
我们的机房也有相似的同题,专门记录一下。
代码里用curl来请求微信,经常超时,这时使用wget试验:
[root@01 tmp]# wget api.mch.weixin.qq.com
--2016-06-18 14:51:03-- http://api.mch.weixin.qq.com/
Resolving api.mch.weixin.qq.com... 域名解析很久不出来
测试确认是ipv6问题
给wget加上-4,强制使用ipv4,如果很快,那基本上确定是ipv6惹的祸了。
- [root@01 tmp]# wget -4 api.mch.weixin.qq.com
- --2016-06-18 17:03:52-- http://api.mch.weixin.qq.com/
- Resolving api.mch.weixin.qq.com... 123.151.71.149, 123.151.79.109
- Connecting to api.mch.weixin.qq.com|123.151.71.149|:80... connected.
代码分析:
专门写个代码来测试ipv6的解析,用到系统函数getaddrinfo:
- #include <stdio.h>
- #include <string.h>
- #include <netdb.h>
- #include <iostream>
- #include <sys/types.h>
- #include <sys/types.h>
- #include <sys/socket.h>
- #include <arpa/inet.h>
- using namespace std;
- int main() {
- struct addrinfo hints,*answer,*curr,*p;
- int error;
- memset(&hints, 0, sizeof hints);
- hints.ai_family = AF_INET6;//AF_UNSPEC; // use AF_INET6 to force IPv6
- hints.ai_socktype = SOCK_STREAM;//SOCK_DGRAM; // SOCK_STREAM
- if ((error = getaddrinfo("api.mch.weixin.qq.com", NULL, &hints, &answer)) != 0) {
- fprintf(stderr, "getaddrinfo: %s\n", gai_strerror(error));
- return 1;
- } else cout <<"Success with a URL\n";
- char ipstr[16];
- for (curr = answer; curr != NULL; curr = curr->ai_next) {
- inet_ntop(AF_INET,&(((struct sockaddr_in *)(curr->ai_addr))->sin_addr),ipstr, 16);
- printf("%s\n", ipstr);
- }
- freeaddrinfo(answer);
- return 0;
- }
包含头文件
netdb.h
函数原型
int getaddrinfo( const char hostname, const char service, const struct addrinfo *hints, struct addrinfo **result );
参数说明
hints:可以是一个空指针,也可以是一个指向某个addrinfo结构体的指针,调用者在这个结构中填入关于期望返回的信息类型的暗示。举例来说:如果指定的服务既支持TCP也支持UDP,那么调用者可以把hints结构中的ai_socktype成员设置成SOCK_DGRAM使得返回的仅仅是适用于数据报套接口的信息。而是否ipv6则由ai_family决定。
result:本函数通过result指针参数返回一个指向addrinfo结构体链表的指针。
返回值:0——成功,非0——出错
测试结果
ai_family为ipv6时,只会寻找ipv6的解析结果,一般域名也没设置。ai_family为AF_UNSPEC时,会先ipv6再ipv4的,而api.mch.weixin.qq.com这个域名的ipv6解析出奇的慢(qq.com却不慢,原因见后)。
解决办法
如果是curl,c可以强制指定ipv4,使用curl_easy_setopt(curl, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
其他语言的也参考此法。
测试代码下载
深层原因分析
nslookup -query=AAAA api.mch.weixin.qq.com -debug 是找不到解析的(指定的AAAA就是ipv6),然后会发现一个SOA声明和他的上级weixin.qq.com有一个ipv6的CNAME,到了minorshort.weixin.qq.com,而这域名又是没有ipv6的解析的。
目测ipv6找解析时是在这个SOA和CNAME的地方打圈了,微信的同学们是不是考虑让大伙好过一点,把这些个域名的ipv6设置去掉。
dig @ns-tel1.qq.com weixin.qq.com AAAA
weixin.qq.com. 43200 IN SOA ns-tel1.qq.com. webmaster.qq.com. 1293502040 300 600 86400 300
Tags: api mch 域名解析慢
相关文章
- ·淘宝API返回的json数据无法用json_decode的问题(2013-12-05)
- ·PHP实现百度、网易、新浪短网址服务的API接口调用(2014-06-27)
- ·利用google api生成二维码名片例子(2014-06-28)
- ·淘宝IP地址库API接口(PHP)通过ip获取地址信息(2014-07-02)
- ·php实现新浪短链接调用API代码(2014-08-26)
- ·分享淘宝API辅助函数-适用CI框架(2014-08-27)
- ·php google api 接口程序(2014-09-10)
- ·php有道翻译api调用方法(2014-09-22)
- ·php利用百度api计算两地距离的代码(2015-04-15)
- ·PHP版微信红包API接口程序(2015-05-09)
- ·微信自动获取收货地址api程序(2016-08-18)
- ·docker提供api访问的方法介绍(2020-02-08)
- ·php调用淘宝开放API实现根据卖家昵称获取卖家店铺ID的方法(2021-06-14)
- ·php通过淘宝API查询IP地址归属等信息(2021-07-01)
- ·PHP中Restful api 错误提示返回值实现思路(2021-07-28)
- ·PHP使Laravel为JSON REST API返回自定义错误的问题(2021-10-31)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)