Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Kelola penerapan dan komponen lokal
Gunakan layanan Greengrass CLI IPC untuk mengelola penerapan lokal dan komponen Greengrass pada perangkat inti.
Untuk menggunakan operasi IPC ini, sertakan versi 2.6.0 atau yang lebih baru dari komponen CLI Greengrass sebagai ketergantungan dalam komponen kustom Anda. Anda kemudian dapat menggunakan operasi IPC di komponen kustom Anda untuk melakukan hal berikut:
-
Buat penerapan lokal untuk memodifikasi dan mengonfigurasi komponen Greengrass pada perangkat inti.
-
Mulai ulang dan hentikan komponen Greengrass pada perangkat inti.
-
Buat kata sandi yang dapat Anda gunakan untuk masuk ke konsol debug lokal.
Topik
SDK (Versi Minimum)
Tabel berikut mencantumkan versi minimum AWS IoT Device SDK yang harus Anda gunakan untuk berinteraksi dengan layanan Greengrass CLI IPC.
SDK | Versi minimum |
---|---|
v1.2.10 |
|
v1.5.3 |
|
v1.17.0 |
|
v1.12.0 |
Otorisasi
Untuk menggunakan layanan Greengrass CLI IPC dalam komponen kustom, Anda harus menentukan kebijakan otorisasi yang memungkinkan komponen Anda mengelola penerapan dan komponen lokal. Untuk informasi tentang cara menentukan kebijakan otorisasi, lihat Otorisasi komponen untuk melakukan operasi IPC.
Kebijakan otorisasi untuk CLI Greengrass memiliki properti berikut.
Pengenal layanan IPC: aws.greengrass.Cli
Operasi | Deskripsi | Sumber daya |
---|---|---|
|
Memungkinkan komponen untuk membuat penyebaran lokal pada perangkat inti. |
|
|
Memungkinkan komponen untuk mencantumkan penerapan lokal pada perangkat inti. |
|
|
Memungkinkan komponen untuk mendapatkan status penyebaran lokal pada perangkat inti. |
ID penyebaran lokal, atau |
|
Memungkinkan komponen untuk daftar komponen pada perangkat inti. |
|
|
Memungkinkan komponen untuk mendapatkan detail tentang komponen pada perangkat inti. |
Nama komponen, seperti |
|
Memungkinkan komponen untuk me-restart komponen pada perangkat inti. |
Nama komponen, seperti |
|
Memungkinkan komponen untuk menghentikan komponen pada perangkat inti. |
Nama komponen, seperti |
|
Mengizinkan komponen menghasilkan kata sandi yang akan digunakan untuk masuk ke komponen konsol debug lokal. |
|
contoh Contoh kebijakan otorisasi
Contoh kebijakan otorisasi berikut memungkinkan komponen untuk membuat penerapan lokal, melihat semua penerapan dan komponen lokal, dan memulai ulang dan menghentikan komponen bernama. com.example.HelloWorld
{ "accessControl": { "aws.greengrass.Cli": { "
com.example.MyLocalManagerComponent
:cli:1": { "policyDescription": "Allows access to create local deployments and view deployments and components.", "operations": [ "aws.greengrass#CreateLocalDeployment", "aws.greengrass#ListLocalDeployments", "aws.greengrass#GetLocalDeploymentStatus", "aws.greengrass#ListComponents", "aws.greengrass#GetComponentDetails" ], "resources": [ "*" ] } }, "aws.greengrass.Cli": { "com.example.MyLocalManagerComponent
:cli:2": { "policyDescription": "Allows access to restart and stop the Hello World component.", "operations": [ "aws.greengrass#RestartComponent", "aws.greengrass#StopComponent" ], "resources": [ "com.example.HelloWorld" ] } } } }
CreateLocalDeployment
Buat atau perbarui deployment lokal menggunakan resep komponen tertentu, artefak, dan argumen waktu aktif.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah deployment create di Greengrass CLI.
Permintaan
Permintaan operasi ini memiliki parameter berikut:
recipeDirectoryPath
(Python:)recipe_directory_path
-
(Opsional) Jalur absolut ke folder yang berisi file resep komponen.
artifactDirectoryPath
(Python:)artifact_directory_path
-
(Opsional) Jalur absolut ke folder yang berisi file artefak untuk disertakan dalam penerapan. Folder artefak harus berisi struktur folder berikut:
/path/to/artifact/folder
/component-name
/component-version
/artifacts
rootComponentVersionsToAdd
(Python:)root_component_versions_to_add
-
(Opsional) Versi komponen yang akan diinstal pada perangkat inti. Objek ini,
ComponentToVersionMap
, adalah peta yang berisi pasangan kunci-nilai berikut:key
-
Nama komponen.
value
-
Versi komponen.
rootComponentsToRemove
(Python:)root_components_to_remove
-
(Opsional) Komponen yang akan dihapus dari perangkat inti. Tentukan daftar di mana setiap entri adalah nama komponen.
componentToConfiguration
(Python:)component_to_configuration
-
(Opsional) Pembaruan konfigurasi untuk setiap komponen dalam penerapan. Objek ini,
ComponentToConfiguration
, adalah peta yang berisi pasangan kunci-nilai berikut:key
-
Nama komponen.
value
-
Konfigurasi memperbarui objek JSON untuk komponen. Objek JSON harus memiliki format berikut.
{ "MERGE": { "
config-key
": "config-value
" }, "RESET": [ "path/to/reset/
" ] }Untuk informasi selengkapnya tentang pembaruan konfigurasi, lihat Perbarui konfigurasi komponen.
componentToRunWithInfo
(Python:)component_to_run_with_info
-
(Opsional) Konfigurasi runtime untuk setiap komponen dalam penerapan. Konfigurasi ini mencakup pengguna sistem yang memiliki proses masing-masing komponen dan batas sistem untuk diterapkan pada setiap komponen. Objek ini,
ComponentToRunWithInfo
, adalah peta yang berisi pasangan kunci-nilai berikut:key
-
Nama komponen.
value
-
Konfigurasi runtime untuk komponen. Jika Anda menghilangkan parameter konfigurasi runtime, perangkat lunak AWS IoT Greengrass Core menggunakan nilai default yang Anda konfigurasikan pada inti Greengrass. Objek ini,
RunWithInfo
, berisi informasi berikut:posixUser
(Python:)posix_user
-
(Opsional) Pengguna sistem POSIX dan, secara opsional, grup untuk digunakan untuk menjalankan komponen ini pada perangkat inti Linux. Pengguna, dan grup jika ditentukan, harus ada di setiap perangkat inti Linux. Tentukan pengguna dan grup yang dipisahkan dengan titik dua (
:
) dalam format berikut:user:group
. Grup ini opsional. Jika Anda tidak menentukan grup, perangkat lunak AWS IoT Greengrass Core menggunakan grup utama untuk pengguna. Lihat informasi yang lebih lengkap di Konfigurasikan pengguna yang menjalankan komponen. windowsUser
(Python:)windows_user
-
(Opsional) Pengguna Windows yang digunakan untuk menjalankan komponen ini pada perangkat inti Windows. Pengguna harus ada di setiap perangkat inti Windows, dan nama serta kata sandinya harus disimpan dalam instance Credentials Manager LocalSystem akun. Lihat informasi yang lebih lengkap di Konfigurasikan pengguna yang menjalankan komponen.
systemResourceLimits
(Python:)system_resource_limits
-
(Opsional) Batas sumber daya sistem untuk diterapkan pada proses komponen ini. Anda dapat menerapkan batas sumber daya sistem ke komponen Lambda generik dan non-kontainer. Lihat informasi yang lebih lengkap di Konfigurasikan batas sumber daya sistem untuk komponen.
AWS IoT Greengrasssaat ini tidak mendukung fitur ini di perangkat inti Windows.
Objek ini,
SystemResourceLimits
, berisi informasi berikut:cpus
-
(Opsional) Jumlah maksimum waktu CPU yang dapat digunakan proses komponen ini pada perangkat inti. Total waktu CPU perangkat inti setara dengan jumlah inti CPU perangkat. Misalnya, pada perangkat inti dengan 4 core CPU, Anda dapat mengatur nilai ini
2
untuk membatasi proses komponen ini hingga 50 persen penggunaan setiap inti CPU. Pada perangkat dengan 1 inti CPU, Anda dapat mengatur nilai ini0.25
untuk membatasi proses komponen ini hingga 25 persen penggunaan CPU. Jika Anda menetapkan nilai ini ke angka yang lebih besar dari jumlah inti CPU, perangkat lunak AWS IoT Greengrass Core tidak membatasi penggunaan CPU komponen. memory
-
(Opsional) Jumlah maksimum RAM (dalam kilobyte) yang dapat digunakan proses komponen ini pada perangkat inti.
groupName
(Python:)group_name
-
(Opsional) Nama grup hal yang akan ditargetkan dengan penerapan ini.
Respons
Tanggapan operasi ini memiliki informasi berikut:
deploymentId
(Python:)deployment_id
-
ID penyebaran lokal yang dibuat permintaan.
ListLocalDeployments
Mendapat status 10 penerapan lokal terakhir.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah daftar penerapan di CLI Greengrass.
Permintaan
Operasi ini tidak memiliki parameter apa pun.
Respons
Tanggapan operasi ini memiliki informasi berikut:
localDeployments
(Python:)local_deployments
-
Daftar penyebaran lokal. Setiap objek dalam daftar ini adalah
LocalDeployment
objek, yang berisi informasi berikut:deploymentId
(Python:)deployment_id
-
ID penyebaran lokal.
status
-
Status penyebaran lokal. Enum ini,
DeploymentStatus
, memiliki nilai-nilai berikut:-
QUEUED
-
IN_PROGRESS
-
SUCCEEDED
-
FAILED
-
GetLocalDeploymentStatus
Mendapat status penyebaran lokal.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah status penerapan di CLI Greengrass.
Permintaan
Permintaan operasi ini memiliki parameter berikut:
deploymentId
(Python:)deployment_id
-
ID penyebaran lokal untuk mendapatkan.
Respons
Tanggapan operasi ini memiliki informasi berikut:
deployment
-
Penyebaran lokal. Objek ini,
LocalDeployment
, berisi informasi berikut:deploymentId
(Python:)deployment_id
-
ID penyebaran lokal.
status
-
Status penyebaran lokal. Enum ini,
DeploymentStatus
, memiliki nilai-nilai berikut:-
QUEUED
-
IN_PROGRESS
-
SUCCEEDED
-
FAILED
-
ListComponents
Mendapat nama, versi, status, dan konfigurasi setiap komponen root pada perangkat inti. Komponen root adalah komponen yang Anda tentukan dalam penerapan. Respons ini tidak termasuk komponen yang diinstal sebagai dependensi komponen lain.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah daftar komponen di CLI Greengrass.
Permintaan
Operasi ini tidak memiliki parameter apa pun.
Respons
Tanggapan operasi ini memiliki informasi berikut:
components
-
Daftar komponen root pada perangkat inti. Setiap objek dalam daftar ini adalah
ComponentDetails
objek, yang berisi informasi berikut:componentName
(Python:)component_name
-
Nama komponen.
version
-
Versi komponen.
state
-
Keadaan komponen. Keadaan ini dapat menjadi salah satu dari yang berikut:
-
BROKEN
-
ERRORED
-
FINISHED
-
INSTALLED
-
NEW
-
RUNNING
-
STARTING
-
STOPPING
-
configuration
-
Konfigurasi komponen sebagai objek JSON.
GetComponentDetails
Mendapat versi, status, dan konfigurasi komponen pada perangkat inti.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah detail komponen di CLI Greengrass.
Permintaan
Permintaan operasi ini memiliki parameter berikut:
componentName
(Python:)component_name
-
Nama komponen yang akan didapat.
Respons
Tanggapan operasi ini memiliki informasi berikut:
componentDetails
(Python:)component_details
-
Detail komponen. Objek ini,
ComponentDetails
, berisi informasi berikut:componentName
(Python:)component_name
-
Nama komponen.
version
-
Versi komponen.
state
-
Keadaan komponen. Keadaan ini dapat menjadi salah satu dari yang berikut:
-
BROKEN
-
ERRORED
-
FINISHED
-
INSTALLED
-
NEW
-
RUNNING
-
STARTING
-
STOPPING
-
configuration
-
Konfigurasi komponen sebagai objek JSON.
RestartComponent
Memulai ulang komponen pada perangkat inti.
catatan
Meskipun Anda dapat me-restart komponen apa pun, kami sarankan Anda hanya me-restart komponen generik.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah restart komponen di CLI Greengrass.
Permintaan
Permintaan operasi ini memiliki parameter berikut:
componentName
(Python:)component_name
-
Nama komponen.
Respons
Tanggapan operasi ini memiliki informasi berikut:
restartStatus
(Python:)restart_status
-
Status permintaan restart. Status permintaan dapat berupa salah satu dari yang berikut:
-
SUCCEEDED
-
FAILED
-
message
-
Pesan tentang mengapa komponen gagal memulai ulang, jika permintaan gagal.
StopComponent
Menghentikan proses komponen pada perangkat inti.
catatan
Meskipun Anda dapat menghentikan komponen apa pun, kami sarankan Anda menghentikan hanya komponen generik.
Operasi ini menyediakan fungsionalitas yang sama dengan perintah stop komponen di CLI Greengrass.
Permintaan
Permintaan operasi ini memiliki parameter berikut:
componentName
(Python:)component_name
-
Nama komponen.
Respons
Tanggapan operasi ini memiliki informasi berikut:
stopStatus
(Python:)stop_status
-
Status permintaan berhenti. Status permintaan dapat berupa salah satu dari yang berikut:
-
SUCCEEDED
-
FAILED
-
message
-
Pesan tentang mengapa komponen gagal berhenti, jika permintaan gagal.
CreateDebugPassword
Menghasilkan kata sandi acak yang dapat Anda gunakan untuk masuk ke komponen konsol debug lokal. Kata sandi kedaluwarsa 8 jam setelah dibuat.
Operasi ini menyediakan fungsionalitas yang sama dengan get-debug-password perintah di CLI Greengrass.
Permintaan
Operasi ini tidak memiliki parameter apa pun.
Respons
Tanggapan operasi ini memiliki informasi berikut:
username
-
Nama pengguna yang digunakan untuk masuk.
password
-
Kata sandi yang digunakan untuk masuk.
passwordExpiration
(Python:)password_expiration
-
Waktu ketika kata sandi kedaluwarsa.
certificateSHA256Hash
(Python:)certificate_sha256_hash
-
Sidik jari SHA-256 untuk sertifikat yang ditandatangani sendiri yang digunakan konsol debug lokal saat HTTPS diaktifkan. Saat Anda membuka konsol debug lokal, gunakan sidik jari ini untuk memverifikasi bahwa sertifikat tersebut sah dan koneksi aman.
certificateSHA1Hash
(Python:)certificate_sha1_hash
-
Sidik jari SHA-1 untuk sertifikat yang ditandatangani sendiri yang digunakan konsol debug lokal saat HTTPS diaktifkan. Saat Anda membuka konsol debug lokal, gunakan sidik jari ini untuk memverifikasi bahwa sertifikat tersebut sah dan koneksi aman.