php版微信支付api.mch.weixin.qq.com域名解析慢原因與解決方法
本文實(shí)例講述了php版微信支付api.mch.weixin.qq.com域名解析慢原因與解決方法。分享給大家供大家參考,具體如下:
微信支付api.mch.weixin.qq.com域名解析慢了,導(dǎo)致付款時(shí)非常的慢,那么要如何來(lái)解決微信支付慢的問(wèn)題呢,這里就來(lái)一起分析一下。
有朋友在阿里云主機(jī)實(shí)現(xiàn)微信支付邏輯時(shí),發(fā)現(xiàn)api.mch.weixin.qq.com的解析實(shí)在是太慢了。
因此出現(xiàn)了手動(dòng)修改/etc/hosts的情況,當(dāng)然了,哪天微信支付要是換個(gè)機(jī)房肯定要掛。
我們的機(jī)房也有相似的同題,專(zhuān)門(mén)記錄一下。
代碼里用curl來(lái)請(qǐng)求微信,經(jīng)常超時(shí),這時(shí)使用wget試驗(yàn):
[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...
域名解析很久不出來(lái)
測(cè)試確認(rèn)是ipv6問(wèn)題
給wget加上-4,強(qiáng)制使用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.
代碼分析
專(zhuān)門(mén)寫(xiě)個(gè)代碼來(lái)測(cè)試ipv6的解析,用到系統(tǒng)函數(shù)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
函數(shù)原型:
int getaddrinfo( const char hostname, const char service, const struct addrinfo *hints, struct addrinfo **result );
參數(shù)說(shuō)明:
hints:可以是一個(gè)空指針,也可以是一個(gè)指向某個(gè)addrinfo結(jié)構(gòu)體的指針,調(diào)用者在這個(gè)結(jié)構(gòu)中填入關(guān)于期望返回的信息類(lèi)型的暗示。舉例來(lái)說(shuō):如果指定的服務(wù)既支持TCP也支持UDP,那么調(diào)用者可以把hints結(jié)構(gòu)中的ai_socktype成員設(shè)置成SOCK_DGRAM使得返回的僅僅是適用于數(shù)據(jù)報(bào)套接口的信息。而是否ipv6則由ai_family決定。
result:本函數(shù)通過(guò)result指針參數(shù)返回一個(gè)指向addrinfo結(jié)構(gòu)體鏈表的指針。
返回值:0——成功,非0——出錯(cuò)
測(cè)試結(jié)果:
ai_family為ipv6時(shí),只會(huì)尋找ipv6的解析結(jié)果,一般域名也沒(méi)設(shè)置。ai_family為AF_UNSPEC時(shí),會(huì)先ipv6再ipv4的,而api.mch.weixin.qq.com這個(gè)域名的ipv6解析出奇的慢(qq.com卻不慢,原因見(jiàn)后)。
解決辦法:
如果是curl,c可以強(qiáng)制指定ipv4,使用curl_easy_setopt(curl, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
其他語(yǔ)言的也參考此法。
深層原因分析
nslookup -query=AAAA api.mch.weixin.qq.com -debug 是找不到解析的(指定的AAAA就是ipv6),然后會(huì)發(fā)現(xiàn)一個(gè)SOA聲明和他的上級(jí)weixin.qq.com有一個(gè)ipv6的CNAME,到了minorshort.weixin.qq.com,而這域名又是沒(méi)有ipv6的解析的。
目測(cè)ipv6找解析時(shí)是在這個(gè)SOA和CNAME的地方打圈了,微信的同學(xué)們是不是考慮讓大伙好過(guò)一點(diǎn),把這些個(gè)域名的ipv6設(shè)置去掉。
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
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP微信開(kāi)發(fā)技巧匯總》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php正則preg_replace_callback函數(shù)用法實(shí)例
這篇文章主要介紹了php正則preg_replace_callback函數(shù)用法,實(shí)例分析了preg_replace_callback函數(shù)進(jìn)行正則替換的相關(guān)技巧,需要的朋友可以參考下2015-06-06PHP數(shù)組常用函數(shù)實(shí)例小結(jié)
這篇文章主要介紹了PHP數(shù)組常用函數(shù),結(jié)合實(shí)例形式總結(jié)分析了php針對(duì)數(shù)組的統(tǒng)計(jì)、計(jì)算、去重、過(guò)濾等相關(guān)函數(shù)使用技巧,需要的朋友可以參考下2018-08-08PHP實(shí)現(xiàn)的創(chuàng)建帶logo圖標(biāo)二維碼生成類(lèi)詳解
這篇文章主要介紹了PHP實(shí)現(xiàn)的創(chuàng)建帶logo圖標(biāo)二維碼生成類(lèi),結(jié)合實(shí)例形式分析了可生成帶logo的二維碼工具類(lèi)PHPQRCode.class.php相關(guān)參數(shù)、功能與使用技巧,需要的朋友可以參考下2018-07-07php和html的區(qū)別點(diǎn)詳細(xì)總結(jié)
在本篇文章里小編給大家整理了關(guān)于php和html的區(qū)別點(diǎn),有需要的朋友們可以參考下。2019-09-09將PHP從5.3.28升級(jí)到5.3.29時(shí)Nginx出現(xiàn)502錯(cuò)誤
這篇文章主要介紹了將PHP從5.3.28升級(jí)到5.3.29時(shí)Nginx出現(xiàn)502錯(cuò)誤,需要的朋友可以參考下2015-05-05php設(shè)計(jì)模式 Composite (組合模式)
將對(duì)象組合成樹(shù)形結(jié)構(gòu)以表示"部分-整體"的層次結(jié)構(gòu),使得客戶(hù)對(duì)單個(gè)對(duì)象和復(fù)合對(duì)象的使用具有一致性2011-06-06