Wählen Sie Ihre Cookie-Einstellungen aus

Wir verwenden essentielle Cookies und ähnliche Tools, die für die Bereitstellung unserer Website und Services erforderlich sind. Wir verwenden Performance-Cookies, um anonyme Statistiken zu sammeln, damit wir verstehen können, wie Kunden unsere Website nutzen, und Verbesserungen vornehmen können. Essentielle Cookies können nicht deaktiviert werden, aber Sie können auf „Anpassen“ oder „Ablehnen“ klicken, um Performance-Cookies abzulehnen.

Wenn Sie damit einverstanden sind, verwenden AWS und zugelassene Drittanbieter auch Cookies, um nützliche Features der Website bereitzustellen, Ihre Präferenzen zu speichern und relevante Inhalte, einschließlich relevanter Werbung, anzuzeigen. Um alle nicht notwendigen Cookies zu akzeptieren oder abzulehnen, klicken Sie auf „Akzeptieren“ oder „Ablehnen“. Um detailliertere Entscheidungen zu treffen, klicken Sie auf „Anpassen“.

Interaktion mit Schatten

Fokusmodus
Interaktion mit Schatten - AWS IoT Core

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

In diesem Thema werden die Nachrichten beschrieben, die jeder der drei Methoden zugeordnet sind, die AWS IoT für das Arbeiten mit Schatten bereitstellt. Zu diesen Methoden gehören die folgenden:

UPDATE

Erstellt einen Schatten, wenn er nicht vorhanden ist, oder aktualisiert den Inhalt eines vorhandenen Schattens mit den Statusinformationen, die im Nachrichtentext bereitgestellt werden. AWS IoT zeichnet mit jeder Aktualisierung einen Zeitstempel auf, um anzugeben, wann der Status zuletzt aktualisiert wurde. Wenn sich der Status des Shadows ändert, werden /delta Nachrichten AWS IoT an alle MQTT Abonnenten gesendet, wobei der Unterschied zwischen dem desired und dem reported Status angegeben wird. Geräte oder Apps, die eine /delta-Nachricht empfangen, können basierend auf dem Unterschied Aktionen durchführen. Bei einem Gerät kann z. B. der Status auf den Sollstatus oder bei einer Anwendung die Benutzeroberfläche aktualisiert werden, um die Änderung des Gerätestatus zu reflektieren.

GET

Ruft ein aktuelles Schattendokument ab, das den vollständigen Status des Schattens einschließlich Metadaten enthält.

DELETE

Löscht den Geräteschatten und seinen gesamten Inhalt.

Sie können ein gelöschtes Geräteschatten-Dokument nicht wiederherstellen, aber Sie können ein neues Geräteschatten-Dokument mit dem Namen eines gelöschten Geräteschatten-Dokuments erstellen. Wenn Sie ein Geräteschatten-Dokument erstellen, das denselben Namen hat wie eines, das innerhalb der letzten 48 Stunden gelöscht wurde, folgt die Versionsnummer des neuen Geräteschatten-Dokuments der Versionsnummer des gelöschten. Wenn ein Geräteschatten-Dokument länger als 48 Stunden gelöscht wurde, lautet die Versionsnummer eines neuen Geräteschatten-Dokuments mit demselben Namen 0.

Protokollunterstützung

AWS IoT unterstützt MQTTund bietet REST API mehr HTTPS Protokolle für die Interaktion mit Schatten. AWS IoT bietet eine Reihe von reservierten Anfrage- und Antwortthemen für MQTT Veröffentlichungs- und Abonnementaktionen. Geräte und Apps sollten die Antwortthemen abonnieren, bevor sie ein Anfragethema veröffentlichen, um Informationen darüber zu erhalten, wie AWS IoT mit der Anfrage umgegangen wurde. Weitere Informationen erhalten Sie unter Device MQTT Shadow-Themen und Device Shadow REST API.

Anforderungs- und Meldestatus

