Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
Gérez les déploiements et les composants locaux
Note
Cette fonctionnalité est disponible pour les versions 2.6.0 et ultérieures du composant Greengrass nucleus.
Utilisez le service IPC Greengrass CLI pour gérer les déploiements locaux et les composants Greengrass sur le périphérique principal.
Pour utiliser ces opérations IPC, incluez la version 2.6.0 ou ultérieure du composant Greengrass CLI en tant que dépendance dans votre composant personnalisé. Vous pouvez ensuite utiliser les opérations IPC dans vos composants personnalisés pour effectuer les opérations suivantes :
-
Créez des déploiements locaux pour modifier et configurer les composants Greengrass sur le périphérique principal.
-
Redémarrez et arrêtez les composants Greengrass sur le périphérique principal.
-
Générez un mot de passe que vous pouvez utiliser pour vous connecter à la console de débogage locale.
Rubriques
Versions minimales du SDK
Le tableau suivant répertorie les versions minimales du Kit SDK des appareils AWS IoT que vous devez utiliser pour interagir avec le service IPC Greengrass CLI.
Kit SDK | Version minimale |
---|---|
v1.2.10 |
|
v1.5.3 |
|
v1.17.0 |
|
v1.12.0 |
Autorisation
Pour utiliser le service IPC Greengrass CLI dans un composant personnalisé, vous devez définir des politiques d'autorisation qui permettent à votre composant de gérer les déploiements et les composants locaux. Pour plus d'informations sur la définition des politiques d'autorisation, consultezAutoriser les composants à effectuer des IPC opérations.
Les politiques d'autorisation de la Greengrass CLI présentent les propriétés suivantes.
Identifiant du service IPC : aws.greengrass.Cli
Opération | Description | Ressources |
---|---|---|
|
Permet à un composant de créer un déploiement local sur le périphérique principal. |
|
|
Permet à un composant de répertorier les déploiements locaux sur le périphérique principal. |
|
|
Permet à un composant d'obtenir l'état d'un déploiement local sur le périphérique principal. |
Un identifiant de déploiement local, ou |
|
Permet à un composant de répertorier les composants du périphérique principal. |
|
|
Permet à un composant d'obtenir des informations sur un composant du périphérique principal. |
Un nom de composant, tel que |
|
Permet à un composant de redémarrer un composant sur le périphérique principal. |
Un nom de composant, tel que |
|
Permet à un composant d'arrêter un composant du périphérique principal. |
Un nom de composant, tel que |
|
Permet à un composant de générer un mot de passe à utiliser pour se connecter au composant de console de débogage local. |
|
Exemple de politique d'autorisation
Les exemples de politiques d'autorisation suivants permettent à un composant de créer des déploiements locaux, de visualiser tous les déploiements et composants locaux, ainsi que de redémarrer et d'arrêter un composant nommé. 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
Créez ou mettez à jour un déploiement local à l'aide de recettes de composants, d'artefacts et d'arguments d'exécution spécifiés.
Cette opération fournit les mêmes fonctionnalités que la commande de création de déploiement dans la CLI Greengrass.
Demande
La demande de cette opération comporte les paramètres suivants :
recipeDirectoryPath
(Python :recipe_directory_path
)-
(Facultatif) Le chemin absolu vers le dossier contenant les fichiers de recettes de composants.
artifactDirectoryPath
(Python :artifact_directory_path
)-
(Facultatif) Le chemin absolu vers le dossier contenant les fichiers d'artefacts à inclure dans le déploiement. Le dossier des artefacts doit contenir la structure de dossiers suivante :
/path/to/artifact/folder
/component-name
/component-version
/artifacts
rootComponentVersionsToAdd
(Python :root_component_versions_to_add
)-
(Facultatif) Les versions des composants à installer sur le périphérique principal. Cet objet est une carte qui contient les paires clé-valeur suivantes :
ComponentToVersionMap
key
-
Le nom du composant.
value
-
Version du composant.
rootComponentsToRemove
(Python :root_components_to_remove
)-
(Facultatif) Les composants à désinstaller du périphérique principal. Spécifiez une liste dans laquelle chaque entrée est le nom d'un composant.
componentToConfiguration
(Python :component_to_configuration
)-
(Facultatif) Les mises à jour de configuration pour chaque composant du déploiement. Cet objet est une carte qui contient les paires clé-valeur suivantes :
ComponentToConfiguration
key
-
Le nom du composant.
value
-
L'objet JSON de mise à jour de configuration pour le composant. L'objet JSON doit avoir le format suivant.
{ "MERGE": { "
config-key
": "config-value
" }, "RESET": [ "path/to/reset/
" ] }Pour plus d'informations sur les mises à jour de configuration, consultezMettre à jour les configurations des composants.
componentToRunWithInfo
(Python :component_to_run_with_info
)-
(Facultatif) La configuration d'exécution pour chaque composant du déploiement. Cette configuration inclut l'utilisateur du système qui possède les processus de chaque composant et les limites du système à appliquer à chaque composant. Cet objet est une carte qui contient les paires clé-valeur suivantes :
ComponentToRunWithInfo
key
-
Le nom du composant.
value
-
Configuration d'exécution du composant. Si vous omettez un paramètre de configuration d'exécution, le logiciel AWS IoT Greengrass Core utilise les valeurs par défaut que vous configurez sur le noyau Greengrass. Cet objet contient
RunWithInfo
les informations suivantes :posixUser
(Python :posix_user
)-
(Facultatif) L'utilisateur du système POSIX et, éventuellement, le groupe à utiliser pour exécuter ce composant sur les périphériques principaux Linux. L'utilisateur et le groupe, s'ils sont spécifiés, doivent exister sur chaque périphérique principal Linux. Spécifiez l'utilisateur et le groupe en les séparant par deux points (
:
) au format suivant :user:group
. Le groupe est facultatif. Si vous ne spécifiez aucun groupe, le logiciel AWS IoT Greengrass Core utilise le groupe principal pour l'utilisateur. Pour plus d'informations, consultez Configurer l'utilisateur qui exécute les composants. windowsUser
(Python :windows_user
)-
(Facultatif) Utilisateur Windows à utiliser pour exécuter ce composant sur les appareils principaux de Windows. L'utilisateur doit exister sur chaque appareil principal de Windows, et son nom et son mot de passe doivent être stockés dans l'instance Credentials Manager du LocalSystem compte. Pour plus d'informations, consultez Configurer l'utilisateur qui exécute les composants.
systemResourceLimits
(Python :system_resource_limits
)-
(Facultatif) Les limites de ressources système à appliquer aux processus de ce composant. Vous pouvez appliquer des limites de ressources système aux composants Lambda génériques et non conteneurisés. Pour plus d'informations, consultez Configuration des limites de ressources système pour les composants.
AWS IoT Greengrassne prend actuellement pas en charge cette fonctionnalité sur les appareils Windows principaux.
Cet objet contient
SystemResourceLimits
les informations suivantes :cpus
-
(Facultatif) Durée maximale du processeur que les processus de ce composant peuvent utiliser sur le périphérique principal. Le temps processeur total d'un appareil principal est équivalent au nombre de cœurs processeurs de l'appareil. Par exemple, sur un périphérique principal doté de 4 cœurs de processeur, vous pouvez définir cette valeur
2
pour limiter les processus de ce composant à 50 % d'utilisation de chaque cœur de processeur. Sur un appareil doté d'un cœur de processeur, vous pouvez définir cette valeur0.25
pour limiter les processus de ce composant à 25 % d'utilisation du processeur. Si vous définissez cette valeur sur un nombre supérieur au nombre de cœurs de processeur, le logiciel AWS IoT Greengrass Core ne limite pas l'utilisation du processeur par le composant. memory
-
(Facultatif) La quantité maximale de RAM (en kilo-octets) que les processus de ce composant peuvent utiliser sur le périphérique principal.
groupName
(Python :group_name
)-
(Facultatif) Nom du groupe d'objets à cibler dans le cadre de ce déploiement.
Réponse
La réponse de cette opération contient les informations suivantes :
deploymentId
(Python :deployment_id
)-
ID du déploiement local créé par la demande.
ListLocalDeployments
Obtient le statut des 10 derniers déploiements locaux.
Cette opération fournit les mêmes fonctionnalités que la commande de liste de déploiement dans la CLI Greengrass.
Demande
La demande de cette opération ne comporte aucun paramètre.
Réponse
La réponse de cette opération contient les informations suivantes :
localDeployments
(Python :local_deployments
)-
La liste des déploiements locaux. Chaque objet de cette liste est un
LocalDeployment
objet qui contient les informations suivantes :deploymentId
(Python :deployment_id
)-
ID du déploiement local.
status
-
État du déploiement local. Cette énumération possède
DeploymentStatus
les valeurs suivantes :-
QUEUED
-
IN_PROGRESS
-
SUCCEEDED
-
FAILED
-
GetLocalDeploymentStatus
Obtient le statut d'un déploiement local.
Cette opération fournit les mêmes fonctionnalités que la commande d'état du déploiement dans la CLI Greengrass.
Demande
La demande de cette opération comporte les paramètres suivants :
deploymentId
(Python :deployment_id
)-
ID du déploiement local à obtenir.
Réponse
La réponse de cette opération contient les informations suivantes :
deployment
-
Le déploiement local. Cet objet contient
LocalDeployment
les informations suivantes :deploymentId
(Python :deployment_id
)-
ID du déploiement local.
status
-
État du déploiement local. Cette énumération possède
DeploymentStatus
les valeurs suivantes :-
QUEUED
-
IN_PROGRESS
-
SUCCEEDED
-
FAILED
-
ListComponents
Obtient le nom, la version, l'état et la configuration de chaque composant racine sur le périphérique principal. Un composant racine est un composant que vous spécifiez dans un déploiement. Cette réponse n'inclut pas les composants installés en tant que dépendances d'autres composants.
Cette opération fournit les mêmes fonctionnalités que la commande de liste de composants dans la CLI Greengrass.
Demande
La demande de cette opération ne comporte aucun paramètre.
Réponse
La réponse de cette opération contient les informations suivantes :
components
-
Liste des composants racine du périphérique principal. Chaque objet de cette liste est un
ComponentDetails
objet qui contient les informations suivantes :componentName
(Python :component_name
)-
Le nom du composant.
version
-
Version du composant.
state
-
État du composant. Cet état peut être l'un des suivants :
-
BROKEN
-
ERRORED
-
FINISHED
-
INSTALLED
-
NEW
-
RUNNING
-
STARTING
-
STOPPING
-
configuration
-
Configuration du composant en tant qu'objet JSON.
GetComponentDetails
Obtient la version, le statut et la configuration d'un composant sur le périphérique principal.
Cette opération fournit les mêmes fonctionnalités que la commande component details de la CLI Greengrass.
Demande
La demande de cette opération comporte les paramètres suivants :
componentName
(Python :component_name
)-
Le nom du composant à obtenir.
Réponse
La réponse de cette opération contient les informations suivantes :
componentDetails
(Python :component_details
)-
Les détails du composant. Cet objet contient
ComponentDetails
les informations suivantes :componentName
(Python :component_name
)-
Le nom du composant.
version
-
Version du composant.
state
-
État du composant. Cet état peut être l'un des suivants :
-
BROKEN
-
ERRORED
-
FINISHED
-
INSTALLED
-
NEW
-
RUNNING
-
STARTING
-
STOPPING
-
configuration
-
Configuration du composant en tant qu'objet JSON.
RestartComponent
Redémarre un composant sur le périphérique principal.
Note
Bien que vous puissiez redémarrer n'importe quel composant, nous vous recommandons de ne redémarrer que les composants génériques.
Cette opération fournit les mêmes fonctionnalités que la commande de redémarrage du composant dans la CLI Greengrass.
Demande
La demande de cette opération comporte les paramètres suivants :
componentName
(Python :component_name
)-
Le nom du composant.
Réponse
La réponse de cette opération contient les informations suivantes :
restartStatus
(Python :restart_status
)-
État de la demande de redémarrage. Le statut de la demande peut être l'un des suivants :
-
SUCCEEDED
-
FAILED
-
message
-
Un message expliquant pourquoi le composant n'a pas pu redémarrer, en cas d'échec de la demande.
StopComponent
Arrête les processus d'un composant sur le périphérique principal.
Note
Bien que vous puissiez arrêter n'importe quel composant, nous vous recommandons de n'arrêter que les composants génériques.
Cette opération fournit les mêmes fonctionnalités que la commande d'arrêt du composant dans la CLI Greengrass.
Demande
La demande de cette opération comporte les paramètres suivants :
componentName
(Python :component_name
)-
Le nom du composant.
Réponse
La réponse de cette opération contient les informations suivantes :
stopStatus
(Python :stop_status
)-
État de la demande d'arrêt. Le statut de la demande peut être l'un des suivants :
-
SUCCEEDED
-
FAILED
-
message
-
Un message expliquant pourquoi le composant n'a pas pu s'arrêter, en cas d'échec de la demande.
CreateDebugPassword
Génère un mot de passe aléatoire que vous pouvez utiliser pour vous connecter au composant de console de débogage local. Le mot de passe expire 8 heures après sa création.
Cette opération fournit les mêmes fonctionnalités que la get-debug-password commande de la CLI Greengrass.
Demande
La demande de cette opération ne comporte aucun paramètre.
Réponse
La réponse de cette opération contient les informations suivantes :
username
-
Le nom d'utilisateur à utiliser pour se connecter.
password
-
Le mot de passe à utiliser pour se connecter.
passwordExpiration
(Python :password_expiration
)-
Heure à laquelle le mot de passe expire.
certificateSHA256Hash
(Python :certificate_sha256_hash
)-
L'empreinte SHA-256 du certificat autosigné utilisé par la console de débogage locale lorsque le protocole HTTPS est activé. Lorsque vous ouvrez la console de débogage locale, utilisez cette empreinte pour vérifier que le certificat est légitime et que la connexion est sécurisée.
certificateSHA1Hash
(Python :certificate_sha1_hash
)-
L'empreinte SHA-1 du certificat autosigné utilisé par la console de débogage locale lorsque le protocole HTTPS est activé. Lorsque vous ouvrez la console de débogage locale, utilisez cette empreinte pour vérifier que le certificat est légitime et que la connexion est sécurisée.