真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

Pulsar消息概念2

1 主題
主題名稱結構的URL:
{persistent|non-persistent}://tenant/namespace/topic

創(chuàng)新互聯(lián)主營銀川網站建設的網絡公司,主營網站建設方案,成都App定制開發(fā),銀川h5重慶小程序開發(fā)搭建,銀川網站營銷推廣歡迎銀川等地區(qū)企業(yè)咨詢

名稱組成說明
persistent / non-persistent 持久和非持久
tenant 租戶
namespace 命名空間 主題的管理單元,用作相關主題的分組機制。大多數(shù)主題配置是在命名空間級別執(zhí)行的。每個租戶可以有多個命名空間
topic 名字的最后一部分

無需顯式創(chuàng)建新主題
你不需要在Pulsar中顯式地創(chuàng)建主題。如果客戶端嘗試向尚未存在的主題寫入消息或接收消息,則Pulsar將自動在主題名稱中提供的命名空間下創(chuàng)建該主題

2 命名空間
名稱空間是租戶中的邏輯術語。租戶可以通過管理API創(chuàng)建多個名稱空間。例如,具有不同應用程序的租戶可以為每個應用程序創(chuàng)建單獨的命名空間。命名空間允許應用程序創(chuàng)建和管理主題的層次結構。主題my tenant/app1是我的租戶的應用程序app1的命名空間??梢栽诿臻g下創(chuàng)建任意數(shù)量的主題

3 訂閱模式
Pulsar有三種訂閱模式:獨占(exclusive),共享(shared),故障轉移(failover)
獨占模式是默認訂閱模式
共享模式的局限性
使用共享模式時有兩件重要的事情需要注意:
無法保證消息排序。
不能將累積確認與共享模式一起使用。
4 密鑰共享(Key_shared)
在密鑰共享模式下,多個消息者可以同一訂閱
密鑰共享模式的限制
在使用密鑰共享模式時,有兩件重要的事情需要注意:
您需要為消息指定密鑰或orderingKey
不能將累積確認與密鑰共享模式一起使用
密鑰共享訂閱是一個測試版功能。您可以在broker.config禁用它(Pulsar 2.4.1)

5 多主題訂閱
從Pulsar 1.23.0版開始,Pulsar用戶可以同時訂閱多個主題,兩種方式
1)基于正則表達式(regex),例如persistent://public/default/finance-*
2)通過明確定義的topic列表
當通過regex訂閱多個主題時,所有主題必須位于同一命名空間中

不能保證順序性
當消費者訂閱多個主題時,Pulsar通常就單個主題提供的所有訂購保證都不成立。如果您的Pulsar用例涉及任何嚴格的訂購要求,我們強烈建議您不要使用此功能
下面是一些Java的多主題訂閱示例:
import java.util.regex.Pattern;

import org.apache.pulsar.client.api.Consumer;
import org.apache.pulsar.client.api.PulsarClient;

PulsarClient pulsarClient = // Instantiate Pulsar client object

// Subscribe to all topics in a namespace
Pattern allTopicsInNamespace = Pattern.compile("persistent://public/default/.*");
Consumer allTopicsConsumer = pulsarClient.newConsumer()
.topicsPattern(allTopicsInNamespace)
.subscriptionName("subscription-1")
.subscribe();

// Subscribe to a subsets of topics in a namespace, based on regex
Pattern someTopicsInNamespace = Pattern.compile("persistent://public/default/foo.*");
Consumer someTopicsConsumer = pulsarClient.newConsumer()
.topicsPattern(someTopicsInNamespace)
.subscriptionName("subscription-1")
.subscribe();

6分區(qū)主題
分區(qū)topic和普通topic,對于訂閱模式如何工作,沒有任何不同。分區(qū)只是決定了從生產者生產消息到消費者處理及確認消息過程中發(fā)生的事情。
分區(qū)topic需要通過admin API指定創(chuàng)建。創(chuàng)建的時候可以指明分區(qū)的數(shù)量。
路由模式

模式說明
RoundRobinPartition 如果沒有提供密鑰,則生產者將以循環(huán)方式發(fā)布所有分區(qū)上的消息,以實現(xiàn)最大吞吐量。請注意,循環(huán)調度不是針對單個消息執(zhí)行的,而是設置為批處理延遲的相同邊界,以確保批處理有效。如果在消息上指定了密鑰,則分區(qū)的生產者將散列該密鑰并將消息分配給特定的分區(qū)。這是默認模式。
SinglePartition 如果沒有提供密鑰,生產者將隨機選擇一個單獨的分區(qū)并將所有消息發(fā)布到該分區(qū)中。如果在消息上指定了密鑰,則分區(qū)的生產者將散列該密鑰并將消息分配給特定的分區(qū)。
CustomPartition 使用將被調用的自定義消息路由器實現(xiàn)來確定特定消息的分區(qū)。用戶可以通過使用Java客戶端并實現(xiàn)MessageRouter接口來創(chuàng)建自定義路由模式。

消息順序
消息的順序與消息路由模式和消息密鑰有關。通常,用戶需要按密鑰分區(qū)保證排序。
如果消息附加了密鑰,則在使用SinglePartition或RoundRobinPartition模式時,將根據(jù)哈希方案將消息路由到相應的分區(qū)

順序規(guī)則說明路由模式和key
按key分發(fā)(Per-key-partition) 所有具有相同key的消息都將按順序排列并放置在同一個分區(qū)中。 使用SinglePartition或RoundRobinPartition模式,每個消息都提供key
按生產者分發(fā)(Per-producer) 來自同一個生產者的所有消息都將按順序排列 使用SinglePartition模式,并且沒有為每個消息提供key

7 非持久性主題
格式如下:
non-persistent://tenant/namespace/topic
生產者和消費者可以以與持久主題相同的方式連接到非持久主題,關鍵的區(qū)別在于主題名稱必須以非持久主題開頭。所有三種訂閱模式(獨占、共享和故障轉移)都支持非持久性主題。
客戶端API
PulsarClient client = PulsarClient.builder()
.serviceUrl("pulsar://localhost:6650")
.build();
String npTopic = "non-persistent://public/default/my-topic";
String subscriptionName = "my-subscription-name";
消費
Consumer consumer = client.newConsumer()
.topic(npTopic)
.subscriptionName(subscriptionName)
.subscribe();
生產
Producer producer = client.newProducer()
.topic(npTopic)
.create();
8 消息保留和過期
默認情況下,Pulsar消息服務器
立即刪除消費者已確認的所有消息,以及
將所有未確認的消息持久存儲在消息待辦事項中。
但是,Pulsar有兩個特性,使您能夠覆蓋此默認行為:
消息保留使您能夠存儲已由消費者確認的消息
消息過期使您能夠為尚未確認的消息設置生存時間(TTL)

9 消息去重
當消息被Pulsar持久化多于一次的時候,會發(fā)生數(shù)據(jù)重復。消息去重是Pulsar可選的特性,阻止不必要的消息重復,每條消息僅處理一次


網頁名稱:Pulsar消息概念2
分享URL:http://weahome.cn/article/jpcjee.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部