-
Type:
Improvement
-
Status:
Closed
-
Priority:
Major
-
Resolution:
Fixed
-
Affects Version/s:
3.1.1
-
-
-
-
Proposal:
Hide
WD11 1232 - 1254
Remove existing content in this section and replace with:
When a Client reconnects with CleanSession = 0, both the client and server MUST redeliver any previous
in-flight messages. This means re-sending any unacknowledged PUBLISH packets (where QoS > 0) and PUBREL packets.
This is the only circumstance where a Client or Server is REQUIRED to redeliver messages.
Clients MAY resend SUBSCRIBE and UNSUBSCRIBE packets on reconnect but are not REQUIRED to do this.
While a modern TCP network is unlikely to lose packets, a Client or Server is permitted to attempt redelivery
at other times. However, redelivery is not encouraged unless a network failure has been detected.
Non-normative comment
Historically retransmission of Control Packets was required to overcome data loss on some older TCP networks.
This might remain a concern where MQTT 3.1.1 implementations are to be deployed in such environments.
Show
WD11 1232 - 1254
Remove existing content in this section and replace with:
When a Client reconnects with CleanSession = 0, both the client and server MUST redeliver any previous
in-flight messages. This means re-sending any unacknowledged PUBLISH packets (where QoS > 0) and PUBREL packets.
This is the only circumstance where a Client or Server is REQUIRED to redeliver messages.
Clients MAY resend SUBSCRIBE and UNSUBSCRIBE packets on reconnect but are not REQUIRED to do this.
While a modern TCP network is unlikely to lose packets, a Client or Server is permitted to attempt redelivery
at other times. However, redelivery is not encouraged unless a network failure has been detected.
Non-normative comment
Historically retransmission of Control Packets was required to overcome data loss on some older TCP networks.
This might remain a concern where MQTT 3.1.1 implementations are to be deployed in such environments.
WD08 (section 4.3) states that if no response is received from PUBLISH, PUBREL, SUBSCRIBE, UNSUBSCRIBE within a reasonable period of time then the sender may retry delivery.
This attempts to cater for unreliable TCP/IP networks. Since modern compliant TCP/IP networks should not lose packets, then the sender should not retry unless a network failure is detected.
The spec should be changed to reflect this and add non-normative content to describe the historical problem.
{"report":{"apdex":0.5,"isInitial":true,"journeyId":"f39f72dc-a715-408f-882d-221e5541b5e5","key":"jira.project.issue.view-issue","navigationType":0,"readyForUser":1146.5,"redirectCount":0,"resourceLoadedEnd":1823.9000000953674,"resourceLoadedStart":521.7999997138977,"resourceTiming":[{"duration":252.40000009536743,"initiatorType":"link","name":"https://issues.oasis-open.org/s/3edeca31ab9ba77980aae0809fbe7121-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/0a4716d29b2d5b1bdcdb168b4efc119e/_/download/contextbatch/css/_super/batch.css","startTime":521.7999997138977,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":521.7999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":774.1999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":252.40000009536743,"initiatorType":"link","name":"https://issues.oasis-open.org/s/7d2823769c2e7b66e860863fe879b7f8-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/9aebb1c0aaa4c36289529757ec9dbb54/_/download/contextbatch/css/project.issue.navigator,jira.view.issue,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&richediton=true","startTime":522.0999999046326,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":522.0999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":774.5,"responseStart":0,"secureConnectionStart":0},{"duration":252.7999997138977,"initiatorType":"link","name":"https://issues.oasis-open.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/8.0.5/_/download/batch/com.atlassian.auiplugin:split_aui.pattern.label/com.atlassian.auiplugin:split_aui.pattern.label.css","startTime":522.4000000953674,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":522.4000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":775.1999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":252.90000009536743,"initiatorType":"link","name":"https://issues.oasis-open.org/s/645acc233eb869f48a571293b8358a7d-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/1.0/_/download/batch/jira.webresources:global-static-adgs/jira.webresources:global-static-adgs.css","startTime":522.5999999046326,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":522.5999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":775.5,"responseStart":0,"secureConnectionStart":0},{"duration":253,"initiatorType":"link","name":"https://issues.oasis-open.org/s/a0dd6509771c1de0667aae5429c04cda-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/1.0/_/download/batch/jira.webresources:global-static/jira.webresources:global-static.css","startTime":522.6999998092651,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":522.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":775.6999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":303,"initiatorType":"script","name":"https://issues.oasis-open.org/s/e5479157e7a0c08b005e6522f2f04104-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/0a4716d29b2d5b1bdcdb168b4efc119e/_/download/contextbatch/js/_super/batch.js?locale=en-US","startTime":523,"connectEnd":523,"connectStart":523,"domainLookupEnd":523,"domainLookupStart":523,"fetchStart":523,"redirectEnd":0,"redirectStart":0,"requestStart":523,"responseEnd":826,"responseStart":826,"secureConnectionStart":523},{"duration":315.59999990463257,"initiatorType":"script","name":"https://issues.oasis-open.org/s/83514d5d4e8543747b02042eafcdc99c-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/9aebb1c0aaa4c36289529757ec9dbb54/_/download/contextbatch/js/project.issue.navigator,jira.view.issue,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en-US&richediton=true","startTime":523.5,"connectEnd":523.5,"connectStart":523.5,"domainLookupEnd":523.5,"domainLookupStart":523.5,"fetchStart":523.5,"redirectEnd":0,"redirectStart":0,"requestStart":523.5,"responseEnd":839.0999999046326,"responseStart":839.0999999046326,"secureConnectionStart":523.5},{"duration":317.5,"initiatorType":"script","name":"https://issues.oasis-open.org/s/70bb2263e59e7e1f04fbd137c80b895b-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/aae1242f5fc81cc6a5bb8bc963ccda29/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en-US","startTime":523.7999997138977,"connectEnd":523.7999997138977,"connectStart":523.7999997138977,"domainLookupEnd":523.7999997138977,"domainLookupStart":523.7999997138977,"fetchStart":523.7999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":523.7999997138977,"responseEnd":841.2999997138977,"responseStart":841.2999997138977,"secureConnectionStart":523.7999997138977},{"duration":317.8999996185303,"initiatorType":"script","name":"https://issues.oasis-open.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":523.9000000953674,"connectEnd":523.9000000953674,"connectStart":523.9000000953674,"domainLookupEnd":523.9000000953674,"domainLookupStart":523.9000000953674,"fetchStart":523.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":523.9000000953674,"responseEnd":841.7999997138977,"responseStart":841.7999997138977,"secureConnectionStart":523.9000000953674},{"duration":318,"initiatorType":"script","name":"https://issues.oasis-open.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":524.0999999046326,"connectEnd":524.0999999046326,"connectStart":524.0999999046326,"domainLookupEnd":524.0999999046326,"domainLookupStart":524.0999999046326,"fetchStart":524.0999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":524.0999999046326,"responseEnd":842.0999999046326,"responseStart":842.0999999046326,"secureConnectionStart":524.0999999046326},{"duration":318.1000003814697,"initiatorType":"script","name":"https://issues.oasis-open.org/s/cda37faab827dbdf305de8efe8282062-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/8.0.5/_/download/batch/com.atlassian.auiplugin:split_aui.pattern.label/com.atlassian.auiplugin:split_aui.pattern.label.js?locale=en-US","startTime":524.2999997138977,"connectEnd":524.2999997138977,"connectStart":524.2999997138977,"domainLookupEnd":524.2999997138977,"domainLookupStart":524.2999997138977,"fetchStart":524.2999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":524.2999997138977,"responseEnd":842.4000000953674,"responseStart":842.4000000953674,"secureConnectionStart":524.2999997138977},{"duration":318.5,"initiatorType":"link","name":"https://issues.oasis-open.org/s/07245784f53abc49bad9d9d4d36c577a-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/cadc4f20cc5c138dee060d42cf85f220/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":524.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":524.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":843,"responseStart":0,"secureConnectionStart":0},{"duration":318.30000019073486,"initiatorType":"script","name":"https://issues.oasis-open.org/rest/api/1.0/shortcuts/803004/a29179d70fa8562374ee16707692af77/shortcuts.js?context=issuenavigation&context=issueaction","startTime":524.5999999046326,"connectEnd":524.5999999046326,"connectStart":524.5999999046326,"domainLookupEnd":524.5999999046326,"domainLookupStart":524.5999999046326,"fetchStart":524.5999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":524.5999999046326,"responseEnd":842.9000000953674,"responseStart":842.9000000953674,"secureConnectionStart":524.5999999046326},{"duration":292.40000009536743,"initiatorType":"link","name":"https://issues.oasis-open.org/s/f77fd89aa211a76b20e9b0e63564383c-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/4a9288299d147101bf66484f4be48925/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-jira.view.issue,-project.issue.navigator/batch.css?jira.create.linked.issue=true&richediton=true","startTime":551.0999999046326,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":551.0999999046326,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":843.5,"responseStart":0,"secureConnectionStart":0},{"duration":292.6000003814697,"initiatorType":"script","name":"https://issues.oasis-open.org/s/41525c48ddceeb9b11e54085268fc285-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/4a9288299d147101bf66484f4be48925/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-jira.view.issue,-project.issue.navigator/batch.js?jira.create.linked.issue=true&locale=en-US&richediton=true","startTime":551.2999997138977,"connectEnd":551.2999997138977,"connectStart":551.2999997138977,"domainLookupEnd":551.2999997138977,"domainLookupStart":551.2999997138977,"fetchStart":551.2999997138977,"redirectEnd":0,"redirectStart":0,"requestStart":551.2999997138977,"responseEnd":843.9000000953674,"responseStart":843.9000000953674,"secureConnectionStart":551.2999997138977},{"duration":528.5,"initiatorType":"script","name":"https://issues.oasis-open.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/nu8zej/803004/aeedb5937bed650f2f0cc4ec9ceaa5d3/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":560.6999998092651,"connectEnd":560.6999998092651,"connectStart":560.6999998092651,"domainLookupEnd":560.6999998092651,"domainLookupStart":560.6999998092651,"fetchStart":560.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":560.6999998092651,"responseEnd":1089.1999998092651,"responseStart":1089.1999998092651,"secureConnectionStart":560.6999998092651}],"threshold":1000,"fetchStart":0,"domainLookupStart":414,"domainLookupEnd":414,"connectStart":414,"connectEnd":463,"secureConnectionStart":439,"requestStart":463,"responseStart":514,"responseEnd":581,"domLoading":517,"domInteractive":1868,"domContentLoadedEventStart":1868,"domContentLoadedEventEnd":1917,"domComplete":2253,"loadEventStart":2253,"loadEventEnd":2255,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[],"measures":[],"correlationId":"5e05b77577072b","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":89,"dbReadsTimeInMs":12,"dbConnsTimeInMs":14,"applicationHash":"4d4040e0714d65b7fffa4801569d014c0b16eaa9","experiments":[]}}
I've always thought this was more of a problem when a connection is re-established after network failure - were the first thing a client should do is retry delivery of failed stuff. I've never been too clear if that include SUBSCRIBE and UNSUBSCRIBE...