本人出現問題的php報錯信息:
GuzzleHttp\Exception\ConnectException: cURL error 6: Could not resolve host: api.mch.weixin.qq.com; Name or service not known
Guzzle是一個PHP的HTTP客戶端,用來輕而易舉地發送請求
系統版本:阿里雲ECS CentOS7
PHP版本:5.5
先放結論:
如果您的Linux機器通過cURL,wget或類似的URL傳輸工具緩慢解析DNS,可能是因爲ipv4 / ipv6解析衝突。
CentOS 6 和 CentOS 7 的 DNS 解析機制中,發送 IPV4 DNS 和 IPV6 DNS 請求使用了相同的網絡五元組,此時應開啓 single-request-reopen 配置,一旦出現同一 socket 發送的兩次請求處理,解析端發送第一次請求後會關閉 socket,並在發送第二次請求前打開新的 socket。配置成功後不需要重啓實例即可生效。
ipv4(A)和ipv6(AAAA)使用相同的套接字和端口來解析DNS,然後它只能發回一個響應,然後cURL或wget,或者你使用的任何東西,都會等待(可能)來自DNS解析的第二個答案的第一次查找超時。如果存在衝突,此選項會使您的計算機重新打開新套接字。
本人環境和說明:
- 查看本機適用的DNS服務器:
# cat /etc/resolv.conf
options timeout:1 attempts:1 rotate
nameserver 100.100.2.136
nameserver 100.100.2.138
以上是購買ECS服務器後的默認值,第一行是可選參數
第二行應該是阿里雲的內部DNS Server IP
-
本機CURL版本(因爲PHP代用的是系統的curl庫)
# rpm -qa|grep curl curl-7.29.0-51.el7.x86_64 libcurl-7.29.0-51.el7.x86_64 libcurl-devel-7.29.0-51.el7.x86_64
- 手動用dig和host命令查詢解析都是正常的
# dig @100.100.2.136 api.mch.weixin.qq.com
; <<>> DiG 9.9.4-RedHat-9.9.4-50.el7_3.1 <<>> @100.100.2.136 api.mch.weixin.qq.com
; (1 server found)
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 48831
;; flags: qr rd ra; QUERY: 1, ANSWER: 3, AUTHORITY: 0, ADDITIONAL: 0
;; QUESTION SECTION:
;api.mch.weixin.qq.com. IN A
;; ANSWER SECTION:
api.mch.weixin.qq.com. 37 IN CNAME forward.weixin.qq.com.
forward.weixin.qq.com. 41 IN A 140.207.69.102
forward.weixin.qq.com. 41 IN A 140.207.69.101
用100.100.2.138查也是同2個IP
- 經過G字母的搜索引擎查找資料,其他人的解決方法:
在/etc/resolv.conf的可選參數后里加上:single-request-reopen
第一行內容既改爲:
options timeout:1 attempts:1 rotate single-request-reopen