Wie viele Zeichen passen in eine 32KB PubNub-Nachricht?

PubNub Developer Relations - Feb 21 - - Dev Community

Die maximale Länge einer PubNub-Nachricht beträgt 32KB (siehe: PubNub SDK docs und PubNub soft and hard limits). Wenn sie mehr als 32KB groß ist, wird Ihre Nachricht nicht zugestellt. Aber wie sehen 32KB für eine Nachricht wirklich aus? Wenn Sie eine IoT-basierte Lösung aufbauen, machen Sie sich wahrscheinlich nicht allzu viele Gedanken über die Nachrichtengröße. Wahrscheinlich senden Sie nur kurze Aktualisierungsinformationen, wie Längen- und Breitengrad für Geolokalisierungszwecke, Temperatur- oder Sensordaten für eingebettete Systeme oder kurze Anweisungen zur Steuerung von Lampen oder anderen intelligenten Geräten. Ebenso passen Leaderboards für groß angelegte Online-Spiele in Echtzeit problemlos in 32 KB. Aber es gibt viele Anwendungsfälle, die mehr Informationen in einer einzigen PubNub-Nachricht erfordern. Denken Sie an Chat-Nachrichten oder Analysen eines kognitiven Dienstes. In diesem Beitrag werden wir eine Chat-Nachricht als Beispiel verwenden.

Machen wir ein paar Berechnungen

Um die Gesamtgröße eines Payloads zu ermitteln, müssen wir zunächst definieren, wie eine Chat-Nachricht aussehen könnte. Eine Chat-Nachricht für unsere Berechnungszwecke umfasst die gesamte Nutzlast: den Kanal, alle Seitenkanalinformationen und den eigentlichen Text. Wenn sie von PubNub verpackt wird, enthält sie auch Umschlaginformationen, einschließlich des Zeitstempels (timetoken) und anderer Kontrollinformationen, die für das Routing benötigt werden. Die Nachricht, die Sie von einem Client veröffentlichen, könnte etwa so aussehen:

var channel = "doc_patient_comms_a";
var message = {
    "name" : "Dr. Blackwell",
    "company" : "Sunnydale Memorial",
    "uuid" : "uuid-string",
    "text" : "Your test results are back and everything looks normal."
};
Enter fullscreen mode Exit fullscreen mode

Um die Größe der Nachricht zu berechnen, kombinieren Sie den Kanalnamen und die Nutzlast (JSON), kodieren das Ergebnis als URI (encodeURIComponent in Javascript) und überprüfen dann die Länge der Nachricht (String.length in Javascript). Eine bewährte Methode ist es, 100 zum Ergebnis hinzuzufügen, um die PubNub-Umschlagdaten (Metadaten) zu berücksichtigen. In unserem Support-Dokument finden Sie eine vollständige Javascript-Funktion und Ideen, wie Sie diese für eines unserer über 70 unterstützten SDKs strukturieren könnten.

Beispiele

Da wir nun eine Möglichkeit haben, die Nachrichtengröße zu berechnen, wollen wir die Möglichkeiten der PubNub-API anhand historischer Texte und ihrer möglichen Übertragung als PubNub-Nachrichten erkunden. Die Unabhängigkeitserklärung von Thomas Jefferson könnte beispielsweise auf folgende Weise als PubNub-Nachricht kodiert werden:

var channel = "continental_congress_declaration_subcommittee";
var message = {
    "name" : "Mr. Jefferson",
    "uuid" : "4f4ec1b4-4957-4125-9103-c6edcfe37770",
    "text" : "The unanimous Declaration of the thirteen united States of America, When in the Course of human events[…]our sacred Honor."
};
Enter fullscreen mode Exit fullscreen mode

Bei Verwendung von JSON-Objekten für den Nachrichteninhalt beträgt die Größe dieser Nachricht 11,4 KB. So konnte Herr Jefferson zwei Kopien der Erklärung in einer einzigen PubNub-Nachricht versenden, was die Effizienz der PubNub-API verdeutlicht - globale Datenübertragung mit minimaler Latenzzeit in weniger als 250 ms.

Ein weiteres Beispiel ist "Routine for a Hornet" von Don Berry, ein Werk des Project Gutenberg. Mit der Nachrichtenpersistenzfunktion von PubNub könnten wir einen großen Teil dieser Kurzgeschichte kodieren:

var channel = "worlds_of_science_fiction_editors";
var message = {
    "name" : "Don Berry",
    "uuid" : "99c8361f-ac61-47f5-9b5f-22095227e6e3",
    "text" : "ROUTINE for a HORNET[…]in any case."
};
Enter fullscreen mode Exit fullscreen mode

In einem Payload kann man etwa 85% dieser Kurzgeschichte aus "The Worlds of Science Fiction" verschicken, aber man muss bei dem Cliffhanger "...Nor could he have taken his hands away from the controls in any case" aufhören und den Rest in einer zweiten Nachricht verschicken. Da jede Nachricht in 50-250ms eintrifft, ist die Wartezeit jedoch kurz. British Goblins: Welsh Folk-lore, Fairy Mythology, Legends and Traditions von Sikes. Dies ist ein langer Wälzer (773kB Dateigröße). Wenn man es verschicken wollte, müsste man es in mehrere Teile aufteilen. Bei meinen Tests füllt jedes Kapitel eines jeden Buches unsere Nutzlast aus. Zum Beispiel ist "BOOK 1 The Realm of Faerie, Chapter 1 - Fairy Tales and the Ancient Mythology..." allein schon 23KB groß. Es gibt viel über das Feenreich zu wissen.

