《PHP教程:php版微信支付api.mch.weixin.qq.com域名解析慢原因與解決方法》要點:
本文介紹了PHP教程:php版微信支付api.mch.weixin.qq.com域名解析慢原因與解決方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
本文實例講述了php版微信支付api.mch.weixin.qq.com域名解析慢原因與解決方法.分享給大家供大家參考,具體如下:PHP應(yīng)用
微信支付api.mch.weixin.qq.com域名解析慢了,導致付款時非常的慢,那么要如何來解決微信支付慢的問題呢,這里就來一起分析一下.PHP應(yīng)用
有朋友在阿里云主機實現(xiàn)微信支付邏輯時,發(fā)現(xiàn)api.mch.weixin.qq.com的解析實在是太慢了.PHP應(yīng)用
因此出現(xiàn)了手動修改/etc/hosts的情況,當然了,哪天微信支付要是換個機房肯定要掛.PHP應(yīng)用
我們的機房也有相似的同題,專門記錄一下.PHP應(yīng)用
代碼里用curl來請求微信,經(jīng)常超時,這時使用wget試驗:PHP應(yīng)用
[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...
域名解析很久不出來PHP應(yīng)用
測試確認是ipv6問題PHP應(yīng)用
給wget加上-4,強制使用ipv4,如果很快,那基本上確定是ipv6惹的禍了.PHP應(yīng)用
[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.
代碼分析PHP應(yīng)用
專門寫個代碼來測試ipv6的解析,用到系統(tǒng)函數(shù)getaddrinfo:PHP應(yīng)用
#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; }
包含頭文件PHP應(yīng)用
netdb.hPHP應(yīng)用
函數(shù)原型:PHP應(yīng)用
int getaddrinfo( const char hostname, const char service, const struct addrinfo *hints, struct addrinfo **result );PHP應(yīng)用
參數(shù)說明:PHP應(yīng)用
hints:可以是一個空指針,也可以是一個指向某個addrinfo結(jié)構(gòu)體的指針,調(diào)用者在這個結(jié)構(gòu)中填入關(guān)于期望返回的信息類型的暗示.舉例來說:如果指定的服務(wù)既支持TCP也支持UDP,那么調(diào)用者可以把hints結(jié)構(gòu)中的ai_socktype成員設(shè)置成SOCK_DGRAM使得返回的僅僅是適用于數(shù)據(jù)報套接口的信息.而是否ipv6則由ai_family決定.
result:本函數(shù)通過result指針參數(shù)返回一個指向addrinfo結(jié)構(gòu)體鏈表的指針.PHP應(yīng)用
返回值:0――成功,非0――出錯PHP應(yīng)用
測試結(jié)果:PHP應(yīng)用
ai_family為ipv6時,只會尋找ipv6的解析結(jié)果,一般域名也沒設(shè)置.ai_family為AF_UNSPEC時,會先ipv6再ipv4的,而api.mch.weixin.qq.com這個域名的ipv6解析出奇的慢(qq.com卻不慢,原因見后).PHP應(yīng)用
解決辦法:PHP應(yīng)用
如果是curl,c可以強制指定ipv4,使用curl_easy_setopt(curl, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);PHP應(yīng)用
其他語言的也參考此法.PHP應(yīng)用
深層原因分析PHP應(yīng)用
nslookup -query=AAAA api.mch.weixin.qq.com -debug 是找不到解析的(指定的AAAA就是ipv6),然后會發(fā)現(xiàn)一個SOA聲明和他的上級weixin.qq.com有一個ipv6的CNAME,到了minorshort.weixin.qq.com,而這域名又是沒有ipv6的解析的.PHP應(yīng)用
目測ipv6找解析時是在這個SOA和CNAME的地方打圈了,微信的同學們是不是考慮讓大伙好過一點,把這些個域名的ipv6設(shè)置去掉.PHP應(yīng)用
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)容感興趣的讀者可查看本站專題:《PHP微信開發(fā)技巧匯總》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》PHP應(yīng)用
希望本文所述對大家PHP程序設(shè)計有所幫助.PHP應(yīng)用
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/3079.html