Wenn Sie Ihre IoT-Lösung mithilfe von AWS IoT Schatten entwerfen, sollten Sie festlegen, welche Apps oder Geräte Änderungen anfordern und welche diese implementieren. In der Regel implementiert und meldet ein Gerät Änderungen an den Schatten zurück, und Apps und Services reagieren auf Änderungen im Schatten und fordern Änderungen an. Ihre Lösung könnte davon abweichen, aber die Beispiele in diesem Thema gehen jedoch davon aus, dass die Client-App oder der Service Änderungen im Schatten anfordert und das Gerät die Änderungen durchführt und sie an den Schatten zurückmeldet.

Aktualisieren eines Shadows

Ihre App oder Ihr Dienst kann den Status eines Shadows aktualisieren, indem Sie das UpdateThingShadow API oder verwenden, indem Sie es im /update Thema veröffentlichen. Aktualisierungen betreffen lediglich die in der Anfrage angegebenen Felder.

Aktualisieren eines Schattens, wenn ein Client eine Statusänderung anfordert

Wenn ein Client mithilfe des MQTT Protokolls eine Statusänderung in einem Shadow anfordert
  1. Der Client sollte über ein aktuelles Schattendokument verfügen, damit er die zu ändernden Eigenschaften identifizieren kann. Weitere Informationen zum Abrufen des aktuellen Schattendokuments finden Sie unter der Aktion /get.

  2. Der Kunde abonniert die folgenden MQTT Themen:

    • $aws/things/thingName/shadow/name/shadowName/update/accepted

    • $aws/things/thingName/shadow/name/shadowName/update/rejected

    • $aws/things/thingName/shadow/name/shadowName/update/delta

    • $aws/things/thingName/shadow/name/shadowName/update/documents

  3. Der Client veröffentlicht ein $aws/things/thingName/shadow/name/shadowName/update-Anforderungsthema mit einem Statusdokument, das den gewünschten Status des Schattens enthält. Nur die zu ändernden Eigenschaften müssen in das Dokument aufgenommen werden. Dies ist ein Beispiel für ein Dokument mit dem gewünschten Status.

    { "state": { "desired": { "color": { "r": 10 }, "engine": "ON" } } }
  4. Wenn die Aktualisierungsanfrage gültig ist, wird der gewünschte Status im Shadow AWS IoT aktualisiert und Nachrichten zu den folgenden Themen veröffentlicht:

    • $aws/things/thingName/shadow/name/shadowName/update/accepted

    • $aws/things/thingName/shadow/name/shadowName/update/delta

    Die /update/accepted-Nachricht enthält ein Antwortstatusdokument „/accepted“-Schattendokument, und die /update/delta-Nachricht enthält ein Antwortstatusdokument „/delta“-Schattendokument.

  5. Wenn die Aktualisierungsanforderung nicht gültig ist, wird eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/update/rejected Thema zusammen mit einem Fehlerantwortdokument Schattendokument AWS IoT veröffentlicht, das den Fehler beschreibt.

Wenn ein Client eine Statusänderung in einem Shadow anfordert, indem er den API
  1. Der Client ruft das UpdateThingShadow API mit einem Anfragestatusdokument Statusdokument als Nachrichtentext auf.

  2. Wenn die Anfrage gültig war, werden ein HTTP Erfolgsantwortcode und ein Antwortstatusdokument „/accepted“ Schattendokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

    AWS IoT veröffentlicht außerdem eine MQTT Nachricht zu dem $aws/things/thingName/shadow/name/shadowName/update/delta Thema mit einem Antwortstatusdokument „/delta“ Shadow-Dokument für alle Geräte oder Clients, die es abonnieren.

  3. Wenn die Anfrage nicht gültig war, wird der HTTP Fehlerantwortcode an Fehlerantwortdokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

Wenn das Gerät den /desired-Status zum /update/delta-Thema erhält, nimmt es die gewünschten Änderungen im Gerät vor. Anschließend wird eine Nachricht an das /update-Thema gesendet, um den aktuellen Status an den Schatten zu melden.