var channel = "british_goblin_researchers";
var message = {
    "name" : "Sikes",
    "uuid" : "8044e839-a3b2-4bab-b2d1-c52897299cf5",
    "text" : "BOOK I.[…]'Welsh Melodies.'"
};
Enter fullscreen mode Exit fullscreen mode

Bewährte Praktiken

Wie wir gesehen haben, sind 32 KB eine angemessene Textmenge. Es empfiehlt sich jedoch, jede von Benutzern erstellte Nachricht auf ihre Größe zu prüfen. Wenn sie zu groß ist, finden Sie in unserem Support-Artikel "Kann ich mit PubNub große Nachrichten versenden?" einige Vorschläge zur Anpassung. Denken Sie auch daran, dass die Verschlüsselung von Nachrichten 30 % mehr ausmachen kann und dass Nachrichten, die in Doppelbyte-Sprachen verfasst sind, mehr Platz benötigen - planen Sie entsprechend. Pro-Tipp: Wenn Sie die Größe Ihrer Nachrichten auf < 1,5KB beschränken, passen sie in ein einziges TCP-Paket. Was ist mit Bildern? Bilder können gesendet werden, wenn sie in Base-64 konvertiert werden. Diese Konvertierung bedeutet einen erheblichen Mehraufwand, daher sollten Sie Ihr System erneut testen. In unserem DIY Snapchat-Klon-Demoprojekt finden Sie einige Ideen. Und schließlich: Was sind 250 ms? 250 Millisekunden sind kürzer, als Sie zum Lesen dieses Satzes gebraucht haben. Mit 15 Präsenzpunkten auf der ganzen Welt und einer patentierten Echtzeitarchitektur liefert PubNub Ihre Nutzdaten schnell aus.

Ein letzter Gedanke

Es kann verlockend sein, jede technische Frage zu beantworten, bevor man ein neues Projekt beginnt. Das Schöne an den PubNub SDKs ist, dass es selten nur einen richtigen Weg gibt. Wir haben viele Beispiele in unserem Blog und wenn Sie nicht weiterkommen, wenden Sie sich an uns - wir wollen, dass Sie erfolgreich sind. Wenn Sie etwas bauen und als Open Source zur Verfügung stellen, schicken Sie eine Nachricht an unser Developer Relations Team - wir würden uns freuen, es zu sehen.

Dieser Blog als PubNub-Botschaft

var channel = "my_channel";
var message = {
    "name" : "Mark Williams",
    "uuid" : "d75dace8-1f15-4b8e-80a3-646ad97b58de",
    "text" : "The maximum length […] we would love to see it."
};
Enter fullscreen mode Exit fullscreen mode

Dieser Blogbeitrag ist 10.5k

Erste Schritte

Starten Sie noch heute mit PubNub! Melden Sie sich für einen PubNub-Account an, überprüfen Sie Ihr Keyset, um Ihren Veröffentlichungs- und Abo-Schlüssel zu erhalten, und sehen Sie sich alles an, was PubNub zu bieten hat:

  1. Veröffentlichen: Senden Sie Nachrichten, wenn Benutzereingaben aktualisiert werden, wie Textaktualisierungen, Emoji-Reaktionen, gesendete Dateien und andere komplexe Metadaten.

  2. Abonnieren: Empfangen Sie neue Nachrichten, um die Bildschirme der Benutzer zu aktualisieren.

  3. Anwesenheit: Aktualisierung und Erkennung des Online-Status der Benutzer.

  4. Persistenz der Nachricht: Zeigen Sie alle empfangenen Nachrichten an, sobald sich die Benutzer bei der App anmelden, oder verfolgen Sie Projekt- und Dokumentänderungen.

  5. Mobile Push-Benachrichtigungen: Benachrichtigen Sie mobile Benutzer, die sich nicht in der App befinden, über Chat-Nachrichten, Projekt- oder Anwendungsaktualisierungen.

  6. App-Kontext: Speichern Sie Informationen über Ihre Benutzer an einem Ort, ohne Ihre Datenbank einrichten oder aufrufen zu müssen.

  7. Zugriffsmanager: Schränken Sie den Zugang zu privaten Gesprächen, Channel-Räumen, Dokumenten und Projekten für bestimmte Benutzer ein.

  8. Funktionen: Übersetzen Sie Nachrichten, zensieren Sie unangemessene Nachrichten, kündigen Sie die Ankunft neuer Nutzer an und benachrichtigen Sie andere Nutzer über Erwähnungen.

  9. Ereignisse & Aktionen: Verwalten Sie Ereignisse im Ökosystem Ihrer Anwendung zentral und lösen Sie Geschäftslogik ohne Code aus.

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .