0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

汽車玩家 ? 來(lái)源:IT知識(shí)課堂 ? 作者:IT知識(shí)課堂 ? 2020-05-05 23:13 ? 次閱讀

精髓

在OkHttp3中,其靈活性很大程度上體現(xiàn)在,可以攔截其任意一個(gè)環(huán)節(jié),而這個(gè)優(yōu)勢(shì)便是okhttp3整個(gè)請(qǐng)求響應(yīng)架構(gòu)體系的精髓所在:

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

Okhttp請(qǐng)求流程

在OkHttp3中,每一個(gè)請(qǐng)求任務(wù)都封裝為一個(gè)Call,其實(shí)現(xiàn)為RealCall。

而所有的策略幾乎都可以通過(guò)OkHttpClient傳入

所有全局策略與數(shù)據(jù),除了存儲(chǔ)在允許上層訪問(wèn)的OkHttpClient實(shí)例以外,還有一部分是存儲(chǔ)在只允許包可見(jiàn)的Internal.instance中(如連接池、路由黑名單等)

OkHttp中用戶可傳入的interceptor分為兩類,一類是全局interceptor,該類interceptor在請(qǐng)求開(kāi)始之前最早被調(diào)用,另外一類為非網(wǎng)頁(yè)請(qǐng)求的networkInterceptor,這類interceptor只有在非網(wǎng)頁(yè)請(qǐng)求中會(huì)被調(diào)用,并且是在組裝完成請(qǐng)求之后,真正發(fā)起請(qǐng)求之前被調(diào)用(這塊具體可以參看RealCall#getResponseWithInterceptorChain()方法)

整個(gè)請(qǐng)求過(guò)程通過(guò)RealInterceptorChain#proceed來(lái)連接,在每個(gè)interceptor中調(diào)用下一個(gè)interceptor來(lái)完成整個(gè)請(qǐng)求流程,并且在回到當(dāng)前interceptor后完成響應(yīng)處理

在異步請(qǐng)求中,我們通過(guò)Callback來(lái)獲得簡(jiǎn)單清晰的請(qǐng)求回調(diào)(onFailure、onResponse)

在OkHttpClient中,我們可以傳入EventListener的工廠方法,為每一個(gè)請(qǐng)求創(chuàng)建一個(gè)EventListener,來(lái)接收非常細(xì)的事件回調(diào)

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

完整interceptor-chain

OkHttp3中的線程池

OkHttp 中的對(duì)所有的任務(wù)采用 NamedRunnable,約束每個(gè)執(zhí)行單元給出對(duì)應(yīng)的業(yè)務(wù)名稱,以便于線程維護(hù)。

1.異步請(qǐng)求線程池-OkHttp Dispatcher

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

該線程池與Android下的 Executors.newCachedThreadPool() 比較類似;

無(wú)任務(wù)上限,自動(dòng)回收閑置60s的線程,適用于大量耗時(shí)較短的任務(wù);

雖然線程池?zé)o任務(wù)上限,但是Dispatcher對(duì)入口enqueue()進(jìn)行了把關(guān),最大的異步任務(wù)數(shù)默認(rèn)是64,同一個(gè)主機(jī)默認(rèn)是5,當(dāng)然這兩個(gè)默認(rèn)值是可以修改的,Dispatcher提供的修改接口;

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

通過(guò)兩個(gè)雙端隊(duì)列來(lái)維護(hù)準(zhǔn)備執(zhí)行的任務(wù)和正在執(zhí)行的任務(wù):Deque readyAsyncCalls, Deque runningAsyncCalls;

在每個(gè)任務(wù)結(jié)束時(shí),都會(huì)檢查 readyAsyncCalls 是否有任務(wù),在條件滿足的情況下,按照先進(jìn)先出的原則將任務(wù)移動(dòng)到 runningAsyncCalls中,并在線程池中執(zhí)行;

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

異步請(qǐng)求線程池

2.連接池清理線程池-OkHttp ConnectionPool

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

該線程池用來(lái)清理長(zhǎng)時(shí)間閑置的和泄漏的連接;

該線程池本身無(wú)任務(wù)上限,線程閑置60s自動(dòng)回收;

雖然任務(wù)無(wú)上限,但其通過(guò) cleanupRunning 標(biāo)記來(lái)控制只有一個(gè)線程在運(yùn)行,當(dāng)連接池中沒(méi)有連接后才會(huì)被重新設(shè)置為 false;

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

