Pub/Sub模式及其在編程中的應用

一、Pub/Sub模式概述

Pub/Sub是一種消息傳遞模式,它通過一個中心點(Pub/Sub服務器)來連接發送者(publishers)和接收者(subscribers),實現解耦和作用。

當一個消息被發送到Pub/Sub服務器時,該消息將被分發給所有訂閱該主題的訂閱者,每個主題可以有多個訂閱者。

二、Pub/Sub模式的應用場景

以下是Pub/Sub模式在編程中的一些應用場景。

1.事件驅動架構

在事件驅動的架構中,事件作為消息進行傳遞,Pub/Sub模式可以很好的實現事件觸發程序。

function subscriber1() {
  console.log('收到通知:事件1');
}
function subscriber2() {
  console.log('收到通知:事件2');
}
function subscriber3() {
  console.log('收到通知:事件3');
}
const pubSub = (function() {
  const subscribers = {};
  function subscribe(topic, callback) {
    if (!subscribers.hasOwnProperty(topic)) {
      subscribers[topic] = [];
    }
    subscribers[topic].push(callback);
  }
  function unsubscribe(topic, callback) {
    if (subscribers.hasOwnProperty(topic)) {
      subscribers[topic] = subscribers[topic].filter(subscriber => subscriber !== callback);
    }
  }
  function publish(topic, data) {
    if (subscribers.hasOwnProperty(topic)) {
      subscribers[topic].forEach(subscriber => subscriber(data));
    }
  }    
  return {
    subscribe,
    unsubscribe,
    publish
  };
})();
pubSub.subscribe('事件1', subscriber1);
pubSub.subscribe('事件2', subscriber2);
pubSub.subscribe('事件3', subscriber3);
pubSub.publish('事件1', '事件1觸發');
pubSub.publish('事件2', '事件2觸發');
pubSub.publish('事件3', '事件3觸發');

2.消息隊列

Pub/Sub模式可以實現基於消息的異步處理,將消息存儲在隊列中,多個消費者可以訂閱該隊列並對消息進行處理。

const messageQueue = (function() {
  const queue = [];
  const subscribers = {};
  let isProcessing = false;
  function subscribe(topic, callback) {
    if (!subscribers.hasOwnProperty(topic)) {
      subscribers[topic] = [];
    }
    subscribers[topic].push(callback);
  }
  function unsubscribe(topic, callback) {
    if (subscribers.hasOwnProperty(topic)) {
      subscribers[topic] = subscribers[topic].filter(subscriber => subscriber !== callback);
    }
  }
  function enqueue(topic, message) {
    queue.push({topic, message});
    if (!isProcessing) {
      processQueue();
    }
  }
  function processQueue() {
    isProcessing = true;
    const message = queue.shift();
    if (subscribers.hasOwnProperty(message.topic)) {
      subscribers[message.topic].forEach(subscriber => subscriber(message.message));
    }
    if (queue.length > 0) {
      setTimeout(() => processQueue(), 0);
    } else {
      isProcessing = false;
    }
  }
  return {
    subscribe,
    unsubscribe,
    enqueue
  };
})();
function consumer1(message) {
  console.log(`consumer1處理消息:${message}`);
}
function consumer2(message) {
  console.log(`consumer2處理消息:${message}`);
}
messageQueue.subscribe('隊列1', consumer1);
messageQueue.subscribe('隊列1', consumer2);
messageQueue.enqueue('隊列1', '隊列1的消息1');
messageQueue.enqueue('隊列1', '隊列1的消息2');

3.分佈式系統

在分佈式系統中,不同的進程或主機可以訂閱相同的主題,以便協調工作、共享信息。

以下是一個使用Node.js和Redis實現Pub/Sub模式的例子。

訂閱主題:

const redis = require('redis');
const client = redis.createClient();
client.subscribe('messages');
client.on('message', (channel, message) => {
  console.log(`收到消息:${message}`);
});

發佈消息:

const redis = require('redis');
const client = redis.createClient();
client.publish('messages', '這是一條消息!');

三、Pub/Sub的優缺點

優點:

1.解耦:發送者和接收者之間的聯繫被完全解耦。