Aktualisieren eines Schattens, wenn ein Gerät seinen aktuellen Status meldet

Wenn ein Gerät mithilfe des MQTT Protokolls seinen aktuellen Status an den Shadow meldet
  1. Das Gerät sollte die folgenden MQTT Themen abonnieren, bevor es den Shadow aktualisiert:

    • $aws/things/thingName/shadow/name/shadowName/update/accepted

    • $aws/things/thingName/shadow/name/shadowName/update/rejected

    • $aws/things/thingName/shadow/name/shadowName/update/delta

    • $aws/things/thingName/shadow/name/shadowName/update/documents

  2. Das Gerät meldet seinen aktuellen Status, indem es eine Nachricht zum $aws/things/thingName/shadow/name/shadowName/update-Thema veröffentlicht, das den aktuellen Status meldet, wie etwa in diesem Beispiel.

    { "state": { "reported" : { "color" : { "r" : 10 }, "engine" : "ON" } } }
  3. Wenn das Update AWS IoT akzeptiert wird, veröffentlicht es eine Nachricht zu den $aws/things/thingName/shadow/name/shadowName/update/accepted Themen zusammen mit einem Antwortstatusdokument „/accepted“ Shadow-Dokument.

  4. Wenn die Aktualisierungsanforderung nicht gültig ist, wird eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/update/rejected Thema zusammen mit einem Fehlerantwortdokument Schattendokument AWS IoT veröffentlicht, das den Fehler beschreibt.

Wenn ein Gerät seinen aktuellen Status an den Shadow meldet, indem es den API
  1. Das Gerät ruft das UpdateThingShadow API mit einem Anfragestatusdokument Statusdokument als Nachrichtentext auf.

  2. Wenn die Anfrage gültig war, AWS IoT aktualisiert es den Shadow und gibt einen HTTP Erfolgsantwortcode mit einem Antwortstatusdokument „/accepted“ Shadow-Dokument als Hauptteil der Antwortnachricht zurück.

    AWS IoT veröffentlicht außerdem eine MQTT Nachricht zum $aws/things/thingName/shadow/name/shadowName/update/delta Thema mit einem Antwortstatusdokument „/delta“ Shadow-Dokument für alle Geräte oder Clients, die es abonnieren.

  3. Wenn die Anfrage nicht gültig war, wird der HTTP Fehlerantwortcode an Fehlerantwortdokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

Optimistische Sperre

Sie können die Version des Statusdokuments verwenden, um sicherzustellen, dass Sie die neueste Version eines Geräteschattendokuments aktualisieren. Wenn Sie eine Version mit einer Aktualisierungsanforderung angeben, lehnt der Dienst die Anfrage mit einem HTTP 409-Konflikt-Antwortcode ab, falls die aktuelle Version des Statusdokuments nicht mit der bereitgestellten Version übereinstimmt. Der Konfliktreaktionscode kann auch bei allen Änderungen auftreten APIThingShadow, darunter: DeleteThingShadow

Beispielsweise:

Ausgangsdokument:

{ "state": { "desired": { "colors": [ "RED", "GREEN", "BLUE" ] } }, "version": 10 }

Aktualisierung: (die Versionen stimmen nicht überein; die Anfrage wird abgelehnt)

{ "state": { "desired": { "colors": [ "BLUE" ] } }, "version": 9 }

Ergebnis:

{ "code": 409, "message": "Version conflict", "clientToken": "426bfd96-e720-46d3-95cd-014e3ef12bb6" }

Aktualisierung: (die Versionen stimmen überein; die Anfrage wird angenommen)

{ "state": { "desired": { "colors": [ "BLUE" ] } }, "version": 10 }

Endzustand:

{ "state": { "desired": { "colors": [ "BLUE" ] } }, "version": 11 }

Abrufen eines Shadow-Dokuments

