国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Pulsar:下一代消息引擎真的這么強嗎?

云計算
本文介紹了 Pulsar 的一些基本概念與優點,同時順便討論一下 Go 的依賴注入;如果大家和我們一樣在做技術選型,不妨考慮一下 Pulsar。

[[394573]]

背景

我們最近在做新業務的技術選型,其中涉及到了對消息中間件的選擇;結合我們的實際情況希望它能滿足以下幾個要求:

  • 友好的云原生支持:因為現在的主力語言是 Go,同時在運維上能夠足夠簡單。
  • 官方支持多種語言的 SDK:還有一些 Python、Java 相關的代碼需要維護。
  • 最好是有一些方便好用的特性,比如:延時消息、死信隊列、多租戶等。

當然還有一些水平擴容、吞吐量、低延遲這些特性就不用多說了,幾乎所有成熟的消息中間件都能滿足這些要求。

基于以上的篩選條件,Pulsar 進入了我們的視野。

作為 Apache 下的頂級項目,以上特性都能很好的支持。

下面我們來它有什么過人之處。

架構

從官方的架構圖中可以看出 Pulsar 主要有以下組件組成:

  1. Broker 無狀態組件,可以水平擴展,主要用于生產者、消費者連接;與 Kafka 的 broker 類似,但沒有數據存儲功能,因此擴展更加輕松。
  2. BookKeeper 集群:主要用于數據的持久化存儲。
  3. Zookeeper 用于存儲 broker 與 BookKeeper 的元數據。

整體一看似乎比 Kafka 所依賴的組件還多,這樣確實會提供系統的復雜性;但同樣的好處也很明顯。

Pulsar 的存儲于計算是分離的,當需要擴容時會非常簡單,直接新增 broker 即可,沒有其他的心智負擔。

當存儲成為瓶頸時也只需要擴容 BookKeeper,不需要人為的做重平衡,BookKeeper 會自動負載。

同樣的操作,Kafka 就要復雜的多了。

特性

多租戶

多租戶也是一個剛需功能,可以在同一個集群中對不同業務、團隊的數據進行隔離。

  1. persistent://core/order/create-order 

以這個 topic 名稱為例,在 core 這個租戶下有一個 order 的 namespace,最終才是 create-order 的 topic 名稱。

在實際使用中租戶一般是按照業務團隊進行劃分,namespace 則是當前團隊下的不同業務;這樣便可以很清晰的對 topic 進行管理。

通常有對比才會有傷害,在沒有多租戶的消息中間件中是如何處理這類問題的呢:

  1. 干脆不分這么細,所有業務線混著用,當團隊較小時可能問題不大;一旦業務增加,管理起來會非常麻煩。
  2. 自己在 topic 之前做一層抽象,但其實本質上也是在實現多租戶。
  3. 各個業務團隊各自維護自己的集群,這樣當然也能解決問題,但運維復雜度自然也就提高了。

以上就很直觀的看出多租戶的重要性了。

Function 函數計算

Pulsar 還支持輕量級的函數計算,例如需要對某些消息進行數據清洗、轉換,然后再發布到另一個 topic 中。

這類需求就可以編寫一個簡單的函數,Pulsar 提供了 SDK 可以方便的對數據進行處理,最后使用官方工具發布到 broker 中。

在這之前這類簡單的需求可能也需要自己處理流處理引擎。

應用

除此之外的上層應用,比如生產者、消費者這類概念與使用大家都差不多。

比如 Pulsar 支持四種消費模式:

  • Exclusive:獨占模式,同時只有一個消費者可以啟動并消費數據;通過 SubscriptionName 標明是同一個消費者),適用范圍較小。
  • Failover 故障轉移模式:在獨占模式基礎之上可以同時啟動多個 consumer,一旦一個 consumer 掛掉之后其余的可以快速頂上,但也只有一個 consumer 可以消費;部分場景可用。
  • Shared 共享模式:可以有 N 個消費者同時運行,消息按照 round-robin 輪詢投遞到每個 consumer 中;當某個 consumer 宕機沒有 ack 時,該消息將會被投遞給其他消費者。這種消費模式可以提高消費能力,但消息無法做到有序。
  • KeyShared 共享模式:基于共享模式;相當于對同一個topic中的消息進行分組,同一分組內的消息只能被同一個消費者有序消費。

第三種共享消費模式應該是使用最多的,當對消息有順序要求時可以使用 KeyShared 模式。

SDK

官方支持的 SDK 非常豐富;我也在官方的 SDK 的基礎之上封裝了一個內部使用的 SDK。

