小程序server請(qǐng)求微信服務(wù)器超時(shí)的解決方法
今天有同學(xué)在測(cè)試小程序的過(guò)程中,發(fā)現(xiàn)一個(gè)問(wèn)題,調(diào)用 微信官方的服務(wù)端接口超時(shí) ,比如這個(gè)接口,https://api.weixin.qq.com/sns/jscode2session ,因?yàn)槲覀冃〕绦虻卿浀臅r(shí)候,會(huì)在自己server端調(diào)用微信的API,這個(gè)接口超時(shí),導(dǎo)致我們的登錄流程也就掛掉了。本來(lái)以為是偶爾的網(wǎng)絡(luò)問(wèn)題,但是,同學(xué)發(fā)現(xiàn)在測(cè)試服務(wù)器上,很穩(wěn)定的復(fù)現(xiàn)超時(shí)!但是在我們本地測(cè)試過(guò)程中,請(qǐng)求微信服務(wù)器又很快響應(yīng)。嗯,理論上微信服務(wù)器不會(huì)出問(wèn)題的……
試著在服務(wù)器上去 curl 微信的接口,確實(shí)挺慢的,我們代碼里配置了超時(shí)是3秒,目測(cè)確實(shí)超過(guò)了3秒才返回!抱著僥幸的想法,讓同學(xué)把超時(shí)改成5秒,依然超時(shí)……嗯,略微有點(diǎn)尷尬。
試著 ping api.weixin.qq.com
,發(fā)現(xiàn)收到第一個(gè)包,隔著挺長(zhǎng)時(shí)間,后面的包平均幾十毫秒,網(wǎng)絡(luò)應(yīng)該也沒問(wèn)題吧。
沒辦法了,因?yàn)槭欠?wù)端,只能用 curl,想看看這個(gè)工具能不能提供一下,整個(gè)請(qǐng)求的各個(gè)階段,時(shí)間是怎么分布的。搜了一下,還真有這個(gè)功能,具體操作如下:
在某個(gè)目錄下,新建一個(gè)文件,比如 curl-format.txt ,內(nèi)容如下:
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
在同一個(gè)目錄下,執(zhí)行 curl 操作:
curl -w "@curl-format.txt" -o /dev/null -s "https://api.weixin.qq.com/sns/jscode2session?xxx=xxx&xx=aa"
拿到的結(jié)果如下:
在網(wǎng)上查閱了下,各個(gè)字段含義如下(單位都是 秒 ):
- time_namelookup: DNS 域名解析的時(shí)候,就是把 https://zhihu.com 轉(zhuǎn)換成 ip 地址的過(guò)程
- time_connect: TCP 連接建立的時(shí)間,就是三次握手的時(shí)間
- time_appconnect: SSL/SSH 等上層協(xié)議建立連接的時(shí)間,比如 connect/handshake 的時(shí)間
- time_pretransfer: 從開始到最后一個(gè)請(qǐng)求事務(wù)的時(shí)間
- time_redirect: 從請(qǐng)求開始到響應(yīng)開始傳輸?shù)臅r(shí)間
- time_starttransfer: 從請(qǐng)求開始到第一個(gè)字節(jié)將要傳輸?shù)臅r(shí)間
- time_total: 這次請(qǐng)求花費(fèi)的全部時(shí)間
從上面截圖中可以看出,我們服務(wù)器上,在DNS域名解析階段,就花了 5秒 ,難怪會(huì)超時(shí)了……
找到了問(wèn)題,那就先在機(jī)器上修改 /etc/hosts 文件,寫死一個(gè)微信域名的IP解析,暫時(shí) 把這個(gè)問(wèn)題修復(fù)了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 解決mysql服務(wù)器在無(wú)操作超時(shí)主動(dòng)斷開連接的情況
- php中curl和soap方式請(qǐng)求服務(wù)超時(shí)問(wèn)題的解決
- 淺談java中異步多線程超時(shí)導(dǎo)致的服務(wù)異常
- 詳解Nginx服務(wù)器中配置超時(shí)時(shí)間的方法
- Win7系統(tǒng)日志提示在沒有配置的 DNS 服務(wù)器響應(yīng)之后,名稱“域名”的名稱解析超時(shí)的解放方法
- oracle遠(yuǎn)程連接服務(wù)器出現(xiàn) ORA-12170 TNS:連接超時(shí) 解決辦法
- 使用FileZilla連接時(shí)超時(shí)無(wú)法連接到服務(wù)器
- SNMP4J服務(wù)端連接超時(shí)問(wèn)題解決方案
相關(guān)文章
CSS中position屬性之fixed實(shí)現(xiàn)div居中
這篇文章主要介紹了CSS中position屬性之fixed實(shí)現(xiàn)div居中的相關(guān)資料,需要的朋友可以參考下2015-12-12微信開發(fā) 使用picker封裝省市區(qū)三級(jí)聯(lián)動(dòng)模板
這篇文章主要學(xué)習(xí)微信開發(fā),如何使用picker封裝省市區(qū)三級(jí)聯(lián)動(dòng)模板,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10JavaScript事件概念詳解(區(qū)分靜態(tài)注冊(cè)和動(dòng)態(tài)注冊(cè))
這篇文章主要介紹了JavaScript事件(區(qū)分靜態(tài)注冊(cè)和動(dòng)態(tài)注冊(cè))的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下2021-02-02javascript設(shè)計(jì)模式 – 中介者模式原理與用法實(shí)例分析
這篇文章主要介紹了javascript設(shè)計(jì)模式 – 中介者模式,結(jié)合實(shí)例形式分析了javascript中介者模式基本概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04Javascript中產(chǎn)生固定結(jié)果的函數(shù)優(yōu)化技巧
分享一個(gè)Javascript編寫函數(shù)的優(yōu)化技巧;適用的函數(shù)應(yīng)該要滿足以下條件;產(chǎn)生固定結(jié)果;復(fù)雜或較耗時(shí)等等,感興趣的朋友可以了解下2013-01-01js正則表達(dá)exec與match的區(qū)別說(shuō)明
本篇文章主要是對(duì)js正則表達(dá)exec與match的區(qū)別進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-01-01