Sie können ein Schattendokument mithilfe von GetThingShadow API oder abrufen, indem Sie das Thema abonnieren und veröffentlichen. /get Hierdurch wird ein vollständiges Schattendokument einschließlich aller Unterschiede zwischen den Statusarten desired und reported abgerufen. Die Vorgehensweise für diese Aufgabe ist unabhängig davon, ob das Gerät oder ein Client die Anforderung durchführt.

Um ein Shadow-Dokument mithilfe des MQTT Protokolls abzurufen
  1. Das Gerät oder der Client sollte die folgenden MQTT Themen abonnieren, bevor der Shadow aktualisiert wird:

    • $aws/things/thingName/shadow/name/shadowName/get/accepted

    • $aws/things/thingName/shadow/name/shadowName/get/rejected

  2. Das Gerät oder der Client veröffentlicht eine Nachricht mit einem leeren Nachrichtentext zum $aws/things/thingName/shadow/name/shadowName/get-Thema.

  3. Wenn die Anfrage erfolgreich ist, wird eine Nachricht zum $aws/things/thingName/shadow/name/shadowName/get/accepted Thema mit einem Antwortstatusdokument „/accepted“ im Nachrichtentext AWS IoT veröffentlicht.

  4. Wenn die Anfrage nicht gültig war, AWS IoT veröffentlicht eine Nachricht zum $aws/things/thingName/shadow/name/shadowName/get/rejected Thema mit einem Fehlerantwortdokument im Nachrichtentext.

Um ein Schattendokument mit einem abzurufen REST API
  1. Das Gerät oder der Client ruft den GetThingShadow API mit einem leeren Nachrichtentext auf.

  2. Wenn die Anfrage gültig ist, wird ein HTTP Erfolgsantwortcode mit einem Antwortstatusdokument „/accepted“ Schattendokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

  3. Wenn die Anfrage nicht gültig ist, wird ein HTTP Fehlerantwortcode an Fehlerantwortdokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

Löschen von Schattendaten

Es gibt zwei Möglichkeiten, Schattendaten zu löschen: Sie können bestimmte Eigenschaften im Schattendokument löschen oder den Schatten vollständig löschen.

  • Um bestimmte Eigenschaften aus einem Schatten zu löschen, aktualisieren Sie den Schatten. Legen Sie jedoch den Wert der Eigenschaften, die Sie löschen möchten, auf null fest. Felder mit dem Wert null werden aus dem Schattendokument entfernt.

  • Um den gesamten Schatten zu löschen, verwenden Sie das DeleteThingShadow API oder veröffentlichen Sie es im /delete Thema.

Anmerkung

Durch das Löschen eines Schattens wird seine Versionsnummer nicht sofort auf Null zurückgesetzt. Er wird nach 48 Stunden auf null zurückgesetzt.

Löschen einer Eigenschaft aus einem Schattendokument

Um mithilfe des MQTT Protokolls eine Eigenschaft aus einem Schatten zu löschen
  1. Das Gerät oder der Client sollte über ein aktuelles Schattendokument verfügen, damit es/er die zu ändernden Eigenschaften identifizieren kann. Weitere Informationen zum Abrufen des aktuellen Schattendokuments finden Sie unter Abrufen eines Shadow-Dokuments.

  2. Das Gerät oder der Client abonniert die folgenden MQTT Themen:

    • $aws/things/thingName/shadow/name/shadowName/update/accepted

    • $aws/things/thingName/shadow/name/shadowName/update/rejected

  3. Das Gerät oder der Client veröffentlicht ein $aws/things/thingName/shadow/name/shadowName/update-Anforderungsthema mit einem Statusdokument, das den Eigenschaften des zu löschenden Schattens null-Werte zuweist. Nur die zu ändernden Eigenschaften müssen in das Dokument aufgenommen werden. Dies ist ein Beispiel für ein Dokument, das die engine-Eigenschaft löscht.

    { "state": { "desired": { "engine": null } } }
  4. Wenn die Aktualisierungsanfrage gültig ist, AWS IoT werden die angegebenen Eigenschaften im Shadow gelöscht und eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/update/accepted Thema mit einem Antwortstatusdokument „/accepted“ Shadow-Dokument im Nachrichtentext veröffentlicht.

  5. Wenn die Aktualisierungsanforderung nicht gültig ist, wird eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/update/rejected Thema zusammen mit einem Fehlerantwortdokument Schattendokument AWS IoT veröffentlicht, das den Fehler beschreibt.