因為我們使用了 dig 這樣的輕量級依賴注入庫,所以使用起來大概是這個樣子:

  1. SetUpPulsar(lookupURL) 
  2. container := dig.New() 
  3. container.Provide(func() ConsumerConfigInstance { 
  4.  return NewConsumer(&pulsar.ConsumerOptions{ 
  5.   Topic:            "persistent://core/order/create-order"
  6.   SubscriptionName: "order-sub"
  7.   Type:             pulsar.Shared, 
  8.   Name:             "consumer01"
  9.  }, ConsumerOrder) 
  10.  
  11. }) 
  12.  
  13. container.Provide(func() ConsumerConfigInstance { 
  14.  return NewConsumer(&pulsar.ConsumerOptions{ 
  15.   Topic:            "persistent://core/order/update-order"
  16.   SubscriptionName: "order-sub"
  17.   Type:             pulsar.Shared, 
  18.   Name:             "consumer02"
  19.  }, ConsumerInvoice) 
  20.  
  21. }) 
  22.  
  23. container.Invoke(StartConsumer) 

其中的兩個 container.Provide() 函數用于注入 consumer 對象。

container.Invoke(StartConsumer) 會從容器中取出所有的 consumer 對象,同時開始消費。

這時以我有限的 Go 開發經驗也在思考一個問題,在 Go 中是否需要依賴注入?

先來看看使用 Dig 這類庫所帶來的好處:

  • 對象交由容器管理,很方便的實現單例。
  • 當各個對象之前依賴關系復雜時,可以減少許多創建、獲取對象的代碼,依賴關系更清晰。

同樣的壞處也有:

  • 跟蹤閱讀代碼時沒有那么直觀,不能一眼看出某個依賴對象是如何創建的。
  • 與 Go 所推崇的簡潔之道不符。

對于使用過 Spring 的 Java 開發者來說肯定直呼真香,畢竟還是熟悉的味道;但對于完全沒有接觸過類似需求的 Gopher 來說貌似也不是剛需。

目前市面上各式各樣的 Go 依賴注入庫層出不窮,也不乏許多大廠出品,可見還是很有市場的。

我相信有很多 Gopher 非常反感將 Java 中的一些復雜概念引入到 Go,但我覺得依賴注入本身是不受語言限制,各種語言也都有自己的實現,只是 Java 中的 Spring 不僅僅只是一個依賴注入框架,還有許多復雜功能,讓許多開發者望而生畏。

如果只是依賴注入這個細分需求,實現起來并不復雜,并不會給帶來太多復雜度。如果花時間去看源碼,在理解概念的基礎上很快就能掌握。

回到 SDK 本身來說,Go 的 SDK 現階段要比 Java 版本的功能少(準確來說只有 Java 版的功能最豐富),但核心的都有了,并不影響日常使用。

總結

 

本文介紹了 Pulsar 的一些基本概念與優點,同時順便討論一下 Go 的依賴注入;如果大家和我們一樣在做技術選型,不妨考慮一下 Pulsar。

 

責任編輯:武曉燕 來源: crossoverJie
相關推薦

2021-01-19 05:36:46

pulsar中間件消息

2013-07-27 21:28:44

2015-10-15 10:30:32

2013-02-20 09:56:17

互聯網移動通信網絡IPv6

2013-06-27 11:21:17

2021-04-01 09:01:57

lit-htmlJavaScript DOM API

2020-09-27 17:27:58

邊緣計算云計算技術

2011-12-28 21:03:58

iPhone

2020-09-16 10:28:54

邊緣計算云計算數據中心

2025-01-03 09:24:10

模型架構論文

2020-03-12 18:12:10

Google FuchAndroid移動應用

2010-03-12 09:37:22

軟交換機

2013-07-09 09:35:03

搜索引擎功能開發搜索

2016-01-26 11:58:12

2013-09-09 16:28:36

2018-09-25 07:00:50

2022-07-06 11:38:40

人工智能AI

2013-07-27 21:41:14

APT攻擊下一代威脅

2009-04-06 08:42:18

Firefox瀏覽器

2009-01-11 10:13:39

Stripes開發框架JSP
點贊
收藏

51CTO技術棧公眾號

