」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 通訊:數據獲取模式

通訊:數據獲取模式

發佈於2024-11-07
瀏覽:869

重大公告!
我開始了我日常的前端系統設計學習之旅。我將在部落格中分享每個模組的見解。所以,這就是開始,還有更多精彩!

在本部落格中,我們將探討前端系統設計所必需的不同資料取得機制,包括短輪詢、長輪詢、WebSocket、伺服器發送事件 (SSE) 和 Webhook。每種技術都滿足向客戶端和伺服器傳輸資料以及從客戶端和伺服器傳輸資料的特定需求,理解它們對於設計可擴展的即時 Web 應用程式至關重要。

1. 短輪詢

短輪詢是客戶端定期向伺服器重複發送請求以檢查更新的方法。

Communication: Data Fetching Patterns

setInterval(async () => {
  const response = await fetch('/api/get-posts');
  const data = await response.json();
  // Update UI with new data
}, 5000); // Poll every 5 seconds

  • 簡短的即時交流
  • 資料沒有持久性
  • 資源效用較少
  • 重複請求導致伺服器負載
  • 頻寬使用量增加

例如 - 股市行情、社群媒體動態

2. 長輪詢

長輪詢是對短輪詢的增強,在短輪詢中,客戶端發送請求,伺服器保持連接打開,直到有新資料要返回。

從後端來看,只有在資料更新時才會發送回應,在此之前它將保留請求。如果長時間沒有更新則逾時處理。

Communication: Data Fetching Patterns

客戶端

async function subscribe() {
  let response = await fetch("/subscribe");

  if (response.status == 502) {
    // Status 502 is a connection timeout error, let's reconnect
    await subscribe();
  } else if (response.status != 200) {
    // An error - let's show it
    showMessage(response.statusText);
    // Reconnect in one second
    await new Promise(resolve => setTimeout(resolve, 1000));
    await subscribe();
  } else {
    // Get and show the message
    let message = await response.text();
    showMessage(message);
    // Call subscribe() again to get the next message
    await subscribe();
  }
}

subscribe();

  • 單一長壽命連接
  • 提供即時更新,請求數量少於短輪詢。
  • 在沒有更新時減少不必要的資料傳輸。
  • 連線可以長時間保持開啟狀態,從而增加伺服器負載。

例如-即時客戶支援聊天

3. 網路套接字

WebSockets 允許客戶端和伺服器之間進行全雙工通信,使其成為即時資料傳輸最有效的方法。

客戶端開啟與伺服器的 WebSocket 連接,客戶端和伺服器都可以透過這個連接互相傳送訊息。

Communication: Data Fetching Patterns

webSocket = new WebSocket(url, protocols);

// Send message
webSocket.send("Here's some text that the server is urgently awaiting!");

// Receive message
webSocket.onmessage = (event) => {
  console.log(event.data);
};
  • 持續雙向通訊
  • 多個函式庫來實現它 - ws、socket.io 等
  • 高效率、低開銷的高頻更新
  • 挑戰 - 與 1 台伺服器保持通訊、處理故障和擴展、佔用資源。

例如-即時聊天應用程式、線上多人遊戲

4. 伺服器發送事件(SSE)

SSE 透過 HTTP 連線提供從伺服器到客戶端的單向更新流。

Communication: Data Fetching Patterns

const evtSource = new EventSource("ssedemo.php");

evtSource.onmessage = (event) => {
  const newElement = document.createElement("li");
  const eventList = document.getElementById("list");

  newElement.textContent = `message: ${event.data}`;
  eventList.appendChild(newElement);
};
  • 單向通訊萬歲
  • 單一 HTTP 連線
  • 挑戰 - 資源使用率、瀏覽器相容性和非活動標籤上的行為

例如 - 來源、通知

5. 網路鉤子

Webhooks 是一種伺服器到伺服器的通訊機制,當事件發生時,伺服器會將資料傳送到預先定義的 URL。客戶端不需要不斷檢查伺服器是否有更新。

通常用於觸發系統之間的操作,例如付款通知、GitHub 事件或第三方服務整合。

結論

選擇正確的通訊方法取決於您的應用程式的要求。 WebSocket 和 SSE 非常適合即時和串流數據,而長輪詢則在效能和易用性之間提供了平衡。短輪詢是針對不頻繁更新的簡單解決方案,但可能會佔用大量資源,而 Webhooks 是伺服器到伺服器通知的理想選擇。

