Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Installa il software AWS IoT Greengrass Core con il provisioning AWS IoT della flotta
Questa funzionalità è disponibile per la versione 2.4.0 e successive del componente Greengrass nucleus.
Con AWS IoT Fleet Provisioning, è possibile AWS IoT configurare la generazione e la distribuzione sicura di certificati e chiavi private X.509 ai dispositivi quando si connettono per la prima volta. AWS IoT AWS IoT fornisce certificati client firmati dall'autorità di certificazione Amazon Root (CA). Puoi anche configurare AWS IoT per specificare gruppi di oggetti, tipi di oggetti e autorizzazioni per i dispositivi core Greengrass di cui effettui il provisioning con il fleet provisioning. È possibile definire un modello di provisioning per definire il modo AWS IoT in cui viene effettuato il provisioning di ciascun dispositivo. Il modello di provisioning specifica l'oggetto, la policy e le risorse dei certificati da creare per un dispositivo durante il provisioning. Per ulteriori informazioni, consulta Provisioning templates nella Developer Guide.AWS IoT Core
AWS IoT Greengrass fornisce un plug-in per il provisioning del AWS IoT parco veicoli che è possibile utilizzare per installare il software AWS IoT Greengrass Core utilizzando AWS le risorse create dal AWS IoT fleet provisioning. Il plug-in per il provisioning della flotta utilizza il provisioning by claim. I dispositivi utilizzano un certificato di richiesta di provisioning e una chiave privata per ottenere un certificato e una chiave privata univoci del dispositivo X.509 da utilizzare per le normali operazioni. È possibile incorporare il certificato di richiesta e la chiave privata in ogni dispositivo durante la produzione, in modo che i clienti possano attivare i dispositivi in un secondo momento, quando ogni dispositivo sarà online. Puoi utilizzare lo stesso certificato di richiesta e la stessa chiave privata per più dispositivi. Per ulteriori informazioni, consulta Provisioning by claim nella AWS IoT Core Developer Guide.
Nota
Il plug-in fleet provisioning attualmente non supporta la memorizzazione di chiavi private e file di certificato in un modulo di sicurezza hardware ()HSM. Per utilizzare unHSM, installa il software AWS IoT Greengrass Core con provisioning manuale.
Per installare il software AWS IoT Greengrass Core con il provisioning AWS IoT della flotta, è necessario configurare le risorse nel dispositivo AWS IoT utilizzato per Account AWS il provisioning dei dispositivi core Greengrass. Queste risorse includono un modello di provisioning, certificati di richiesta e un ruolo di scambio di token. IAM Dopo aver creato queste risorse, puoi riutilizzarle per effettuare il provisioning di più dispositivi principali in una flotta. Per ulteriori informazioni, consulta Configura il provisioning AWS IoT della flotta per i dispositivi core Greengrass.
Importante
Prima di scaricare il software AWS IoT Greengrass Core, verificate che il dispositivo principale soddisfi i requisiti per installare ed eseguire il software AWS IoT Greengrass Core v2.0.
Argomenti
- Prerequisiti
- Recupera AWS IoT gli endpoint
- Scarica i certificati sul dispositivo
- Configura l'ambiente del dispositivo
- Scaricate il software Core AWS IoT Greengrass
- Scarica il plug-in per il provisioning AWS IoT della flotta
- Installa il software AWS IoT Greengrass Core
- Configura il provisioning AWS IoT della flotta per i dispositivi core Greengrass
- Configurare il plug-in per il provisioning AWS IoT della flotta
- AWS IoT log delle modifiche del plugin per il provisioning della flotta
Prerequisiti
Per installare il software AWS IoT Greengrass Core con il provisioning AWS IoT della flotta, devi prima configurare il provisioning AWS IoT della flotta per i dispositivi core Greengrass. Dopo aver completato questi passaggi una volta, puoi utilizzare il provisioning del parco veicoli per installare il software AWS IoT Greengrass Core su un numero qualsiasi di dispositivi.
Recupera AWS IoT gli endpoint
Ottieni gli AWS IoT endpoint per te e salvali per Account AWS utilizzarli in un secondo momento. Il tuo dispositivo utilizza questi endpoint per connettersi a. AWS IoT Esegui questa operazione:
-
Ottieni l'endpoint di AWS IoT dati per il tuo. Account AWS
aws iot describe-endpoint --endpoint-type iot:Data-ATS
La risposta è simile all'esempio seguente, se la richiesta ha esito positivo.
{ "endpointAddress": "
device-data-prefix
-ats.iot.us-west-2.amazonaws.com" } -
Ottieni l'endpoint delle AWS IoT credenziali per il tuo. Account AWS
aws iot describe-endpoint --endpoint-type iot:CredentialProvider
La risposta è simile all'esempio seguente, se la richiesta ha esito positivo.
{ "endpointAddress": "
device-credentials-prefix
.credentials.iot.us-west-2.amazonaws.com" }
Scarica i certificati sul dispositivo
Il dispositivo utilizza un certificato di richiesta e una chiave privata per autenticare la richiesta di fornitura di AWS risorse e acquisire un certificato del dispositivo X.509. È possibile incorporare il certificato di richiesta e la chiave privata nel dispositivo durante la produzione oppure copiare il certificato e la chiave sul dispositivo durante l'installazione. In questa sezione, copi il certificato di richiesta e la chiave privata sul dispositivo. Puoi anche scaricare il certificato Amazon Root Certificate Authority (CA) sul dispositivo.
Importante
Il provisioning dichiara che le chiavi private devono essere protette in ogni momento, anche sui dispositivi core Greengrass. Ti consigliamo di utilizzare i CloudWatch parametri e i log di Amazon per monitorare eventuali indicazioni di uso improprio, come l'uso non autorizzato del certificato di attestazione per il provisioning dei dispositivi. Se rilevi un uso improprio, disattiva il certificato di richiesta di approvvigionamento in modo che non possa essere utilizzato per il provisioning dei dispositivi. Per ulteriori informazioni, consulta Monitoring AWS IoT nella Developer Guide.AWS IoT Core
Per aiutarti a gestire meglio il numero di dispositivi e i dispositivi che si registrano automaticamente nel tuo sistema Account AWS, puoi specificare un hook di pre-provisioning quando crei un modello di provisioning del parco veicoli. Un hook di pre-provisioning è una AWS Lambda funzione che convalida i parametri del modello forniti dai dispositivi durante la registrazione. Ad esempio, è possibile creare un hook di pre-provisioning che verifichi l'ID di un dispositivo confrontandolo con un database per verificare che il dispositivo disponga dell'autorizzazione al provisioning. Per ulteriori informazioni, consulta Pre-provisioning hook nella Developer Guide.AWS IoT Core
Per scaricare i certificati di richiesta sul dispositivo
-
Copia il certificato di richiesta e la chiave privata sul dispositivo. Se SSH e SCP sono abilitati sul computer di sviluppo e sul dispositivo, puoi utilizzare il
scp
comando sul tuo computer di sviluppo per trasferire il certificato di richiesta e la chiave privata. Il comando di esempio seguente trasferisce questi file in una cartella denominataclaim-certs
sul computer di sviluppo al dispositivo. Sostituiscilodevice-ip-address
con l'indirizzo IP del tuo dispositivo.scp -r claim-certs/
device-ip-address
:~ -
Crea la cartella principale Greengrass sul dispositivo. Successivamente installerai il software AWS IoT Greengrass Core in questa cartella.
Nota
In Windows esiste un limite di lunghezza del percorso di 260 caratteri. Se usi Windows, usa una cartella principale come
C:\greengrass\v2
oD:\greengrass\v2
per mantenere i percorsi dei componenti Greengrass al di sotto del limite di 260 caratteri. -
(Solo Linux) Imposta le autorizzazioni del genitore della cartella principale di Greengrass.
-
Sostituiscilo
/greengrass
con quello principale della cartella principale.
sudo chmod 755
/greengrass
-
-
Sposta i certificati di reclamo nella cartella principale di Greengrass.
-
Sostituisci
o/greengrass/v2
C:\greengrass\v2
con la cartella principale di Greengrass.
-
-
Scarica il certificato Amazon Root Certificate Authority (CA). AWS IoT per impostazione predefinita, i certificati sono associati al certificato CA root di Amazon.
Configura l'ambiente del dispositivo
Segui i passaggi di questa sezione per configurare un dispositivo Linux o Windows da utilizzare come dispositivo AWS IoT Greengrass principale.
Configura un dispositivo Linux
Per configurare un dispositivo Linux per AWS IoT Greengrass V2
-
Installa il runtime Java, necessario per l'esecuzione del software AWS IoT Greengrass Core. Ti consigliamo di utilizzare le versioni di supporto JDK a lungo termine di Amazon Corretto
o Open . È richiesta la versione 8 o successiva. I seguenti comandi mostrano come installare Open JDK sul tuo dispositivo. -
Per le distribuzioni basate su Debian o basate su Ubuntuu:
sudo apt install default-jdk
-
Per le distribuzioni basate su Red Hat:
sudo yum install java-11-openjdk-devel
-
Per Amazon Linux 2:
sudo amazon-linux-extras install java-openjdk11
-
Per Amazon Linux 2023:
sudo dnf install java-11-amazon-corretto -y
Al termine dell'installazione, esegui il comando seguente per verificare che Java sia in esecuzione sul tuo dispositivo Linux.
java -version
Il comando stampa la versione di Java in esecuzione sul dispositivo. Ad esempio, su una distribuzione basata su Debian, l'output potrebbe essere simile all'esempio seguente.
openjdk version "11.0.9.1" 2020-11-04 OpenJDK Runtime Environment (build 11.0.9.1+1-post-Debian-1deb10u2) OpenJDK 64-Bit Server VM (build 11.0.9.1+1-post-Debian-1deb10u2, mixed mode)
-
-
(Facoltativo) Crea l'utente e il gruppo di sistema predefiniti che eseguono i componenti sul dispositivo. Puoi anche scegliere di lasciare che il programma di installazione del software AWS IoT Greengrass Core crei questo utente e gruppo durante l'installazione con l'argomento
--component-default-user
installer. Per ulteriori informazioni, consulta Argomenti dell'installatore.sudo useradd --system --create-home ggc_user sudo groupadd --system ggc_group
-
Verificate che l'utente che esegue il software AWS IoT Greengrass Core (in genere
root
) sia autorizzato a funzionaresudo
con qualsiasi utente e gruppo.-
Eseguite il comando seguente per aprire il
/etc/sudoers
file.sudo visudo
-
Verificate che l'autorizzazione per l'utente sia simile all'esempio seguente.
root ALL=(ALL:ALL) ALL
-
-
(Facoltativo) Per eseguire funzioni Lambda containerizzate, è necessario abilitare cgroups
v1 e abilitare e montare i cgroup di memoria e dispositivi. Se non intendi eseguire funzioni Lambda containerizzate, puoi saltare questo passaggio. Per abilitare queste opzioni di cgroups, avvia il dispositivo con i seguenti parametri del kernel Linux.
cgroup_enable=memory cgroup_memory=1 systemd.unified_cgroup_hierarchy=0
Per informazioni sulla visualizzazione e l'impostazione dei parametri del kernel per il tuo dispositivo, consulta la documentazione del tuo sistema operativo e del boot loader. Segui le istruzioni per impostare in modo permanente i parametri del kernel.
-
Installa tutte le altre dipendenze richieste sul tuo dispositivo come indicato dall'elenco dei requisiti in. Requisiti per il dispositivo
Configura un dispositivo Windows
Nota
Questa funzionalità è disponibile per la versione 2.5.0 e successive del componente Greengrass nucleus.
Per configurare un dispositivo Windows per AWS IoT Greengrass V2
-
Installa il runtime Java, necessario per l'esecuzione del software AWS IoT Greengrass Core. Ti consigliamo di utilizzare le versioni di supporto JDK a lungo termine di Amazon Corretto
o Open . È richiesta la versione 8 o successiva. -
Controlla se Java è disponibile nella variabile di PATH
sistema e aggiungilo in caso contrario. L' LocalSystem account esegue il software AWS IoT Greengrass Core, quindi è necessario aggiungere Java alla variabile di PATH sistema anziché alla variabile PATH utente per l'utente. Esegui questa operazione: -
Premi il tasto Windows per aprire il menu di avvio.
-
Digita
environment variables
per cercare le opzioni di sistema dal menu di avvio. -
Nei risultati della ricerca del menu di avvio, scegli Modifica le variabili di ambiente di sistema per aprire la finestra delle proprietà del sistema.
-
Scegli le variabili di ambiente... per aprire la finestra Variabili d'ambiente.
-
In Variabili di sistema, seleziona Percorso, quindi scegli Modifica. Nella finestra Modifica variabile di ambiente, puoi visualizzare ogni percorso su una riga separata.
-
Controlla se è presente il percorso della
bin
cartella di installazione di Java. Il percorso potrebbe essere simile all'esempio seguente.C:\\Program Files\\Amazon Corretto\\jdk11.0.13_8\\bin
-
Se la
bin
cartella di installazione Java non è presente in Path, scegliete Nuovo per aggiungerla, quindi scegliete OK.
-
-
Aprite il prompt dei comandi di Windows (
cmd.exe
) come amministratore. -
Crea l'utente predefinito nell' LocalSystem account sul dispositivo Windows. Sostituiscilo
password
con una password sicura.net user /add ggc_user
password
Suggerimento
A seconda della configurazione di Windows, la password dell'utente potrebbe essere impostata per scadere in date future. Per garantire che le tue applicazioni Greengrass continuino a funzionare, tieni traccia della scadenza della password e aggiornala prima che scada. Puoi anche impostare la password dell'utente in modo che non scada mai.
-
Per verificare la scadenza di un utente e della relativa password, esegui il comando seguente.
net user
ggc_user
| findstr /C:expires -
Per impostare la password di un utente in modo che non scada mai, esegui il comando seguente.
wmic UserAccount where "Name='
ggc_user
'" set PasswordExpires=False -
Se utilizzi Windows 10 o versioni successive in cui il
wmic
comando è obsoleto, esegui il comandoseguente. PowerShell Get-CimInstance -Query "SELECT * from Win32_UserAccount WHERE name = '
ggc_user
'" | Set-CimInstance -Property @{PasswordExpires="False"}
-
-
Scarica e installa l'PsExecutilità
di Microsoft sul dispositivo. -
Utilizzate l' PsExec utilità per memorizzare il nome utente e la password per l'utente predefinito nell'istanza di Credential Manager per l' LocalSystem account. Sostituiscila
password
con la password dell'utente che hai impostato in precedenza.psexec -s cmd /c cmdkey /generic:ggc_user /user:ggc_user /pass:
password
Se l'icona PsExec License Agreementapre, scegli Acceptper accettare la licenza ed eseguire il comando.
Nota
Sui dispositivi Windows, l' LocalSystem account esegue il Greengrass nucleus ed è necessario utilizzare l' PsExec utilità per memorizzare le informazioni utente predefinite nell'account. LocalSystem L'utilizzo dell'applicazione Credential Manager archivia queste informazioni nell'account Windows dell'utente attualmente connesso, anziché nell'account. LocalSystem
Scaricate il software Core AWS IoT Greengrass
È possibile scaricare la versione più recente del software AWS IoT Greengrass Core dal seguente indirizzo:
-
https://d2s8p88vqu9w66.cloudfront. net/releases/greengrass
-nucleus-latest.zip
Nota
È possibile scaricare una versione specifica del software AWS IoT Greengrass Core dal seguente percorso. Sostituiscila version
con la versione da scaricare.
https://d2s8p88vqu9w66.cloudfront.net/releases/greengrass-
version
.zip
Per scaricare il software AWS IoT Greengrass Core
-
Sul dispositivo principale, scaricate il software AWS IoT Greengrass Core in un file denominato
greengrass-nucleus-latest.zip
.Scaricando questo software accetti l'Accordo di licenza del software Greengrass Core
. -
(Facoltativo) Per verificare la firma del software Greengrass nucleus
Nota
Questa funzionalità è disponibile con Greengrass nucleus versione 2.9.5 e successive.
-
Usa il seguente comando per verificare la firma del tuo artefatto Greengrass nucleus:
-
L'
jarsigner
invocazione produce un output che indica i risultati della verifica.-
Se il file zip Greengrass nucleus è firmato, l'output contiene la seguente dichiarazione:
jar verified.
-
Se il file zip Greengrass nucleus non è firmato, l'output contiene la seguente dichiarazione:
jar is unsigned.
-
-
Se hai fornito l'
-certs
opzione Jarsigner insieme alle-verbose
opzioni-verify
e, l'output include anche informazioni dettagliate sul certificato del firmatario.
-
-
Decomprimi il software AWS IoT Greengrass Core in una cartella sul tuo dispositivo. Sostituiscilo
GreengrassInstaller
con la cartella che desideri utilizzare. -
(Facoltativo) Eseguite il comando seguente per visualizzare la versione del software AWS IoT Greengrass Core.
java -jar ./
GreengrassInstaller
/lib/Greengrass.jar --version
Importante
Se installi una versione del nucleo Greengrass precedente alla v2.4.0, non rimuovere questa cartella dopo aver installato il software Core. AWS IoT Greengrass Il software AWS IoT Greengrass Core utilizza i file in questa cartella per l'esecuzione.
Se hai scaricato la versione più recente del software, installi la versione 2.4.0 o successiva e puoi rimuovere questa cartella dopo aver installato il software AWS IoT Greengrass Core.
Scarica il plug-in per il provisioning AWS IoT della flotta
Puoi scaricare l'ultima versione del plug-in per il provisioning AWS IoT della flotta dal seguente indirizzo:
Nota
È possibile scaricare una versione specifica del plug-in per il provisioning AWS IoT della flotta dalla seguente posizione. version
Sostituiscila con la versione da scaricare. Per ulteriori informazioni su ciascuna versione del plug-in Fleet Provisioning, consultaAWS IoT log delle modifiche del plugin per il provisioning della flotta.
https://d2s8p88vqu9w66.cloudfront.net/releases/aws-greengrass-FleetProvisioningByClaim/fleetprovisioningbyclaim-
version
.jar
Il plug-in per il provisioning della flotta è open source. Per visualizzarne il codice sorgente, consulta il plug-in AWS IoT
Fleet Provisioning
Per scaricare il plug-in per il provisioning AWS IoT della flotta
-
Sul tuo dispositivo, scarica il plug-in AWS IoT Fleet Provisioning in un file denominato.
aws.greengrass.FleetProvisioningByClaim.jar
SostituisciloGreengrassInstaller
con la cartella che desideri utilizzare.Scaricando questo software accetti l'Accordo di licenza del software Greengrass Core
.
Installa il software AWS IoT Greengrass Core
Esegui il programma di installazione con argomenti che specificano le seguenti azioni:
-
Esegui l'installazione da un file di configurazione parziale che specifica di utilizzare il plug-in fleet provisioning per il provisioning delle risorse. AWS Il software AWS IoT Greengrass Core utilizza un file di configurazione che specifica la configurazione di ogni componente Greengrass sul dispositivo. Il programma di installazione crea un file di configurazione completo a partire dal file di configurazione parziale fornito dall'utente e dalle AWS risorse create dal plug-in Fleet Provisioning.
-
Specificare di utilizzare l'utente
ggc_user
del sistema per eseguire i componenti software sul dispositivo principale. Sui dispositivi Linux, questo comando specifica anche di utilizzare il gruppo diggc_group
sistema e il programma di installazione crea automaticamente l'utente e il gruppo di sistema. -
Configura il software AWS IoT Greengrass Core come servizio di sistema che viene eseguito all'avvio. Sui dispositivi Linux, ciò richiede il sistema di inizializzazione Systemd
. Importante
Sui dispositivi Windows core, è necessario configurare il software AWS IoT Greengrass Core come servizio di sistema.
Per ulteriori informazioni sugli argomenti che è possibile specificare, vedereArgomenti dell'installatore.
Nota
Se si utilizza un dispositivo con memoria limitata, è possibile controllare la quantità di memoria utilizzata dal software AWS IoT Greengrass Core. AWS IoT Greengrass Per controllare l'allocazione della memoria, è possibile impostare le opzioni relative alla dimensione dell'JVMheap nel parametro di jvmOptions
configurazione del componente nucleus. Per ulteriori informazioni, consulta Controlla l'allocazione della memoria con le opzioni JVM.
Per installare il software Core AWS IoT Greengrass
-
Controlla la versione del software AWS IoT Greengrass Core.
-
Sostituisci
GreengrassInstaller
con il percorso della cartella che contiene il software.
java -jar ./
GreengrassInstaller
/lib/Greengrass.jar --version -
-
Utilizzate un editor di testo per creare un file di configurazione denominato
config.yaml
da fornire all'installatore.Ad esempio, su un sistema basato su Linux, è possibile eseguire il comando seguente per utilizzare GNU nano per creare il file.
nano
GreengrassInstaller
/config.yamlCopia il seguente YAML contenuto nel file. Questo file di configurazione parziale specifica i parametri per il plug-in Fleet Provisioning. Per ulteriori informazioni sulle opzioni che è possibile specificare, vedere. Configurare il plug-in per il provisioning AWS IoT della flotta
Successivamente, esegui queste operazioni:
-
Sostituire
2.14.0
con la versione del software AWS IoT Greengrass Core. -
Sostituisci ogni istanza di
o/greengrass/v2
C:\greengrass\v2
con la cartella principale di Greengrass.Nota
Sui dispositivi Windows, è necessario specificare i separatori di percorso come doppie barre rovesciate (
\\
), ad esempio.C:\\greengrass\\v2
-
us-west-2
Sostituiscilo con la AWS regione in cui hai creato il modello di provisioning e altre risorse. -
Sostituiscilo
iotDataEndpoint
con il tuo endpoint di AWS IoT dati. -
Sostituisci l'
iotCredentialEndpoint
endpoint con AWS IoT le tue credenziali. -
Sostituisci
GreengrassCoreTokenExchangeRoleAlias
con il nome dell'alias del ruolo di scambio di token. -
Sostituiscilo
GreengrassFleetProvisioningTemplate
con il nome del modello di approvvigionamento della flotta. -
Sostituisci il
claimCertificatePath
con il percorso del certificato di richiesta sul dispositivo. -
Sostituiscilo
claimCertificatePrivateKeyPath
con il percorso della chiave privata del certificato di richiesta sul dispositivo. -
Sostituisci i parametri del modello (
templateParameters
) con i valori da utilizzare per il provisioning del dispositivo. Questo esempio si riferisce al modello di esempio che definisceThingName
iThingGroupName
parametri.
Nota
In questo file di configurazione, è possibile personalizzare altre opzioni di configurazione come le porte e il proxy di rete da utilizzare, come illustrato nell'esempio seguente. Per ulteriori informazioni, vedere Greengrass nucleus configuration.
Per utilizzare un HTTPS proxy, è necessario utilizzare la versione 1.1.0 o successiva del plug-in Fleet Provisioning. È inoltre necessario specificare quanto segue
system
, comerootCaPath
illustrato nell'esempio seguente. -
-
Eseguire il programma di installazione. Specificate
--trusted-plugin
di fornire il plug-in Fleet Provisioning e specificate--init-config
di fornire il file di configurazione.-
Sostituisci
con la cartella principale di Greengrass./greengrass/v2
-
Sostituisci ogni istanza di
GreengrassInstaller
con la cartella in cui hai decompresso il programma di installazione.
Importante
Nei dispositivi Windows Core, è necessario specificare
--setup-system-service true
di configurare il software AWS IoT Greengrass Core come servizio di sistema.Se si specifica
--setup-system-service true
, il programma di installazione stampaSuccessfully set up Nucleus as a system service
se ha configurato ed eseguito il software come servizio di sistema. In caso contrario, il programma di installazione non emette alcun messaggio se installa il software correttamente.Nota
Non è possibile utilizzare l'
deploy-dev-tools
argomento per distribuire strumenti di sviluppo locali quando si esegue il programma di installazione senza l'argomento.--provision true
Per informazioni sulla distribuzione di CLI Greengrass direttamente sul tuo dispositivo, consulta. Interfaccia a riga di comando Greengrass -
-
Verifica l'installazione visualizzando i file nella cartella principale.
Se l'installazione è riuscita, la cartella principale contiene diverse cartelle, ad esempio
config
packages
, elogs
.
Se avete installato il software AWS IoT Greengrass Core come servizio di sistema, il programma di installazione esegue il software al posto vostro. In caso contrario, è necessario eseguire il software manualmente. Per ulteriori informazioni, consulta Esegui il software AWS IoT Greengrass Core.
Per ulteriori informazioni su come configurare e utilizzare il software e AWS IoT Greengrass, vedere quanto segue: