Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Timestream
Tindakan aturan Timestream menulis atribut (ukuran) dari pesan MQTT ke dalam tabel Amazon Timestream. Untuk informasi selengkapnya tentang Amazon Timestream, lihat Apa itu Amazon Timestream? .
catatan
Amazon Timestream tidak tersedia di semua Wilayah AWS s. Jika Amazon Timestream tidak tersedia di Wilayah Anda, Amazon Timestream tidak akan muncul dalam daftar tindakan aturan.
Atribut yang disimpan aturan ini dalam database Timestream adalah atribut yang dihasilkan dari pernyataan kueri aturan. Nilai setiap atribut dalam hasil pernyataan query diuraikan untuk menyimpulkan tipe datanya (seperti dalam DynamoDBv2 tindakan). Setiap nilai atribut ditulis ke catatannya sendiri di tabel Timestream. Untuk menentukan atau mengubah tipe data atribut, gunakan cast()fungsi dalam pernyataan query. Untuk informasi selengkapnya tentang isi setiap catatan Timestream, lihatKonten rekaman Timestream.
catatan
Dengan SQL V2 (2016-03-23), nilai numerik yang merupakan bilangan bulat, seperti10.0
, dikonversi representasi Integer mereka (). 10
Secara eksplisit mentransmisikan mereka ke Decimal
nilai, seperti dengan menggunakan fungsi cast (), tidak mencegah perilaku ini—hasilnya masih merupakan nilai. Integer
Hal ini dapat menyebabkan kesalahan jenis ketidakcocokan yang mencegah data direkam dalam database Timestream. Untuk memproses nilai numerik bilangan bulat sebagai Decimal
nilai, gunakan SQL V1 (2015-10-08) untuk pernyataan kueri aturan.
catatan
Jumlah maksimum nilai yang dapat ditulis oleh tindakan aturan Timestream ke dalam tabel Amazon Timestream adalah 100. Untuk informasi selengkapnya, lihat Referensi Kuota Amazon Timestream.
Persyaratan
Tindakan aturan ini memiliki persyaratan sebagai berikut:
-
Peran IAM yang AWS IoT dapat diasumsikan untuk melakukan
timestream:DescribeEndpoints
dantimestream:WriteRecords
operasi. Untuk informasi selengkapnya, lihat Memberikan AWS IoT aturan akses yang dibutuhkannya.Di AWS IoT konsol, Anda dapat memilih, memperbarui, atau membuat peran AWS IoT untuk memungkinkan melakukan tindakan aturan ini.
-
Jika Anda menggunakan pelanggan- AWS KMS untuk mengenkripsi data saat istirahat di Timestream, layanan harus memiliki izin untuk menggunakan AWS KMS key atas nama pemanggil. Untuk informasi selengkapnya, lihat Cara AWS layanan menggunakan AWS KMS.
Parameter
Saat Anda membuat AWS IoT aturan dengan tindakan ini, Anda harus menentukan informasi berikut:
databaseName
-
Nama database Amazon Timestream yang memiliki tabel untuk menerima catatan yang dibuat tindakan ini. Lihat juga
tableName
.Mendukung template substitusi: API dan hanya AWS CLI
dimensions
-
Atribut metadata dari deret waktu yang ditulis dalam setiap catatan ukuran. Misalnya, nama dan Availability Zone dari instans EC2 atau nama produsen turbin angin adalah dimensi.
name
Nama dimensi metadata. Ini adalah nama kolom dalam catatan tabel database.
Dimensi tidak dapat diberi nama:
measure_name
,measure_value
, atautime
. Nama-nama ini dicadangkan. Nama dimensi tidak dapat dimulai dengants_
ataumeasure_value
dan tidak dapat berisi karakter titik dua (:
).Mendukung template substitusi: Tidak
value
Nilai untuk ditulis dalam kolom ini dari catatan basis data.
Mendukung template substitusi: Ya
roleArn
-
Amazon Resource Name (ARN) peran yang memberikan AWS IoT izin untuk menulis ke tabel basis data Timestream. Untuk informasi selengkapnya, lihat Persyaratan.
Mendukung template substitusi: Tidak
tableName
-
Nama tabel database untuk menulis catatan ukuran. Lihat juga
databaseName
.Mendukung template substitusi: API dan hanya AWS CLI
timestamp
-
Nilai yang akan digunakan untuk stempel waktu entri. Jika kosong, waktu untuk memproses entri yang akan digunakan.
unit
-
Ketepatan nilai stempel waktu yang dihasilkan dari ekspresi yang dijelaskan dalam
value
.Nilai yang valid:
SECONDS
|MILLISECONDS
|MICROSECONDS
|NANOSECONDS
. Nilai default-nyaMILLISECONDS
. value
-
Ekspresi yang mengembalikan nilai waktu jangka waktu panjang.
Anda dapat menggunakan time_to_epoch (String, String) fungsi ini untuk membuat stempel waktu yang valid dari nilai tanggal atau waktu yang diteruskan dalam payload pesan.
Konten rekaman Timestream
Data yang ditulis ke tabel Amazon Timestream oleh tindakan ini mencakup stempel waktu, metadata dari tindakan aturan Timestream, dan hasil dari pernyataan kueri aturan.
Untuk setiap atribut (ukuran) dalam hasil pernyataan kueri, tindakan aturan ini menulis catatan ke tabel Timestream yang ditentukan dengan kolom ini.
Nama kolom |
Jenis atribut |
Nilai |
Komentar |
---|---|---|---|
|
UKURAN |
Nilai yang ditentukan dalam entri tindakan aturan Timestream. |
Setiap Dimensi yang ditentukan dalam entri tindakan aturan membuat kolom dalam database Timestream dengan nama dimensi. |
ukuran_nama |
UKURAN_NAMA |
Nama atribut |
Nama atribut dalam hasil pernyataan query yang nilainya ditentukan dalam |
|
UKURAN_NILAI |
Nilai atribut dalam hasil pernyataan query. Nama atribut ada di |
Nilai ditafsirkan* dan dilemparkan sebagai kecocokan yang paling cocok dari: |
Waktu |
TIMESTAMP |
Tanggal dan waktu catatan dalam database. |
Nilai ini ditetapkan oleh mesin aturan atau |
* Nilai atribut yang dibaca dari payload pesan ditafsirkan sebagai berikut. Lihat Contoh untuk ilustrasi dari masing-masing kasus ini.
-
Nilai yang tidak dikutip dari
true
ataufalse
ditafsirkan sebagai tipe.boolean
-
Numerik desimal ditafsirkan sebagai tipe.
double
-
Nilai numerik tanpa titik desimal ditafsirkan sebagai tipe.
bigint
-
String yang dikutip ditafsirkan sebagai
varchar
tipe. -
Objek dan nilai array dikonversi ke string JSON dan disimpan sebagai
varchar
tipe.
Contoh
Contoh JSON berikut mendefinisikan tindakan aturan Timestream dengan template substitusi dalam aturan. AWS IoT
{ "topicRulePayload": { "sql": "SELECT * FROM 'iot/topic'", "ruleDisabled": false, "awsIotSqlVersion": "2016-03-23", "actions": [ { "timestream": { "roleArn": "arn:aws:iam::123456789012:role/aws_iot_timestream", "tableName": "devices_metrics", "dimensions": [ { "name": "device_id", "value": "${clientId()}" }, { "name": "device_firmware_sku", "value": "My Static Metadata" } ], "databaseName": "record_devices" } } ] } }
Menggunakan tindakan aturan topik Timestream yang ditentukan dalam contoh sebelumnya dengan payload pesan berikut menghasilkan catatan Amazon Timestream yang ditulis dalam tabel berikut.
{ "boolean_value": true, "integer_value": 123456789012, "double_value": 123.456789012, "string_value": "String value", "boolean_value_as_string": "true", "integer_value_as_string": "123456789012", "double_value_as_string": "123.456789012", "array_of_integers": [23,36,56,72], "array of strings": ["red", "green","blue"], "complex_value": { "simple_element": 42, "array_of_integers": [23,36,56,72], "array of strings": ["red", "green","blue"] } }
Tabel berikut menampilkan kolom database dan catatan yang menggunakan tindakan aturan topik tertentu untuk memproses payload pesan sebelumnya dibuat. device_id
Kolom device_firmware_sku
dan adalah DIMENSI yang didefinisikan dalam tindakan aturan topik. Tindakan aturan topik Timestream membuat time
kolom dan measure_value::*
kolom measure_name
dan kolom, yang diisi dengan nilai dari hasil pernyataan kueri tindakan aturan topik.
device_firmware_sku | device_id | ukuran_nama | ukuran_nilai: :bigint | ukuran_nilai: :varchar | ukuran_nilai: :ganda | ukuran_nilai: :boolean | Waktu |
---|---|---|---|---|---|---|---|
Metadata Statis Saya | IOTCONSOLE-159Example738-0 | complex_value | - | {"simple_element” :42, "array_of_integers”: [23,36,56,72], "array string”: ["red”, "green”, "blue "]} | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | IOTCONSOLE-159Example738-0 | integer_value_as_string | - | 123456789012 | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | IOTCONSOLE-159Example738-0 | boolean_nilai | - | - | - | BETUL | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | IOTCONSOLE-159Example738-0 | integer_nilai | 123456789012 | - | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | string_nilai | - | Nilai string | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | array_of_integer | - | [23,36,56,72] | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | array string | - | ["merah”, “hijau”, “biru"] | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | boolean_value_as_string | - | BETUL | - | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | nilai ganda | - | - | 123.456789012 | - | 2020-08-26 22:42:16.423 000000 |
Metadata Statis Saya | iotconsole-159example738-0 | double_value_as_string | - | 123.45679 | - | - | 2020-08-26 22:42:16.423 000000 |