Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
ust-in-time Penyediaan J
Anda dapat menggunakan just-in-time provisioning (JITP) untuk menyediakan perangkat Anda ketika mereka pertama kali mencoba untuk terhubung. AWS IoT Untuk menyediakan perangkat, Anda harus mengaktifkan pendaftaran otomatis dan mengaitkan templat penyediaan dengan sertifikat CA yang digunakan untuk menandatangani sertifikat perangkat. Keberhasilan dan kesalahan penyediaan dicatat seperti di Metrik penyediaan perangkat Amazon. CloudWatch
Topik
Ikhtisar JITP
Ketika perangkat mencoba untuk terhubung AWS IoT dengan menggunakan sertifikat yang ditandatangani oleh sertifikat CA terdaftar, AWS IoT memuat template dari sertifikat CA dan menggunakannya untuk memanggil RegisterThing. Alur kerja JITP pertama-tama mendaftarkan sertifikat dengan nilai status. PENDING_ACTIVATION
Ketika alur penyediaan perangkat selesai, status sertifikat diubah menjadi. ACTIVE
AWS IoT mendefinisikan parameter berikut yang dapat Anda deklarasikan dan referensi dalam templat penyediaan:
-
AWS::IoT::Certificate::Country
-
AWS::IoT::Certificate::Organization
-
AWS::IoT::Certificate::OrganizationalUnit
-
AWS::IoT::Certificate::DistinguishedNameQualifier
-
AWS::IoT::Certificate::StateName
-
AWS::IoT::Certificate::CommonName
-
AWS::IoT::Certificate::SerialNumber
-
AWS::IoT::Certificate::Id
Nilai untuk parameter template penyediaan ini terbatas pada apa yang dapat diekstrak JITP dari bidang subjek sertifikat perangkat yang sedang disediakan. Sertifikat harus berisi nilai untuk semua parameter dalam badan template. AWS::IoT::Certificate::Id
Parameter mengacu pada ID yang dihasilkan secara internal, bukan ID yang terkandung dalam sertifikat. Anda bisa mendapatkan nilai ID ini menggunakan principal()
fungsi di dalam AWS IoT aturan.
catatan
Anda dapat menyediakan perangkat menggunakan fitur AWS IoT Core just-in-time provisioning (JITP) tanpa harus mengirim seluruh rantai kepercayaan pada koneksi pertama perangkat ke. AWS IoT Core Menyajikan sertifikat CA adalah opsional, tetapi perangkat diperlukan untuk mengirim ekstensi Server Name Indication (SNI)
Contoh badan template
File JSON berikut adalah contoh badan template dari template JITP lengkap.
{ "Parameters":{ "AWS::IoT::Certificate::CommonName":{ "Type":"String" }, "AWS::IoT::Certificate::SerialNumber":{ "Type":"String" }, "AWS::IoT::Certificate::Country":{ "Type":"String" }, "AWS::IoT::Certificate::Id":{ "Type":"String" } }, "Resources":{ "thing":{ "Type":"AWS::IoT::Thing", "Properties":{ "ThingName":{ "Ref":"AWS::IoT::Certificate::CommonName" }, "AttributePayload":{ "version":"v1", "serialNumber":{ "Ref":"AWS::IoT::Certificate::SerialNumber" } }, "ThingTypeName":"lightBulb-versionA", "ThingGroups":[ "v1-lightbulbs", { "Ref":"AWS::IoT::Certificate::Country" } ] }, "OverrideSettings":{ "AttributePayload":"MERGE", "ThingTypeName":"REPLACE", "ThingGroups":"DO_NOTHING" } }, "certificate":{ "Type":"AWS::IoT::Certificate", "Properties":{ "CertificateId":{ "Ref":"AWS::IoT::Certificate::Id" }, "Status":"ACTIVE" } }, "policy":{ "Type":"AWS::IoT::Policy", "Properties":{ "PolicyDocument":"{ \"Version\": \"2012-10-17\", \"Statement\": [{ \"Effect\": \"Allow\", \"Action\":[\"iot:Publish\"], \"Resource\": [\"arn:aws:iot:us-east-1:123456789012:topic/foo/bar\"] }] }" } } } }
Templat sampel ini mendeklarasikan nilai untuk parameter AWS::IoT::Certificate::CommonName
AWS::IoT::Certificate::SerialNumber
,AWS::IoT::Certificate::Country
,, dan AWS::IoT::Certificate::Id
penyediaan yang diekstraksi dari sertifikat dan digunakan di bagian tersebut. Resources
Alur kerja JITP kemudian menggunakan template ini untuk melakukan tindakan berikut:
-
Daftarkan sertifikat dan atur statusnya ke PENDING_ACTIVE.
-
Buat sumber daya satu hal.
-
Buat satu sumber kebijakan.
-
Lampirkan kebijakan ke sertifikat.
-
Lampirkan sertifikat pada objek .
-
Perbarui status sertifikat ke AKTIF.
Penyediaan perangkat gagal jika sertifikat tidak memiliki semua properti yang disebutkan di Parameters
bagian. templateBody
Misalnya, jika AWS::IoT::Certificate::Country
disertakan dalam templat, tetapi sertifikat tidak memiliki Country
properti, penyediaan perangkat akan gagal.
Anda juga dapat menggunakan CloudTrail untuk memecahkan masalah dengan template JITP Anda. Untuk informasi tentang metrik yang dicatat di Amazon CloudWatch, lihatMetrik penyediaan perangkat. Untuk informasi selengkapnya tentang penyediaan templat, lihat Templat penyediaan.
catatan
Selama proses penyediaan, just-in-time provisioning (JITP) memanggil operasi API bidang kontrol lainnya. AWS IoT Panggilan ini mungkin melebihi Kuota AWS IoT Pelambatan yang ditetapkan untuk akun Anda dan mengakibatkan panggilan terhambat. Hubungi AWS
Customer Support
Daftarkan CA menggunakan templat penyediaan
Untuk mendaftarkan CA menggunakan templat penyediaan lengkap, ikuti langkah-langkah berikut:
-
Simpan template penyediaan Anda dan informasi ARN peran seperti contoh berikut sebagai file JSON:
{ "templateBody" : "{\r\n \"Parameters\" : {\r\n \"AWS::IoT::Certificate::CommonName\": {\r\n \"Type\": \"String\"\r\n },\r\n \"AWS::IoT::Certificate::SerialNumber\": {\r\n \"Type\": \"String\"\r\n },\r\n \"AWS::IoT::Certificate::Country\": {\r\n \"Type\": \"String\"\r\n },\r\n \"AWS::IoT::Certificate::Id\": {\r\n \"Type\": \"String\"\r\n }\r\n },\r\n \"Resources\": {\r\n \"thing\": {\r\n \"Type\": \"AWS::IoT::Thing\",\r\n \"Properties\": {\r\n \"ThingName\": {\r\n \"Ref\": \"AWS::IoT::Certificate::CommonName\"\r\n },\r\n \"AttributePayload\": {\r\n \"version\": \"v1\",\r\n \"serialNumber\": {\r\n \"Ref\": \"AWS::IoT::Certificate::SerialNumber\"\r\n }\r\n },\r\n \"ThingTypeName\": \"lightBulb-versionA\",\r\n \"ThingGroups\": [\r\n \"v1-lightbulbs\",\r\n {\r\n \"Ref\": \"AWS::IoT::Certificate::Country\"\r\n }\r\n ]\r\n },\r\n \"OverrideSettings\": {\r\n \"AttributePayload\": \"MERGE\",\r\n \"ThingTypeName\": \"REPLACE\",\r\n \"ThingGroups\": \"DO_NOTHING\"\r\n }\r\n },\r\n \"certificate\": {\r\n \"Type\": \"AWS::IoT::Certificate\",\r\n \"Properties\": {\r\n \"CertificateId\": {\r\n \"Ref\": \"AWS::IoT::Certificate::Id\"\r\n },\r\n \"Status\": \"ACTIVE\"\r\n },\r\n \"OverrideSettings\": {\r\n \"Status\": \"DO_NOTHING\"\r\n }\r\n },\r\n \"policy\": {\r\n \"Type\": \"AWS::IoT::Policy\",\r\n \"Properties\": {\r\n \"PolicyDocument\": \"{ \\\"Version\\\": \\\"2012-10-17\\\", \\\"Statement\\\": [{ \\\"Effect\\\": \\\"Allow\\\", \\\"Action\\\":[\\\"iot:Publish\\\"], \\\"Resource\\\": [\\\"arn:aws:iot:us-east-1:123456789012:topic\/foo\/bar\\\"] }] }\"\r\n }\r\n }\r\n }\r\n}", "roleArn" : "arn:aws:iam::123456789012:role/JITPRole" }
Dalam contoh ini, nilai
templateBody
bidang harus berupa objek JSON yang ditentukan sebagai string yang lolos dan hanya dapat menggunakan nilai-nilai dalam daftar sebelumnya. Anda dapat menggunakan berbagai alat untuk membuat output JSON yang diperlukan, sepertijson.dumps
(Python)JSON.stringify
atau (Node). NilairoleARN
bidang harus ARN dari peran yangAWSIoTThingsRegistration
melekat padanya. Selain itu, template Anda dapat menggunakan yang sudah adaPolicyName
alih-alih inlinePolicyDocument
dalam contoh. -
Daftarkan sertifikat CA dengan operasi RegisterCacerTificate API atau perintah CLI.
register-ca-certificate
Anda akan menentukan direktori template penyediaan dan peran informasi ARN yang Anda simpan di langkah sebelumnya:Berikut ini menunjukkan contoh cara mendaftarkan sertifikat CA dalam
DEFAULT
mode menggunakan AWS CLI:aws iot register-ca-certificate --ca-certificate file://
your-ca-cert
--verification-cert file://your-verification-cert
--set-as-active --allow-auto-registration --registration-config file://your-template
Berikut ini menunjukkan contoh cara mendaftarkan sertifikat CA dalam
SNI_ONLY
mode menggunakan AWS CLI:aws iot register-ca-certificate --ca-certificate file://
your-ca-cert
--certificate-modeSNI_ONLY
--set-as-active --allow-auto-registration --registration-config file://your-template
Untuk informasi selengkapnya, lihat Mendaftarkan Sertifikat CA Anda.
-
(Opsional) Perbarui pengaturan untuk sertifikat CA dengan menggunakan operasi UpdateCacertificate API atau perintah CLI.
update-ca-certificate
Berikut ini menunjukkan contoh cara memperbarui sertifikat CA menggunakan AWS CLI:
aws iot update-ca-certificate --certificate-id
caCertificateId
--new-auto-registration-status ENABLE --registration-config file://your-template
Daftarkan CA menggunakan nama templat penyediaan
Untuk mendaftarkan CA menggunakan nama templat penyediaan, ikuti langkah-langkah berikut:
-
Simpan isi template penyediaan Anda sebagai file JSON. Anda dapat menemukan contoh badan template dalam contoh badan template.
-
Untuk membuat template penyediaan, gunakan CreateProvisioningTemplate API atau perintah CLI
create-provisioning-template
:aws iot create-provisioning-template --template-name
your-template-name
\ --template-body file://your-template-body.json
--type JITP \ --provisioning-role-arnarn:aws:iam::123456789012:role/test
catatan
Untuk just-in-time penyediaan (JITP), Anda harus menentukan jenis templat
JITP
saat membuat templat penyediaan. Untuk informasi selengkapnya tentang jenis templat, lihat CreateProvisioningTemplate di Referensi AWS API. -
Untuk mendaftarkan CA dengan nama template, gunakan RegisterCacertificate API atau perintah CLI:
register-ca-certificate
aws iot register-ca-certificate --ca-certificate file:
//your-ca-cert
--verification-certfile://your-verification-cert
\ --set-as-active --allow-auto-registration --registration-config templateName=your-template-name