Freigeben über


Konfigurationsdatei von Device Update for IoT Hub

Der Device Update-Agent ruft seine Konfigurationsinformationen aus der Datei du-config.json auf dem Gerät ab. Der Agent liest diese Werte und meldet sie dem Device Update-Dienst:

  • AzureDeviceUpdateCore:4.ClientMetadata:4.deviceProperties["manufacturer"]
  • AzureDeviceUpdateCore:4.ClientMetadata:4.deviceProperties["model"]
  • DeviceInformation.manufacturer
  • DeviceInformation.model
  • additionalProperties
  • connectionData
  • connectionType

Dateispeicherort

Wenn Sie den Debian-Agent auf einem IoT-Gerät mit einem Linux-Betriebssystem installieren, ändern Sie die Datei /etc/adu/du-config.json zum Aktualisieren von Werten. Erstellen Sie für ein Yocto-Buildsystem in der Partition oder auf dem Datenträger mit dem Namen adu eine JSON-Datei mit dem Namen /adu/du-config.json.

Liste der Felder

Name Beschreibung
SchemaVersion Die Schemaversion, mit der die aktuelle Formatversion der Konfigurationsdatei zugeordnet wird.
aduShellTrustedUsers Die Liste der Benutzer, die das Programm adu-shell starten können. Beachten Sie, dass adu-shell ein Brokerprogramm ist, das verschiedene Updateaktionen als „root“ ausführt. Die Device Update-Standardhandler für Inhaltsupdates rufen adu-shell auf, um Aufgaben auszuführen, für die die Superuser-Berechtigung erforderlich ist. Beispiele für Aufgaben, die diese Berechtigung erfordern, sind apt-get install oder das Ausführen privilegierter Skripts.
Hersteller Wird von der Schnittstelle AzureDeviceUpdateCore:4.ClientMetadata:4 gemeldet, um das Gerät für die Updatebereitstellung zu klassifizieren.
model Wird von der Schnittstelle AzureDeviceUpdateCore:4.ClientMetadata:4 gemeldet, um das Gerät für die Updatebereitstellung zu klassifizieren.
iotHubProtocol Zum Ändern des Protokolls, das zum Herstellen einer Verbindung mit dem IoT-Hub verwendet wird, wird der Wert mqtt oder mqtt/ws akzeptiert. Der Standardwert ist „mqtt“.
compatPropertyNames Diese Eigenschaften werden verwendet, um die Kompatibilität des Geräts für die Updatebereitstellung zu überprüfen. Damit alle für die Kompatibilität angegebenen Eigenschaften verwendet werden, dürfen die Werte nur in Kleinbuchstaben angegeben werden.
additionalProperties Optionales Feld. Zusätzliche vom Gerät gemeldete Eigenschaften können festgelegt und für die Kompatibilitätsprüfung verwendet werden. Auf fünf Geräteeigenschaften beschränkt. Diese Eigenschaften sollten nur in Kleinbuchstaben vorliegen.
connectionType Zulässige Werte sind string und AIS. Verwenden Sie string, wenn Sie das Gerät zu Testzwecken manuell mit IoT Hub verbinden. Verwenden Sie für Produktionsszenarien AIS, wenn Sie den IoT-Identitätsdienst zum Verbinden des Geräts mit IoT Hub verwenden. Weitere Informationen finden Sie unter Grundlegendes zu Konfigurationen des IoT-Identitätsdiensts.
connectionData Fügen Sie bei „connectionType = "string"“ hier die Verbindungszeichenfolge Ihres IoT-Geräts, Geräts oder Moduls hinzu. Wenn „connectionType = "AIS"“, legen Sie connectionData auf eine leere Zeichenfolge fest("connectionData": "").
Hersteller Wird vom Device Update-Agent als Teil der Schnittstelle DeviceInformation gemeldet.
model Wird vom Device Update-Agent als Teil der Schnittstelle DeviceInformation gemeldet.
extensionsFolder Optionales Feld. Dieser Pfad legt den Pfad für den Ordner „ADU-Erweiterungen“ fest. Der Standardpfad lautet „/var/lib/adu/extensions“
downloadsFolder Optionales Feld. Dieser Pfad legt den Pfad für den Ordner „ADU-Downloads“ fest. Der Standardpfad lautet „/var/lib/adu/downloads“
aduShellFilePath Optionales Feld. Dieser Pfad legt den Pfad für die ADU-Shell fest. Der Standardpfad ist „/usr/lib/adu“
downloadTimeoutInMinutes Optionales Feld. Dadurch wird das Downloadtimeout in Minuten für die Updatenutzlast festgelegt. Ein Wert von Null bedeutet, den Standardwert zu verwenden, der 8 Stunden beträgt.

Das Feld „Datafolder“ kann zum Festlegen des Pfads für den ADU-Datenordner verwendet werden. CheckDataDir() in der Integritätsverwaltungsprüfung, aktualisiert werden muss, um auf den Wert in der Konfigurationsdatei zu verweisen. Der Standardpfad ist „/var/lib/adu“ wird andernfalls verwendet.

Beispielinhalt der Datei „du-config.json“


{
  "schemaVersion": "1.1",
  "aduShellTrustedUsers": [
    "adu",
    "do"
  ],
  "iotHubProtocol": "mqtt",
  "compatPropertyNames":"manufacturer,model,location,environment" <The property values must be in lower case only>,
  "manufacturer": <Place your device info manufacturer here>,
  "model": <Place your device info model here>,
  "agents": [
    {
      "name": <Place your agent name here>,
      "runas": "adu",
      "connectionSource": {
        "connectionType": "string", //or “AIS”
        "connectionData": <Place your Azure IoT device connection string here>
      },
      "manufacturer": <Place your device property manufacturer here>,
      "model": <Place your device property model here>,
      "additionalDeviceProperties": {
        "location": "usa",
        "environment": "development"
      }
    }
  ]
}