次工作線程會(huì)不斷地清理,當(dāng)清理完一遍后超時(shí)連接后,根據(jù)當(dāng)前連接池中最近的下一個(gè)空閑超時(shí)連接計(jì)算出一個(gè)阻塞時(shí)間并阻塞,直到連接池中沒(méi)有任何連接才結(jié)束,并將 cleanupRunning 設(shè)為 false;

在每次有連接加入連接池時(shí),如果當(dāng)前沒(méi)有清理任務(wù)運(yùn)行,會(huì)加入一個(gè)清理任務(wù)到到線程池中執(zhí)行;

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

連接池清理線程池

3. 緩存整理線程池-OkHttp DiskLruCache

架構(gòu)分析高效HTTP客戶端OkHttp有什么優(yōu)勢(shì)

該線程池用于整理本地請(qǐng)求緩存數(shù)據(jù);

緩存的整理包含: 達(dá)到閥值大小的文件,刪除最近最少使用的記錄,在有關(guān)操作達(dá)到一定數(shù)量以后對(duì)記錄進(jìn)行重建;

最大運(yùn)行線程數(shù)1,無(wú)需考慮線程安全問(wèn)題,自動(dòng)回收閑置60s的線程;

4. HTTP2異步事務(wù)線程池-OkHttp Http2Connection

HTTP2采用了多路復(fù)用,因此需要維護(hù)連接有效性,本線程池就是用于維護(hù)相關(guān)的各類HTTP2事務(wù);

線程池本身無(wú)任務(wù)上限,自動(dòng)回收閑置60s的線程;

