日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

Go 事件驅動編程:實現一個簡單的事件總線

來源: 責編: 時間:2024-05-16 09:09:16 238觀看
導讀前言在當今微服務和分布式系統盛行的背景下,事件驅動架構(Event-Driven Architecture,EDA)扮演著一個至關重要的角色,此架構的設計使得服務間可以通過事件進行同步或異步通信,替代了傳統的直接接口調用。基于事件的交互方式

前言

在當今微服務和分布式系統盛行的背景下,事件驅動架構(Event-Driven Architecture,EDA)扮演著一個至關重要的角色,此架構的設計使得服務間可以通過事件進行同步或異步通信,替代了傳統的直接接口調用。基于事件的交互方式,促進了服務之間的松耦合,提高系統的可擴展性。vZ928資訊網——每日最新資訊28at.com

發布-訂閱模式是實現事件驅動架構的模式之一,它允許系統的不同組件或服務發布事件,而其他組件或服務可以訂閱這些事件并根據事件內容進行響應。相信大部分開發者都接觸過這一模式,常見的技術實現有消息隊列(MQ)和 Redis 發布/訂閱(PUB/SUB)功能等。vZ928資訊網——每日最新資訊28at.com

在 Go 語言中,我們可以利用其強大的 channel 和并發機制來實現發布-訂閱模式。本文將深入探討如何在 Go 中實現一個簡單的事件總線,這是發布-訂閱模式的具體實現。vZ928資訊網——每日最新資訊28at.com

準備好了嗎?準備一杯你最喜歡的咖啡或茶,隨著本文一探究竟吧。vZ928資訊網——每日最新資訊28at.com

事件總線

事件總線是發布-訂閱模式的具體實現,它作為發布者和訂閱者的中間件,管理著事件傳遞與分發,確保事件從發布者順利地傳達到訂閱者。vZ928資訊網——每日最新資訊28at.com

圖片圖片vZ928資訊網——每日最新資訊28at.com

vZ928資訊網——每日最新資訊28at.com

事件總線的優勢主要包括:vZ928資訊網——每日最新資訊28at.com

  • 解耦:服務間不需要直接通信,而是通過時間進行交互,減少服務間的依賴。
  • 異步處理:事件可以被異步處理,提高系統的響應性和性能。
  • 可擴展性:新的訂閱者可以輕松訂閱事件,不需要修改現有的發布者代碼。
  • 錯誤隔離:事件處理的失敗不會直接影響其他服務的正常運行。

事件總線的代碼實現

接下來將介紹如何在 Go 語言中實現一個簡單的事件總線,它包含以下關鍵功能:vZ928資訊網——每日最新資訊28at.com

  • 發布:允許系統的各個服務發送事件。
  • 訂閱:允許感興趣的服務訂閱接收特定類型的事件。
  • 取消訂閱:允許各個服務將本身已訂閱的事件刪除。

項目源碼地址:https://github.com/chenmingyong0423/go-eventbusvZ928資訊網——每日最新資訊28at.com

事件數據結構定義

type Event struct {    Payload any}

Event 是一個封裝事件的結構體,其中 Payload 為事件的上下文信息,類型是 any。vZ928資訊網——每日最新資訊28at.com

事件總線定義

type (    EventChan chan Event)type EventBus struct {    mu    sync.RWMutex    subscribers map[string][]EventChan}func NewEventBus() *EventBus {    return &EventBus{        subscribers: make(map[string][]EventChan),    }}

EventChan 是一個類型別名,定義為傳遞 Event 結構體的通道 chan Event。vZ928資訊網——每日最新資訊28at.com

EventBus 為事件總線的定義,它包含兩個屬性:vZ928資訊網——每日最新資訊28at.com

  • mu:一個讀寫互斥鎖(sync.RWMutex),用于保證下面 subscribers 的并發讀寫安全。
  • subscribers:一個映射,鍵為字符串類型,表示訂閱的主題;值為 EventChan 切片類型。該屬性用于存儲各個主體的所有訂閱者,每個訂閱者通過 EventChan 接收事件。

NewEventBus 函數用于創建一個新的 EventBus 事件總線。vZ928資訊網——每日最新資訊28at.com

事件總線的方法實現

事件總線實現了三個方法,分別為發布事件(Publish)和訂閱事件(Subscribe)以及取消訂閱事件(Unsubscribe)。vZ928資訊網——每日最新資訊28at.com