2.可伸縮:可以隨着業務增長來擴展系統,因為Pub/Sub模式可以很容易地添加新的發送者和接收者。

3.分佈式:可以將發送者和接收者分佈在不同的服務器上,從而實現分佈式架構的目的。

4.異步:Pub/Sub模式是異步的,因此發送者無需等待接收者的響應。

缺點:

1.消息可靠性:Pub/Sub模式下,當訂閱者處理消息過程中發生錯誤,消息可能會丟失。

2.消息處理順序:在訂閱者處理消息之前,無法保證消息的處理順序。

3.消息重複:由於系統故障或其他原因,可能會導致消息被重複發送給訂閱者。

四、總結

Pub/Sub模式是一種非常常見的消息傳遞模式,可以應用在很多場景中,如事件驅動架構、消息隊列、分佈式系統等。雖然它具有很多優點,但也存在一些缺點,比如消息可靠性和消息處理順序等問題。在實際應用中,我們需要根據具體的場景選擇合適的消息傳遞模式。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/246784.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:17
下一篇 2024-12-12 13:17

相關推薦

  • 手機安全模式怎麼解除?

    安全模式是一種手機自身的保護模式,它會禁用第三方應用程序並使用僅限基本系統功能。但有時候,安全模式會使你無法使用手機上的一些重要功能。如果你想解除手機安全模式,可以嘗試以下方法: …

    編程 2025-04-28
  • Qt State Machine與狀態機模式

    本文將介紹Qt State Machine和狀態機模式在Qt中的實現。Qt提供了QStateMachine和QState兩個類,可以方便地實現狀態機模式,並且能有效地處理複雜的、多…

    編程 2025-04-27
  • 顯示C++設計模式

    本文將詳細介紹顯示C++設計模式的概念、類型、優點和代碼實現。 一、概念 C++設計模式是在軟件設計階段定義,用於處理常見問題的可重用解決方案。這些解決方案是經過測試和驗證的,並已…

    編程 2025-04-27
  • Centos7進入單用戶模式的解釋

    本文將介紹如何在Centos7中進入單用戶模式,並從以下幾個方面進行詳細的闡述。 一、Centos7進入單用戶模式的解答 在Centos7中進入單用戶模式需要執行以下步驟: 1. …

    編程 2025-04-27
  • 深入解析PSM模式

    一、PSM模式是什麼 PSM模式,即頁面-狀態-模型模式,是一種前端開發模式。它以頁面為中心,將頁面內的所有狀態和業務邏輯抽象成一個由頁面轉化而來的虛擬狀態機模型,從而將業務邏輯與…

    編程 2025-04-25
  • 授權碼模式與OAuth2.0

    一、什麼是授權碼模式 授權碼模式(Authorization Code Grant Type)是OAuth2.0協議中最常用的授權方式之一,也是最為安全的一種授權方式。授權碼模式的…

    編程 2025-04-24
  • 谷歌瀏覽器深色模式

    一、深色模式的概念 深色模式是一種日益流行的 UI 設計趨勢,通過使用暗灰色或黑色背景,大大降低了屏幕的亮度,更加舒適和護眼。深色模式也被稱為暗黑模式。 谷歌瀏覽器深色模式的推出可…

    編程 2025-04-24
  • 暗黑模式的盛行

    一、背景和定義 暗黑模式起源於智能手錶和夜視儀等專業設備上的配色方案,是指採用黑底白字、暗灰底白字等相對較暗的背景色搭配亮色前景,以減少屏幕對用戶眼睛的刺激,降低視覺疲勞感。這種設…

    編程 2025-04-24
  • 從多個方面詳細闡述MVC模式和三層架構

    一、MVC模式 MVC是Model-View-Controller的縮寫,是一種應用於軟件工程的設計模式。MVC模式將一個軟件應用分為三個基本部分:模型(Model)、視圖(Vie…

    編程 2025-04-24
  • 單例模式的作用

    一、概念解釋 1、單例模式是指一個類只允許存在一個實例對象,且該對象能被系統中其他模塊所共用。該模式主要解決了全局變量的問題,在同一時間只有一個實例被使用,避免了多次重複實例化造成…

    編程 2025-04-23

發表回復

登錄後才能評論