OASIS Mailing List ArchivesView the OASIS mailing list archive below
or browse/search using MarkMail.

 


Help: OASIS Mailing Lists Help | MarkMail Help

mqtt message

[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]


Subject: [OASIS Issue Tracker] (MQTT-234) Shared Subscriptions


Andrew Banks created MQTT-234:
---------------------------------

             Summary: Shared Subscriptions
                 Key: MQTT-234
                 URL: https://issues.oasis-open.org/browse/MQTT-234
             Project: OASIS Message Queuing Telemetry Transport (MQTT) TC
          Issue Type: New Feature
          Components: futures
    Affects Versions: 3.1.1
            Reporter: Andrew Banks


Shared Subscriptions
--------------------

Shared subscriptions allow a set of clients to share the consumption of messages
produced in response to a subscription. The set of subscribers is created by the use
of a common share name. Shared subscriptions provide a facility similar to point to 
point messaging in that the processing of messages is not limited to the availability 
or capacity of a single consumer, the share name is analogous to the queue name in 
that it names the list of messages to be processed.


I suggest that a shared subscription be defined by the topic filter syntax:

  $share:shareName:topicFilter

- This specialised topic filter takes the place of the normal topic filter in the 
  subscribe packet. 
- The "$share:" prefix uses a reserved $ name and will therefore not cause a conflict
  with other topic filters.
- shareName is a string which labels the shared subscription and must not contain any 
  ":" characters.
- TopicFilter follows the existing topic filter rules.
- Subscribing clients will be a member of the share only if both the shareName and
  topicFilter are identical. So, a different shareName with the same topicFiler 
  will create a different share. Similarly a shareName followed by a different topic
  filter will create separate share.
- Servers may decline to support shared subscriptions by not accepting subscribe
  packets containing topic filters starting with the "$share:" prefix. However, if 
  they do accept the "$share:" prefix they must follow this definition.
- The subscribing clients may make both non durable and durable subscriptions by 
  setting clean session true or false. The shared subscription ceases to exist if    
  the number of clients subscribed to it reaches zero. If the shared subscription
  ceases to exist the messages queued for processing are deleted by the server as 
  with an non shared subscription.
- A good server implementation will avoid allocating messages to subscribers with 
  durable subscriptions while the client is disconnected. Instead the messages will be 
  allocated when a suitable client connects. 
- A Qos=1 message should be reallocated to another client sharing the same subscription
  if the network connection to the client is lost before the PUBACK is received.
  Qos=0 and Qos=2 messages must not be reallocated. 




--
This message was sent by Atlassian JIRA
(v6.2.2#6258)


[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]