Um eine Eigenschaft aus einem Schatten zu löschen, verwenden Sie REST API
  1. Das Gerät oder der Client ruft das UpdateThingShadow API mit einem aufAnfragestatusdokument, das den Eigenschaften des zu löschenden Schattens null Werte zuweist. Fügen Sie nur die Eigenschaften, die Sie löschen möchten, in das Dokument ein. Dies ist ein Beispiel für ein Dokument, das die engine-Eigenschaft löscht.

    { "state": { "desired": { "engine": null } } }
  2. Wenn die Anfrage gültig war, wird ein HTTP Erfolgsantwortcode und ein Antwortstatusdokument „/accepted“ Shadow-Dokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

  3. Wenn die Anfrage nicht gültig war, wird ein HTTP Fehlerantwortcode an Fehlerantwortdokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

Löschen eines Shadows

Im Folgenden werden einige Aspekte beschrieben, die beim Löschen des Schattens eines Geräts berücksichtigt werden sollten.

  • Wenn Sie den Schattenstatus des Geräts auf null festlegen, wird der Schatten nicht gelöscht. Die Schattenversion wird beim nächsten Update erhöht.

  • Das Löschen eines Geräteschattens löscht das Objekt nicht. Das Löschen eines Objekts löscht den entsprechenden Geräteschatten nicht.

  • Durch das Löschen eines Shadows wird seine Versionsnummer nicht sofort auf Null zurückgesetzt. Er wird nach 48 Stunden auf null zurückgesetzt.

Um einen Shadow mithilfe des MQTT Protokolls zu löschen
  1. Das Gerät oder der Client abonniert die folgenden MQTT Themen:

    • $aws/things/thingName/shadow/name/shadowName/delete/accepted

    • $aws/things/thingName/shadow/name/shadowName/delete/rejected

  2. Das Gerät oder der Client veröffentlicht eine $aws/things/thingName/shadow/name/shadowName/delete-mit einem leeren Nachrichtenpuffer.

  3. Wenn die Löschanforderung gültig ist, wird der Shadow AWS IoT gelöscht und eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/delete/accepted Thema und einem abgekürzten Antwortstatusdokument „/accepted“ Shadow-Dokument im Nachrichtentext veröffentlicht. Dies ist ein Beispiel für eine akzeptierte Löschmeldung:

    { "version": 4, "timestamp": 1591057529 }
  4. Wenn die Aktualisierungsanforderung nicht gültig ist, wird eine Nachricht mit dem $aws/things/thingName/shadow/name/shadowName/delete/rejected Thema zusammen mit einem Fehlerantwortdokument Shadow-Dokument AWS IoT veröffentlicht, das den Fehler beschreibt.

Um einen Schatten mit dem zu löschen REST API
  1. Das Gerät oder der Client ruft den DeleteThingShadow API mit einem leeren Nachrichtenpuffer auf.

  2. Wenn die Anfrage gültig war, werden ein HTTP Erfolgsantwortcode Antwortstatusdokument „/accepted“ und ein abgekürztes Antwortstatusdokument „/accepted“ Schattendokument im Nachrichtentext AWS IoT zurückgegeben. Dies ist ein Beispiel für eine akzeptierte Löschmeldung:

    { "version": 4, "timestamp": 1591057529 }
  3. Wenn die Anfrage nicht gültig war, wird ein HTTP Fehlerantwortcode an Fehlerantwortdokument als Hauptteil der Antwortnachricht AWS IoT zurückgegeben.

DatenschutzNutzungsbedingungen für die WebsiteCookie-Einstellungen
© 2025, Amazon Web Services, Inc. oder Tochtergesellschaften. Alle Rechte vorbehalten.