每一個(gè)HTTP2連接都有這么一個(gè)線程池存在;

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 存儲(chǔ)
    +關(guān)注

    關(guān)注

    13

    文章

    4130

    瀏覽量

    85294
  • HTTP
    +關(guān)注

    關(guān)注

    0

    文章

    481

    瀏覽量

    30778
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用NS1串口服務(wù)器HTTP模式上傳服務(wù)器數(shù)據(jù)

    HTTP協(xié)議工作于客戶端-服務(wù)架構(gòu)之上。瀏覽器作為HTTP客戶端通過(guò)URL向
    的頭像 發(fā)表于 08-30 12:36 ?132次閱讀
    使用NS1串口服務(wù)器<b class='flag-5'>HTTP</b>模式上傳服務(wù)器數(shù)據(jù)

    使用ESP8266板和AT命令集構(gòu)建一個(gè)多客戶端HTTP服務(wù)器遇到的疑問(wèn)求解

    我們正在嘗試使用ESP8266板和 AT 命令集構(gòu)建一個(gè)多客戶端 HTTP 服務(wù)器,通過(guò)串行端口連接到 Arduino 板。我們正在使用 Arduino Mega 2560 板。它有更多的串行端口
    發(fā)表于 07-18 08:03

    esp_iot_sdk_v0.9.6_b1客戶端斷開(kāi)連接導(dǎo)致WDT重置怎么解決?

    客戶端斷開(kāi)連接,服務(wù)器一定不會(huì)掛起。實(shí)際上,由于客戶端啟動(dòng)了連接,因此客戶端理所當(dāng)然地應(yīng)該能夠斷開(kāi)連接,而不會(huì)對(duì)服務(wù)器造成任何問(wèn)題。 IPD,0,80:GET /測(cè)試 HTTP/1.
    發(fā)表于 07-18 06:33

    如何同時(shí)在ESP8266上運(yùn)行TCP客戶端和TCP服務(wù)?

    客戶端無(wú)法連接到 TCP 服務(wù)器。如果不將 TCP 客戶端從 ESP 連接到云服務(wù)器,則 ESP 上的 TCP 服務(wù)器可以很好地接受 TCP 客戶端連接。 TCP 客戶端 UDP
    發(fā)表于 07-08 08:26

    求助,關(guān)于ESP32C3 TCP客戶端連接斷線問(wèn)題求解

    ESP32C3開(kāi)啟AP模式做TCP服務(wù)器,手機(jī)做客戶端連接服務(wù)器;超過(guò)默認(rèn)最大連接數(shù)(5)以后,即使部分客戶端斷開(kāi)了,也無(wú)法再發(fā)起連接連接不上。一定需要服務(wù)器給客戶端發(fā)送數(shù)據(jù),確認(rèn)
    發(fā)表于 06-27 07:54

    服務(wù)測(cè)試和客戶端測(cè)試區(qū)別在哪

    服務(wù)測(cè)試和客戶端測(cè)試是軟件開(kāi)發(fā)過(guò)程中的兩個(gè)重要環(huán)節(jié),它們分別針對(duì)服務(wù)器客戶端的軟件進(jìn)行測(cè)試。本文將詳細(xì)介紹服務(wù)測(cè)試和
    的頭像 發(fā)表于 05-30 15:27 ?1536次閱讀

    HarmonyOS開(kāi)發(fā)實(shí)例:【分布式新聞客戶端

    基于柵格布局、設(shè)備管理和多端協(xié)同,實(shí)現(xiàn)一次開(kāi)發(fā),多端部署的分布式新聞客戶端頁(yè)面。
    的頭像 發(fā)表于 04-17 15:57 ?736次閱讀
    HarmonyOS開(kāi)發(fā)實(shí)例:【分布式新聞<b class='flag-5'>客戶端</b>】

    適用于Linux的基于Rust的同步客戶端介紹

    一個(gè)簡(jiǎn)單而優(yōu)雅的 GUI 同步客戶端,提供雙向同步。
    的頭像 發(fā)表于 01-05 11:32 ?475次閱讀
    適用于Linux的基于Rust的同步<b class='flag-5'>客戶端</b>介紹

    分享一款別樣的ssh客戶端-PortX

    目前支持ssh的客戶端很多,比如putty、crt、xshell等,今天分享一款別樣的ssh客戶端-PortX,通過(guò)簡(jiǎn)單但全面的UI,PortX為您提供了純粹的終端模擬體驗(yàn)。
    的頭像 發(fā)表于 01-02 13:37 ?494次閱讀
    分享一款別樣的ssh<b class='flag-5'>客戶端</b>-PortX

    如何使用ESP8266搭建MQTT客戶端?

    手頭一塊ESP8266的板子,想搭建一個(gè)MQTT客戶端,該如何實(shí)現(xiàn)呢?
    發(fā)表于 11-07 06:36

    安信可Ai-WB2模組HTTP 客戶端 POST請(qǐng)求方法

    文章目錄 一、準(zhǔn)備工作 二、連接路由器 三、HTTP客戶端POST請(qǐng)求方法(適用于POST少量數(shù)據(jù)) 四、HTTP 客戶端 POST 請(qǐng)求方法(推薦方式) 五、聯(lián)系我們 01 準(zhǔn)備工作
    的頭像 發(fā)表于 10-30 17:27 ?543次閱讀
    安信可Ai-WB2模組<b class='flag-5'>HTTP</b> <b class='flag-5'>客戶端</b> POST請(qǐng)求方法

    AT32基于FreeRTOS的AWS MQTT客戶端

    AT32基于FreeRTOS的AWS MQTT客戶端建立一個(gè)MQTT客戶端與 AWS IoT Core進(jìn)行通訊,用戶可以基于這個(gè)范例去開(kāi)發(fā)屬于自己的應(yīng)用。
    發(fā)表于 10-26 06:03

    C#編寫(xiě)socket客戶端案例

    C#編寫(xiě)socketDemo,socket做服務(wù)器和做客戶端例子
    發(fā)表于 10-25 15:10 ?0次下載

    安信可Ai-WB2模組HTTP 客戶端 HEAD和GET 請(qǐng)求方法

    文章目錄 一、準(zhǔn)備工作 二、連接路由器 三、HTTP客戶端HEAD請(qǐng)求方法 四、HTTP 客戶端 GET 請(qǐng)求方法 五、聯(lián)系我們 01 準(zhǔn)備工作 需要準(zhǔn)備的軟硬件:Ai-WB2系列模組
    的頭像 發(fā)表于 10-23 17:41 ?568次閱讀
    安信可Ai-WB2模組<b class='flag-5'>HTTP</b> <b class='flag-5'>客戶端</b> HEAD和GET 請(qǐng)求方法

    OPCUA客戶端工具:UaExpert使用進(jìn)階小技巧

    UaExpert是一款UA客戶端工具,該軟件支持OPCUA標(biāo)準(zhǔn)中的大部分客戶端功能,兼容性良好,頁(yè)面簡(jiǎn)潔,絕大多數(shù)功能免費(fèi)使用,是業(yè)內(nèi)獨(dú)一檔的OPCUA服務(wù)器功能測(cè)試軟件。 本文將重點(diǎn)介紹其仿真、配置、歷史功能測(cè)試和導(dǎo)出節(jié)點(diǎn)的功能。
    的頭像 發(fā)表于 10-13 11:00 ?6056次閱讀
    OPCUA<b class='flag-5'>客戶端</b>工具:UaExpert使用進(jìn)階小技巧