色女孩综合网| 亚洲第一级黄色片| 丝袜美腿精品国产二区| www欧美xxxx| 亚洲精品一线二线三线无人区| 国产专区在线| 精品国产乱码久久久久久老虎| segui88久久综合9999| 爱福利视频一区| 欧美大片网址| 国产精品推荐精品| eeuss鲁片一区二区三区在线观看 eeuss影院一区二区三区 | 美女的尿口免费视频| 欧美性高潮在线| 精品123区| 亚洲国产美国国产综合一区二区| 人人九九精品| 日韩三级成人av网| 欧美天天综合| 一区视频二区视频| 中文字幕一区二区三区不卡在线| 国内三级在线观看| 韩剧1988在线观看免费完整版| 日本大片在线观看| 社区色欧美激情 | 一区二区91| 国产91大片| 国产精品久久久一本精品 | 欧美日韩一级二级| 亚洲尤物av| 杨幂毛片午夜性生毛片| 欧美成人aa大片| 国产精品大片| 91入口在线观看| 911精品国产| 久久久久se| 黄色亚洲免费| 宅男午夜电影| 91精品国产99| 国产精品久久久久四虎| 国模套图日韩精品一区二区| 亚洲高清av在线| 国产一区二区三区91| 人人爽人人av| 久久久久女教师免费一区| 国产69精品久久久久777| 美女免费久久| 秋霞久久久久久一区二区| 在线成人小视频| 日韩av二区在线播放| 伊人久久综合一区二区| 日b视频免费观看| 日韩资源在线观看| 久久精品欧美一区二区三区麻豆 | av一区二区三区在线观看| 亚洲第一伊人| 在线xxxx| 97精品国产97久久久久久春色| 久久久精品tv| 国产超碰精品| 白天操夜夜操| 日韩精品一区在线| 国产一区二区三区观看| 国精产品一区一区三区四川| 自拍日韩亚洲一区在线| 久久精品国产久精国产一老狼| 欧美日韩国产高清电影| 日本午夜精品一区二区| 中文字幕亚洲欧美日韩2019| 国产欧美日韩另类视频免费观看| 亚洲一区二区三区精品中文字幕 | 亚洲午夜精品在线| 免费视频一区二区三区在线观看| 日韩高清在线| 成年人在线观看| 久久久精品在线| 欧美视频一区二区三区…| 经典三级在线一区| 日韩国产91| a黄色片在线观看| 草裙成人精品一区二区三区| 日本一区二区三区视频在线播放| 久久综合久久八八| 美洲精品一卡2卡三卡4卡四卡| 九一国产精品视频| 国产区欧美区日韩区| 欧美精品www| 国产一区二区三区免费播放| 精品中文字幕一区二区三区四区| 九九九九精品| 国产精品主播视频| 亚洲婷婷国产精品电影人久久| 蜜桃av一区二区在线观看| 国产成人精品免费视| 福利精品一区| 欧美色片在线观看| 涩涩视频网站在线观看| 免费a级人成a大片在线观看| 免费激情网址| 四色成人av永久网址| 国产精品久久久久久久久久免费| 亚洲一区www| 亚洲精品黄网在线观看| 在线不卡免费av| 欧美三级乱人伦电影| 亚洲高清一区二区三区| 中文字幕在线免费不卡| 中文字幕乱码日本亚洲一区二区| 欧美成人ⅴideosxxxxx| 2021中文字幕在线| 不卡的av影片| 天天免费亚洲黑人免费| 欧美freesex| 欧美三级一区| 四虎影视精品| 在线免费91| 国产二区视频在线观看| 美女av网站| 视频国产在线观看| 先锋影音亚洲资源| 中文字幕第50页| 毛片av在线播放| 欧美黑人xxxⅹ高潮交| 久久成年人视频| 欧美最顶级的aⅴ艳星| 国产九九精品视频| 日韩精品无码一区二区三区| 视频一区二区三| 婷婷六月天在线| 欧美伦理影视网| 中文字幕一区久| 亚洲国产国产| 亚洲日本激情| 久久青草国产手机看片福利盒子| 精品国产一区二区三区久久久樱花 | 欧美日韩在线播放| aaa欧美色吧激情视频| 91丨porny丨中文| 久久久久美女| 成人污视频在线观看| 欧美精品自拍| 老司机亚洲精品一区二区| 北条麻妃一区二区三区在线观看| 小说区亚洲自拍另类图片专区| 日韩电影在线一区二区三区| 亚洲国产经典视频| 精品电影一区二区三区 | 日韩国产在线观看一区| 久久影院视频免费| 日韩午夜精品视频| 亚洲图片欧美激情| 日韩精品一区二区三区视频在线观看 | 日韩中文字幕无砖| 日本不卡一区二区| 亚洲高清中文字幕| 久久99精品久久久久久噜噜| 亚洲成人精品av| 国产一区二区丝袜| 成人拍拍拍免费视频网站| 91av在线免费播放| 少女频道在线观看高清 | 久久精品国产久精国产一老狼| 99视频国产精品免费观看| 日韩欧美xxxx| 亚洲第一会所001| 国内精品国产成人| 在线播放国产精品二区一二区四区| 国产精品香蕉av| 毛片中文在线观看| 少妇精品久久久一区二区三区| 日韩专区视频| 国产精品中文欧美| 日韩欧美国产一二三区| 欧美中文在线免费| 国产又黄又猛又粗又爽的视频| 日韩影片中文字幕| 国产**成人网毛片九色| 亚洲福利影片在线| 亚洲五码在线观看视频| 欧美6一10sex性hd| 国产精品一区二区久久不卡| 亚洲色图第一页| 欧美国产激情视频| 日韩第一区第二区| 一区二区三区中文免费| 91在线视频成人| 欧美精品videossex少妇| 国产一区二区在线免费观看| 中文字幕在线看视频国产欧美| 成人一区二区三| 欧美丰满老妇| 精品在线播放免费| 日韩中文娱乐网| 久草福利资源站| 91精品产国品一二三产区| 成人性色生活片| 91精品久久久久久久久| 黄色在线视频网站| 欧美国产精品v| 亚洲欧洲国产日韩精品|