每種技術都有其自身的優點和限制。了解這些可以幫助您做出明智的決策,以建立高效、反應迅速的 Web 應用程式。

此部落格開放供建議與討論!

版本聲明 本文轉載於:https://dev.to/shagun/communication-data-fetching-patterns-5d7a?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 理解 Shadow DOM:封裝 Web 元件的關鍵
    理解 Shadow DOM:封裝 Web 元件的關鍵
    在現代 Web 開發中,創建可重複使用和可維護的元件至關重要。 Shadow DOM 是 Web 元件標準的一部分,在實現這一目標方面發揮著至關重要的作用。本文深入探討了 Shadow DOM 的概念、它的優點以及如何在您的專案中有效地使用它。 什麼是 Shadow DOM? Sh...
    程式設計 發佈於2024-11-07
  • 如何使用 Java 運行時解決輸出重定向問題?
    如何使用 Java 運行時解決輸出重定向問題?
    使用Runtime 的exec() 方法解決輸出重定向問題在Java 中,利用Runtime.getRuntime().exec() 運行指令可以擷取進程的輸出和錯誤流。但是,在需要輸出重定向的情況下,單獨使用此方法可能會無效。 問題:輸出未重定向當使用Runtime.getRuntime().ex...
    程式設計 發佈於2024-11-07
  • 如何使用 CSS 懸停效果從左到右填滿背景顏色?
    如何使用 CSS 懸停效果從左到右填滿背景顏色?
    使用CSS 從左到右填充背景顏色在CSS 中,您可以透過利用線性漸層和動畫背景定位來創造迷人的懸停效果。這種方法使您能夠在懸停時從左到右用新顏色填充元素的背景。 線性漸變和背景大小關鍵是使用由兩種顏色組成的線性漸變背景,並將背景大小設定為元素寬度的兩倍。這允許您在兩種顏色之間創建無縫過渡。 背景定位...
    程式設計 發佈於2024-11-07
  • GraalVM 本機映像中的記憶體管理
    GraalVM 本機映像中的記憶體管理
    内存管理是计算机软件开发的重要组成部分,负责应用程序中内存的有效分配、利用和释放。其重要性在于增强软件性能,保证系统稳定性。 垃圾收集 垃圾收集 (GC) 在 Java 和 Go 等当代编程语言中至关重要。它自动检测并回收未使用的内存,从而减轻开发人员手动管理内存的需要。 GC 的概...
    程式設計 發佈於2024-11-07
  • ## 在 C++ 中什麼時候應該使用參考作為函數參數?
    ## 在 C++ 中什麼時候應該使用參考作為函數參數?
    在 C 中傳遞參數:瞭解引用在 C 中,函數參數的行為由其型別決定。一個重要的區別是「按值傳遞」和「按引用傳遞」。 為什麼在函數參數中使用引用? 引用在函數參數中用於兩種情況主要原因:修改參數:引用允許函數修改值論證通過了。這意味著該函數可以進行呼叫者可見的更改。 避免物件複製: 透過引用傳遞大物件...
    程式設計 發佈於2024-11-07
  • 為什麼會出現“getaddrinfo 失敗”以及如何修復?
    為什麼會出現“getaddrinfo 失敗”以及如何修復?
    探索“getaddrinfo failed”錯誤名稱解析過程中發生錯誤“getaddrinfo failed”,其中主機名稱被翻譯轉換為IP 位址。它顯示所提供的主機名的解析有問題。 深入研究錯誤情境從提供的錯誤追蹤中,我們可以將原因追溯到套接字。 getaddrinfo(主機,連接埠)方法。當無法...
    程式設計 發佈於2024-11-07
  • 如何在單一命令列中運行多行命令?
    如何在單一命令列中運行多行命令?
    如何在一行命令列中執行多行語句使用Python的-c選項執行單行循環時,在循環之前導入模組會導致語法錯誤。這是因為Python解釋器將程式碼區塊視為單一語句。 要解決此問題,可以採用以下幾種方法:使用管道要克服語法錯誤,請使用echo 命令將程式碼區塊作為一系列輸入行重定向到Python:echo ...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中從 MySQL 遷移到 MySQLi?
    如何在 PHP 中從 MySQL 遷移到 MySQLi?
    從 MySQL 遷移到 MySQLi將網站從 MySQL 遷移到 MySQLi 需要修改 PHP 程式碼,但資料庫本身基本上不受影響。 MySQLi 是 MySQL 擴充功能的改進版本,提供增強的功能和安全性。 PHP 程式碼變更是的,您可以簡單地將 MySQLi 函數替換為 MySQL 函數。這裡...
    程式設計 發佈於2024-11-07
  • 如何在CSS中實現背景和子元素的不同透明度?
    如何在CSS中實現背景和子元素的不同透明度?
    理解 CSS 背景不透明度在 CSS 中,不透明度控制元素的透明度。當應用於容器時,它自然會影響背景及其子元素。 繼承問題要實現背景和子元素不同的不透明度, CSS 繼承帶來了挑戰。子元素從其父容器繼承不透明度,從而導致所提供範例中的背景和文字具有相同的不透明度。 實現所需不透明度的解決方案實現要達...
    程式設計 發佈於2024-11-07
  • 【個人網站】Next如何整合Notion資料庫
    【個人網站】Next如何整合Notion資料庫
    To integrate a Notion database into a Next.js project, you can use Notion as a content management system (CMS) and display its content on your website...
    程式設計 發佈於2024-11-07
  • 為什麼 PhpMyAdmin 在 Ubuntu 12.04 上給出「MySQLi 擴充缺失」錯誤?
    為什麼 PhpMyAdmin 在 Ubuntu 12.04 上給出「MySQLi 擴充缺失」錯誤?
    PhpMyAdmin 錯誤:MySQLi 擴充缺失在 Ubuntu 12.04 遇到 PhpMyAdmin 問題?儘管安裝了 Apache2、PHP5、MySQL 和 PhpMyAdmin,您還是遇到了「mysqli 擴充遺失」錯誤。 儘管您已取消註解 php.ini 中的「extension=my...
    程式設計 發佈於2024-11-07
  • 如何使用 java.net.URLConnection 將檔案和附加參數上傳到 HTTP 伺服器?
    如何使用 java.net.URLConnection 將檔案和附加參數上傳到 HTTP 伺服器?
    在 Java 中使用附加參數將檔案上傳到 HTTP 伺服器將檔案上傳到 HTTP 伺服器是許多應用程式的常見需求。但是,有時也需要隨文件一起傳遞附加參數。這是一個允許您在不使用外部庫的情況下發送文件和參數的解決方案:java.net.URLConnection 和Multipart/Form-Dat...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中逐行讀取和處理文字檔?
    如何在 PHP 中逐行讀取和處理文字檔?
    在 PHP 中讀取文字檔案:逐步指南許多 Web 開發場景都涉及從文字檔案讀取資料。在 PHP 中,檔案處理函數提供了逐行讀取純文字檔案的便捷方法。讓我們分解一下使用 PHP 讀取文字檔案的過程。 讀取文字檔案的程式碼:以下PHP 程式碼片段示範如何讀取文字檔案並逐行處理其內容:<?php /...
    程式設計 發佈於2024-11-07
  • 我離不開的生產力工具(獎勵)
    我離不開的生產力工具(獎勵)
    大家好,你們的孩子 Nomadev 帶著另一篇貼文回來了!今天,我很高興與大家分享一些我每天使用的超酷的人工智慧工具。這些工具已成為我日常工作的重要部分,幫助我保持井井有條、有效率並完成更多工作。 在當今快節奏的世界中,我們都希望提高生產力和效率。借助人工智慧,有大量工具可以幫助我們管理任務、簡化...
    程式設計 發佈於2024-11-07
  • 在 Go/Templ 中製作一個乾淨、友好的 Spinner
    在 Go/Templ 中製作一個乾淨、友好的 Spinner
    无用的 HTML 你们可能认为在 HTML 中制作一个一致、干净且专业的旋转框是一项简单的任务...但是,令我们失望的是,没有标准的属性来告诉输入它应该只接受整数或小数值,所有的输入过滤都必须是JS。哎呀! 我将使用 Go、a-h/Templ、Tailwind 和我心爱的 Alpi...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3