Publish 發布事件

func (eb *EventBus) Publish(topic string, event Event) {	eb.mu.RLock()	defer eb.mu.RUnlock()	// 復制一個新的訂閱者列表,避免在發布事件時修改訂閱者列表	subscribers := append([]EventChan{}, eb.subscribers[topic]...)	gofunc() {		for _, subscriber := range subscribers {			subscriber <- event		}	}()}

Publish 方法用于發布事件。該方法接收兩個參數:topic(主題)和 event (封裝事件的對象)。vZ928資訊網——每日最新資訊28at.com

在 Publish 方法的實現中,首先通過 mu 屬性獲取讀鎖,以確保接下來的 subscribers 寫操作是協程安全的。然后復制一份當前主題的訂閱者列表 subscribers。接下來開啟一個新 goroutine,在這個 goroutine 中遍歷復制的訂閱者列表,將事件通過通道發送給所有訂閱者。完成這些操作后,釋放讀鎖。vZ928資訊網——每日最新資訊28at.com

為什么會復制一個新的訂閱者列表?vZ928資訊網——每日最新資訊28at.com

答:復制訂閱者列表是為了在發送事件時保持數據的一致性和穩定性。由于向通道發送數據的操作是在一個新的 goroutine 中進行的,在發送數據時,讀鎖已經被釋放,原來的訂閱者列表可能會由于添加或刪除訂閱者而發生變化。如果直接使用原來的訂閱者列表,可能會發生預料之外的錯誤(如向一個已經關閉的通道發送數據會產生 panic)。vZ928資訊網——每日最新資訊28at.com

Subscribe 訂閱事件

func (eb *EventBus) Subscribe(topic string) EventChan {	eb.mu.Lock()	defer eb.mu.Unlock()	ch := make(EventChan)	eb.subscribers[topic] = append(eb.subscribers[topic], ch)	return ch}

Subscribe 方法用于訂閱特定主題的事件。該方法有接收一個 topic 參數,表示希望訂閱的主題。通過此方法,可以獲得一個 EventChan 通道,用于接收該主題的事件。vZ928資訊網——每日最新資訊28at.com

在 Subscribe 方法的實現中,首先通過 mu 屬性獲取寫鎖,以保證接下來的 subscribers 讀寫操作是協程安全的;接著創建一個新的 EventChan 通道 ch,將其添加到相應主題的訂閱者切片中。完成這些操作后,釋放寫鎖。vZ928資訊網——每日最新資訊28at.com

Unsubscribe 取消訂閱事件

func (eb *EventBus) Unsubscribe(topic string, ch EventChan) {	eb.mu.Lock()	defer eb.mu.Unlock()	if subscribers, ok := eb.subscribers[topic]; ok {		for i, subscriber := range subscribers {			if ch == subscriber {				eb.subscribers[topic] = append(subscribers[:i], subscribers[i+1:]...)				close(ch)				// 清空通道				forrange ch {				}				return			}		}	}}

Unsubscribe 方法用于取消訂閱事件。該方法接收兩個參數:topic(已訂閱的主題)和 ch(被頒發的通道)。vZ928資訊網——每日最新資訊28at.com

在 Unsubscribe 方法里,首先通過 mu 屬性獲取寫鎖,以保證接下來的 subscribers 讀寫操作是協程安全的;然后檢查 topic 主題是否存在對應的訂閱者。如果存在,遍歷該主題的訂閱者切片,找到與 ch 相匹配的通道,將其從訂閱者切片里移除并關閉該通道。然后清空通道。完成這些操作后,釋放寫鎖。vZ928資訊網——每日最新資訊28at.com

使用示例

// https://github.com/chenmingyong0423/blog/blob/master/tutorial-code/go/eventbus/main.gopackage mainimport (	"fmt"	"time"	"github.com/chenmingyong0423/go-eventbus")func main() {	eventBus := eventbus.NewEventBus()	// 訂閱 post 主題事件	subscribe := eventBus.Subscribe("post")	gofunc() {		for event := range subscribe {			fmt.Println(event.Payload)		}	}()	eventBus.Publish("post", eventbus.Event{Payload: map[string]any{		"postId": 1,		"title":  "Go 事件驅動編程:實現一個簡單的事件總線",		"author": "陳明勇",	}})	// 不存在訂閱者的 topic	eventBus.Publish("pay", eventbus.Event{Payload: "pay"})	time.Sleep(time.Second * 2)	// 取消訂閱 post 主題事件	eventBus.Unsubscribe("post", subscribe)}

擴展建議

本文實現的事件總線較為簡單,如果要增強時間總線的靈活性,可靠性和易用性等方面,我們可以考慮擴展它,以下是一些建議:vZ928資訊網——每日最新資訊28at.com

  • 事件持久化:實現時間的持久化存儲功能,確保系統崩潰后可以恢復未處理的事件。
  • 通配符和模式匹配訂閱:允許使用通配符或正則表達式來訂閱一組相關主題,而不是單個具體的主題。
  • 負載均衡和消息分發策略:在多個訂閱者之間分配事件,實現負載均衡。
  • 插件支持:支持通過插件來擴展功能,如日志記錄、消息過濾、轉換等。

小結

本文深入探討了在 Go 語言中實現簡單事件總線的過程。通過利用 Go 語言的強大特性,如 channel 和并發機制,我們可以輕松地實現發布-訂閱模式。vZ928資訊網——每日最新資訊28at.com

文章從事件總線的優勢開始,介紹了其解耦、異步處理、可擴展性和錯誤隔離等特點。然后詳細解釋了如何定義事件數據結構和事件總線結構,并實現了發布、訂閱和取消訂閱事件的方法。最后,提出了一些可能的擴展方向,如事件持久化、通配符訂閱、負載均衡和插件支持,以增強事件總線的靈活性和功能性。vZ928資訊網——每日最新資訊28at.com

通過閱讀本文,你可以學會在 Go 語言中實現一個簡單但功能強大的事件總線,并根據可能的需求進行擴展。vZ928資訊網——每日最新資訊28at.com

★項目源碼地址:https://github.com/chenmingyong0423/go-eventbusvZ928資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-88374-0.htmlGo 事件驅動編程:實現一個簡單的事件總線

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 要不要升級?Java 21強大的新特性,代碼量減半

下一篇: 剖析 Figma 圖形對象的基本屬性

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
免费在线观看成人av| 久久精品水蜜桃av综合天堂| 亚洲黄网站在线观看| 亚洲国产精品久久久久婷婷884| 亚洲人成欧美中文字幕| 一区二区三区波多野结衣在线观看| 亚洲视频专区在线| 欧美一区免费视频| 欧美激情久久久久久| 国产精品久久久久天堂| 一区在线观看视频| 9人人澡人人爽人人精品| 午夜激情综合网| 嫩草国产精品入口| 国产精品国产馆在线真实露脸| 国产一区二区日韩| 亚洲美女中文字幕| 国产精品久久久久久久久久三级 | 国产精品美女视频网站| 极品尤物av久久免费看| 一本色道久久| 久久青草久久| 国产精品国产亚洲精品看不卡15| 国内精品国语自产拍在线观看| 亚洲全部视频| 欧美在线一区二区| 欧美午夜电影一区| 影音先锋国产精品| 亚洲欧美精品suv| 欧美电影资源| 国产一区二区三区黄| 99国产精品久久久久久久成人热| 久久精品女人天堂| 国产精品乱码妇女bbbb| 亚洲人成在线观看| 久久深夜福利免费观看| 国产精品视频1区| 亚洲美女淫视频| 久久婷婷色综合| 国产精品人成在线观看免费 | 欧美体内she精视频在线观看| 很黄很黄激情成人| 亚洲女同性videos| 欧美理论电影在线观看| 亚洲成人在线网站| 欧美伊人久久| 国产精品福利在线观看网址| 亚洲国产日韩一区二区| 久久久精品视频成人| 国产精品一区二区久久精品 | 久久aⅴ国产紧身牛仔裤| 国产精品xxxxx| 亚洲精品视频免费观看| 久久婷婷久久| 国产亚洲精品久久久| 亚洲一区国产视频| 欧美日韩精品一本二本三本| 亚洲国产精品悠悠久久琪琪 | 国产欧美日韩综合一区在线观看| 日韩一级视频免费观看在线| 男人天堂欧美日韩| 在线观看成人av电影| 久久国产黑丝| 国产视频不卡| 性一交一乱一区二区洋洋av| 国产精品久久久久久av下载红粉| 99视频一区二区三区| 欧美高潮视频| 亚洲欧洲精品一区二区三区不卡| 久久婷婷成人综合色| 国产一区二区三区久久悠悠色av | 欧美日韩亚洲综合在线| 日韩一级黄色av| 欧美女激情福利| av成人免费在线观看| 欧美久久99| 亚洲美女av在线播放| 欧美黑人一区二区三区| 最新国产の精品合集bt伙计| 欧美ed2k| 亚洲人成啪啪网站| 欧美黑人在线播放| 亚洲精品美女久久久久| 欧美了一区在线观看| 99re热这里只有精品视频 | 依依成人综合视频| 麻豆精品网站| 亚洲国产一区二区在线| 久久精品国产999大香线蕉| 国产精品永久免费| 一区二区在线视频| 久久久www成人免费无遮挡大片| 国内自拍亚洲| 国产精品日本| 欧美精品一区在线播放| 欧美一区二区三区免费观看| 久久国产精品久久久| 亚洲免费成人av电影| 亚洲国产欧美不卡在线观看| 亚洲国产精品尤物yw在线观看| 国产欧美在线| 国产欧美一区二区精品秋霞影院| 国产欧美日韩综合一区在线播放| 欧美经典一区二区三区| 欧美成人免费在线| 美女国产精品| 欧美日产在线观看| 黄网动漫久久久| 亚洲精品小视频在线观看| 久久大逼视频| 欧美日韩一区二区在线播放| 亚洲大片av| 性亚洲最疯狂xxxx高清| 亚洲视频你懂的| 久久久久国产精品午夜一区| 尹人成人综合网| 欧美电影免费观看网站| 99国产精品久久久久久久| 欧美亚洲第一页| 久久国内精品自在自线400部| 精品动漫3d一区二区三区| 欧美高清视频一区二区| 亚洲午夜国产成人av电影男同| 夜色激情一区二区| 老司机精品福利视频| 久久一区精品| 免费看亚洲片| 国产精品久在线观看| 亚洲人成在线播放网站岛国| 久久久福利视频| 国产一区欧美| 老牛影视一区二区三区| 亚洲国产另类久久久精品极度| 欧美高清在线播放| 欧美高清你懂得| 国产精品久久久久77777| 久久狠狠亚洲综合| 亚洲精品久久久蜜桃| 国产精品每日更新在线播放网址| 久久精品综合一区| 日韩视频一区二区三区在线播放 | 久久国产手机看片| 亚洲精品在线视频观看| 国产精品揄拍一区二区| 女女同性女同一区二区三区91| 亚洲一区区二区| 亚洲黄色一区| 国产一区观看| 国产精品国产三级国产aⅴ9色 | 国产美女精品视频免费观看| 欧美gay视频激情| 先锋影音网一区二区| 亚洲精品乱码久久久久久黑人| 国产日本欧洲亚洲| 欧美欧美天天天天操| 久久久噜噜噜久久久| 亚洲视频图片小说| 亚洲国产精品欧美一二99| 国产日韩精品久久| 欧美色区777第一页| 欧美高清视频一区二区| 久久久久久穴| 新67194成人永久网站| 在线视频欧美一区| 亚洲欧洲中文日韩久久av乱码| 好看不卡的中文字幕| 国产精品区二区三区日本| 欧美日本二区| 免费高清在线视频一区·| 欧美在线免费观看| 亚洲一区视频| 一区二区日韩精品| 亚洲人体一区| 亚洲国产精品久久久久婷婷老年| 国产午夜精品美女视频明星a级| 欧美午夜在线一二页| 欧美日韩另类视频| 欧美激情国产日韩| 欧美阿v一级看视频| 久久综合久久久久88| 久久久精品日韩欧美| 欧美在线日韩精品| 午夜精品久久久| 亚洲欧美韩国| 亚洲主播在线观看| 亚洲天堂免费在线观看视频| 亚洲美女中文字幕| 亚洲精品乱码久久久久久久久 | 国产精品私拍pans大尺度在线 | 亚洲精品视频免费| 亚洲国产精品久久人人爱蜜臀| 国内伊人久久久久久网站视频 | 在线观看欧美日韩国产| 国内不卡一区二区三区| 国产一区二区三区不卡在线观看| 国产精品一区二区你懂得| 国产精品久久久久久久久久直播| 欧美系列亚洲系列| 国产精品第2页| 国产精品久久久久久福利一牛影视| 欧美日韩一区自拍| 欧美视频免费看| 国产精品v片在线观看不卡| 欧美性做爰毛片|