Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Topik MQTT Bayangan Perangkat
Layanan Device Shadow menggunakan topik MQTT yang dicadangkan untuk memungkinkan perangkat dan aplikasi mendapatkan, memperbarui, atau menghapus informasi status untuk perangkat (bayangan).
Menerbitkan dan berlangganan topik bayangan memerlukan otorisasi berbasis topik. AWS IoT
berhak untuk menambahkan topik baru ke struktur topik yang ada. Untuk alasan ini, kami menyarankan Anda menghindari langganan wild card ke topik bayangan. Misalnya, hindari berlangganan filter topik seperti $aws/things/thingName/shadow/# karena jumlah topik yang cocok dengan filter topik ini mungkin meningkat saat AWS IoT memperkenalkan topik bayangan baru. Untuk contoh pesan yang dipublikasikan pada topik ini lihatBerinteraksi dengan bayangan.
Bayangan dapat dinamai atau tidak disebutkan namanya (klasik). Topik yang digunakan oleh masing-masing hanya berbeda dalam awalan topik. Tabel ini menunjukkan awalan topik yang digunakan oleh setiap jenis bayangan.
Nilai ShadowTopicPrefix |
Jenis bayangan |
|---|---|
$aws/things/ |
Bayangan tanpa nama (klasik) |
$aws/things/ |
Bernama bayangan |
Untuk membuat topik lengkap, pilih jenis bayangan yang ingin Anda rujuk, ganti, dan jika berlakushadowName, dengan nilai yang sesuai, lalu tambahkan dengan rintisan topik seperti yang ditunjukkan pada bagian berikut. thingNameShadowTopicPrefix
Berikut ini adalah topik MQTT yang digunakan untuk berinteraksi dengan bayangan.
Topik
/dapatkan
Publikasikan pesan kosong ke topik ini untuk mendapatkan bayangan perangkat:
ShadowTopicPrefix/get
AWS IoT merespons dengan menerbitkan salah satu /dapatkan/diterima atau/dapatkan/ditolak.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/dapatkan/diterima
AWS IoT menerbitkan dokumen bayangan respons ke topik ini saat mengembalikan bayangan perangkat:
ShadowTopicPrefix/get/accepted
Untuk informasi selengkapnya, lihat Dokumen negara respons.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/dapatkan/ditolak
AWS IoT menerbitkan dokumen respons kesalahan ke topik ini jika tidak dapat mengembalikan bayangan perangkat:
ShadowTopicPrefix/get/rejected
Untuk informasi selengkapnya, lihat Dokumen respons kesalahan.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/perbarui
Publikasikan dokumen status permintaan ke topik ini untuk memperbarui bayangan perangkat:
ShadowTopicPrefix/update
Badan pesan berisi dokumen status permintaan sebagian.
Klien yang mencoba memperbarui status perangkat akan mengirim dokumen status permintaan JSON dengan desired properti seperti ini:
{ "state": { "desired": { "color": "red", "power": "on" } } }
Perangkat yang memperbarui bayangannya akan mengirim dokumen status permintaan JSON dengan reported properti, seperti ini:
{ "state": { "reported": { "color": "red", "power": "on" } } }
AWS IoT merespons dengan menerbitkan salah satu /perbarui/diterima atau/perbarui/ditolak.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/perbarui/delta
AWS IoT menerbitkan dokumen status respons ke topik ini saat menerima perubahan untuk bayangan perangkat, dan dokumen status respons berisi nilai desired dan reported status yang berbeda:
ShadowTopicPrefix/update/delta
Buffer pesan berisi file. /dokumen status respons delta
Detail isi pesan
-
Pesan yang dipublikasikan hanya
update/deltamencakup atribut yang diinginkan yang berbeda antara bagiandesireddanreportedbagian. Ini berisi semua atribut ini, terlepas dari apakah atribut ini terkandung dalam pesan pembaruan saat ini atau sudah disimpan di AWS IoT. Atribut yang tidak berbeda antarareportedbagiandesireddan bagian tidak termasuk. -
Jika atribut ada di
reportedbagian tetapi tidak memiliki padanan didesiredbagian, itu tidak termasuk. -
Jika atribut ada di
desiredbagian tetapi tidak memiliki padanan direportedbagian, itu disertakan. -
Jika atribut dihapus dari
reportedbagian tetapi masih ada didesiredbagian, itu disertakan.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/perbarui/diterima
AWS IoT menerbitkan dokumen status respons ke topik ini saat menerima perubahan untuk bayangan perangkat:
ShadowTopicPrefix/update/accepted
Buffer pesan berisi file. /dokumen status respons yang diterima
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/pembaruan/dokumen
AWS IoT menerbitkan dokumen status ke topik ini setiap kali pembaruan bayangan berhasil dilakukan:
ShadowTopicPrefix/update/documents
Badan pesan berisi a/dokumen dokumen status respon.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/perbarui/ditolak
AWS IoT menerbitkan dokumen respons kesalahan ke topik ini saat menolak perubahan bayangan perangkat:
ShadowTopicPrefix/update/rejected
Badan pesan berisiDokumen respons kesalahan.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/delete
Untuk menghapus bayangan perangkat, publikasikan pesan kosong ke topik hapus:
ShadowTopicPrefix/delete
Isi pesan diabaikan.
Perhatikan bahwa menghapus bayangan tidak mengatur ulang nomor versinya ke 0.
AWS IoT merespons dengan menerbitkan salah satu /hapus/diterima atau/hapus/ditolak.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/hapus/diterima
AWS IoT menerbitkan pesan ke topik ini saat bayangan perangkat dihapus:
ShadowTopicPrefix/delete/accepted
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan:
/hapus/ditolak
AWS IoT menerbitkan dokumen respons kesalahan ke topik ini jika tidak dapat menghapus bayangan perangkat:
ShadowTopicPrefix/delete/rejected
Badan pesan berisiDokumen respons kesalahan.
Contoh kebijakan
Berikut ini adalah contoh kebijakan yang diperlukan: