用戶
 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

掃一掃,登錄網站

小程序社區 首頁 教程 實戰教程 查看內容

:小程序server請求微信服務器超時

巴黎彩票计划 www.hknsi.icu Rolan 2019-5-21 00:13

今天有同學在測試小程序的過程中,發現一個問題,調用 微信官方的服務端接口超時 ,比如這個接口,https://api.weixin.qq.com/sns/jscode2session ,因為我們小程序登錄的時候,會在自己server端調用微信的API,這個 ...

今天有同學在測試巴黎彩票计划的過程中,發現一個問題,調用 微信官方的服務端接口超時 ,比如這個接口,https://api.weixin.qq.com/sns/jscode2session ,因為我們小程序登錄的時候,會在自己server端調用微信的API,這個接口超時,導致我們的登錄流程也就掛掉了。本來以為是偶爾的網絡問題,但是,同學發現在測試服務器上,很穩定的復現超時!但是在我們本地測試過程中,請求微信服務器又很快響應。嗯,理論上微信服務器不會出問題的……

試著在服務器上去 curl 微信的接口,確實挺慢的,我們代碼里配置了超時是3秒,目測確實超過了3秒才返回!抱著僥幸的想法,讓同學把超時改成5秒,依然超時……嗯,略微有點尷尬。

試著 ping api.weixin.qq.com ,發現收到第一個包,隔著挺長時間,后面的包平均幾十毫秒,網絡應該也沒問題吧。

沒辦法了,因為是服務端,只能用 curl,想看看這個工具能不能提供一下,整個請求的各個階段,時間是怎么分布的。搜了一下,還真有這個功能,具體操作如下:

  1. 在某個目錄下,新建一個文件,比如 curl-format.txt ,內容如下:
 time_namelookup:  %{time_namelookup}\n
       time_connect:  %{time_connect}\n
    time_appconnect:  %{time_appconnect}\n
   time_pretransfer:  %{time_pretransfer}\n
      time_redirect:  %{time_redirect}\n
 time_starttransfer:  %{time_starttransfer}\n
                    ----------\n
         time_total:  %{time_total}\n
復制代碼
  1. 同一個目錄下,執行 curl 操作:
curl -w "@curl-format.txt" -o /dev/null -s "https://api.weixin.qq.com/sns/jscode2session?xxx=xxx&xx=aa"
復制代碼

拿到的結果如下:

 

在網上查閱了下,各個字段含義如下(單位都是 ):

  • time_namelookup: DNS 域名解析的時候,就是把 https://zhihu.com 轉換成 ip 地址的過程
  • time_connect: TCP 連接建立的時間,就是三次握手的時間
  • time_appconnect: SSL/SSH 等上層協議建立連接的時間,比如 connect/handshake 的時間
  • time_pretransfer: 從開始到最后一個請求事務的時間
  • time_redirect: 從請求開始到響應開始傳輸的時間
  • time_starttransfer: 從請求開始到第一個字節將要傳輸的時間
  • time_total: 這次請求花費的全部時間

從上面截圖中可以看出,我們服務器上,在DNS域名解析階段,就花了 5秒 ,難怪會超時了……

找到了問題,那就先在機器上修改 /etc/hosts 文件,寫死一個微信域名的IP解析,暫時 把這個問題修復了。

相關資料

分享至 : QQ空間
收藏
原作者: Jess 來自: 掘金
最新彩票IOS版 正规的彩票网站 福建31选7130期开奖结果 足彩310星象走势图 彩票托网上照片曝光 体彩十一选五奖金对照表 竞彩推荐吧 黑龙江福彩36选七综合版 湖北11选五基本走势图彩经网 2018买马??免费资料 排列三走势图表 四个循环倍投法 排列3开奖走势图综合版 广东快乐8开奖结果 一分赛车 新一代时时彩在线计划