解決CentOS php執行curl DNS解析慢

本人出現問題的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解析的第二個答案的第一次查找超時。如果存在衝突,此選項會使您的計算機重新打開新套接字。


本人環境和說明:

  1. 查看本機適用的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
  1. 本機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
  2. 手動用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
  1. 經過G字母的搜索引擎查找資料,其他人的解決方法:
在/etc/resolv.conf的可選參數后里加上:single-request-reopen
第一行內容既改爲:
options timeout:1 attempts:1 rotate single-request-reopen

本文參考出處:

  1. https://aarvik.dk/disable-ipv6/
  2. https://help.aliyun.com/knowledge_detail/59344.html
  3. http://blog.sina.com.cn/s/blog_7f2122c50101uk9m.html
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章