チュートリアル: Ubuntu Server 18.04 x64 上のパッケージ エージェントを使用した Device Update for Azure IoT Hub
Device Update for Azure IoT Hub では、イメージベース、パッケージベース、スクリプトベースの更新がサポートされています。
パッケージベースの更新は、デバイス上の特定のコンポーネントまたはアプリケーションのみを変更するターゲット指定の更新となります。 これにより、帯域幅の消費量が少なくなるほか、更新のダウンロードとインストールにかかる時間が短縮されます。 また、通常、パッケージベースの更新プログラムを使用した場合も、更新プログラムを適用するときのデバイスのダウンタイムを短縮し、イメージ作成のオーバーヘッドを回避できます。 また、APT マニフェスト ファイルで指定されたパッケージ (およびその依存関係) を指定されたリポジトリからダウンロードしてインストールするために必要な情報を、デバイス更新エージェントに提供する APT マニフェストが使用されています。
このチュートリアルでは、Device Update パッケージ エージェントを使用して、Ubuntu Server 18.04 x64 の Azure IoT Edge を更新する手順について説明します。 このチュートリアルでは IoT Edge の更新を扱いますが、同様の手順を使用すれば、他のパッケージ、たとえば使用されているコンテナー エンジンを更新することもできます。
このチュートリアルで取り上げるツールと概念は、使用を検討している OS プラットフォーム構成が異なる場合にも当てはまります。 ここでは、エンド ツー エンドの更新プロセスの概要について説明します。 次に、OS プラットフォームを更新するための適切な形式を選択して、詳細を確認します。
このチュートリアルでは、次の方法について説明します。
- デバイス更新エージェントとその依存関係をダウンロードしてインストールする
- デバイスにタグを追加する
- 更新プログラムをインポートする
- デバイス グループを作成する
- パッケージの更新をデプロイする
- 更新プログラムのデプロイを監視する
前提条件
Device Update アカウントとインスタンスをまだ作成していない場合は作成します。 IoT ハブを構成します。
IoT Edge デバイスの接続文字列が必要です。
前のテストでシミュレーター エージェントのチュートリアルを使用した場合は、次のコマンドを実行して APT ハンドラーを呼び出し、このチュートリアルの無線でのパッケージの更新をデプロイできます。
# sudo /usr/bin/AducIotAgent --register-content-handler /var/lib/adu/extensions/sources/libmicrosoft_apt_1.so --update-type 'microsoft/a pt:1'
デバイスを準備する
デバイスを自動的に、または手動で準備します。
自動化された [Azure へのデプロイ] ボタンを使用する
Ubuntu 18.04 LTS 仮想マシンを短時間で設定しやすいように、このチュートリアルでは便宜上 cloud-init ベースの Azure Resource Manager テンプレートを使用します。 Azure IoT Edge ランタイムと Device Update パッケージ エージェントが両方インストールされます。 次に、指定した IoT Edge デバイスのデバイス接続文字列 (前提条件) を使用して、プロビジョニング情報を含むデバイスが自動的に構成されます。 また、Resource Manager テンプレートを使用すれば、セットアップを完了するために SSH セッションを開始する必要はありません。
開始するには、ボタンを選択します。
使用可能なテキストボックスに入力します。
- サブスクリプション:仮想マシンをデプロイするためのアクティブな Azure サブスクリプション。
- [リソース グループ]: 仮想マシンとそれに関連付けられたリソースを格納する、既存の、または新規に作成されたリソース グループ。
- [リージョン]: 仮想マシンをデプロイする 地理的リージョン。 この値の既定値は、選択したリソース グループの場所です。
- [DNS ラベル プレフィックス]: 仮想マシンのホスト名のプレフィックスとして使用される、ユーザーが選択する必須の値。
- [管理ユーザー名]: ユーザー名。デプロイ時にルート権限が与えられます。
- [デバイス接続文字列]: 目的の IoT hub 内に作成された、デバイス用のデバイス接続文字列。
- [VM サイズ]: デプロイする仮想マシンのサイズ。
- [Ubuntu OS バージョン] :ベース仮想マシンにインストールする Ubuntu OS のバージョン。 既定値は変更せず、そのままにしておいてください。あらかじめ Ubuntu 18.04-LTS に設定されます。
- [認証の種類]: sshPublicKey または パスワード を選択します。
- [管理パスワードまたはキー]: 認証の種類の選択に応じて、SSH 公開キーの値、またはパスワードの値。
すべてのボックスに入力した後、ページの下部にあるチェックボックスをオンにして、使用条件に同意します。 [購入] を選択してデプロイを開始します。
デプロイが正常に完了したことを確認します。 デプロイの完了後、インストール後の処理と構成で IoT Edge とデバイス パッケージ更新エージェントがインストールされるまで数分待ちます。
仮想マシン リソースが、選択したリソース グループにデプロイされている必要があります。
vm-0000000000000
という形式のコンピューター名をメモします。 また、関連付けられている DNS 名は<dnsLabelPrefix>
.<location>
.cloudapp.azure.com という形式であることにも注意してください。DNS 名は、Azure portal に新しくデプロイされた仮想マシンの [概要] セクションから取得できます。
ヒント
設定後にこの VM に SSH 接続する場合は、次のコマンドと関連付けられている DNS 名を使用します。
ssh <adminUsername>@<DNS_Name>
構成の詳細を開きます (以下のコマンドを使用してここで構成ファイルを設定する方法を参照してください。 connectionType を 'AIS' に、connectionData を空の文字列として設定します。
/etc/adu/du-config.json
- 次のコマンドを実行して、Device Update エージェントを再起動します。
sudo systemctl restart adu-agent
Device Update for Azure IoT Hub ソフトウェア パッケージには、次のライセンス条項が適用されます。
パッケージを使用する前にライセンス条項をお読みください。 インストールし、パッケージを使用すると、これらの条項に同意したものと見なされます。 ライセンス条項に同意しない場合は、そのパッケージを使用しないでください。
デバイスを手動で準備する
以下に示したのは、cloud-init スクリプトによって自動化される手順と同じようにデバイスのインストールと構成で使用される手動の手順です。 次の手順を使用して物理デバイスを準備します。
「Azure IoT Edge ランタイムをインストールする」の手順に従います。
注意
Device Update エージェントは IoT Edge に依存しません。 ただし、ID を取得して IoT Hub に接続するために、IoT Edge (1.2.0 以上) と一緒にインストールされる IoT ID サービス デーモンに依存します。
このチュートリアルでは取り上げませんが、IoT ID サービス デーモンは Linux ベースの IoT デバイスにスタンドアロンでインストールすることができます。 インストールの順序が重要です。 Device Update パッケージ エージェントは、IoT ID サービスの "後に" インストールする必要があります。 そうしないと、承認済みのコンポーネントとしてパッケージ エージェントが登録されず、IoT Hub との接続が確立されません。
Device Update エージェントの .deb パッケージをインストールします。
sudo apt-get install deviceupdate-agent deliveryoptimization-plugin-apt
次のコマンドを実行して、IoT デバイスのモジュール (Device Update を使用してデバイスをプロビジョニングした方法によってはデバイス) のプライマリ接続文字列を構成ファイルに入力します。
/etc/adu/du-config.json
次のコマンドを実行して、Device Update エージェントを再起動します。
sudo systemctl restart adu-agent
Device Update for Azure IoT Hub ソフトウェア パッケージには、次のライセンス条項が適用されます。
パッケージを使用する前にライセンス条項をお読みください。 インストールし、パッケージを使用すると、これらの条項に同意したものと見なされます。 ライセンス条項に同意しない場合は、そのパッケージを使用しないでください。
デバイスにタグを追加する
Azure portal にサインインし、IoT ハブに移動します。
左側のウィンドウの [デバイス] で、対象の IoT Edge デバイスを見つけて、デバイス ツインまたはモジュール ツインに移動します。
Device Update エージェント モジュールの [モジュール ツイン] で、既存の Device Update タグ値を null 値に設定して削除します。 Device Update エージェントでデバイス ID を使用している場合は、[デバイス ツイン] でそれらの変更を行います。
次に示すように、Device Update の新しいタグ値を追加します。
"tags": { "ADUGroup": "<CustomTagValue>" },
更新プログラムをインポートする
GitHub の「デバイス更新プログラムのリリース」に移動し、[アセット] ドロップダウン リストをクリックします。
Tutorial_IoTEdge_PackageUpdate.zip
を選択してダウンロードします。 フォルダーの内容を抽出して、サンプル APT マニフェスト (sample-1.0.2-aziot-edge-apt-manifest.json) とそれに対応するインポート マニフェスト (sample-1.0.2-aziot-edge-importManifest.json) を検出します。Azure portal にサインインし、Device Update がある IoT Hub に移動します。 左側のウィンドウの [デバイスの自動管理]の下で、[更新プログラム] を選択します。
[更新] タブを選択します。
[+ 新しい更新プログラムのインポート] を選択します。
[+ ストレージ コンテナーから選択] を選択します。 [+ ストレージ アカウント] を使用して、既存のストレージ アカウントを選択するか、新しいストレージ アカウントを作成します。 次に、既存のコンテナーを選択するか、[+ コンテナー] を使用して新しいコンテナーを作成します。 このコンテナーは、インポート用に更新ファイルをステージするために使用されます。
注意
以前の更新プログラムから誤ってファイルをインポートしないように、更新プログラムをインポートするごとに新しいコンテナーを使用することをお勧めします。 新しいコンテナーを使用しない場合は、この手順を実行する前に、既存のコンテナーからファイルを削除してください。
コンテナーで [アップロード] を選択し、手順 1 でダウンロードしたファイルに移動します。 すべての更新ファイルを選択した後、[アップロード] を選択します。 続いて [選択] ボタンを選択して、[更新プログラムのインポート] ページに戻ります。
このスクリーンショットは、インポートの手順を示しています。 ファイル名は、例で使用されているものと一致しない場合があります。
[更新プログラムのインポート] ページで、インポートするファイルを確認します。 次に、[更新プログラムのインポート] を選択してインポート プロセスを開始します。
インポート プロセスが開始され、画面が [インポートの履歴] セクションに切り替わります。 [状態] 列にインポートが正常に完了したことが表示されたら、[使用可能な更新プログラム] 見出しを選択します。 インポートされた更新プログラムが一覧に表示されるはずです。
更新プログラムをインポートする方法の詳細については、こちらを参照してください。
更新グループの作成
ページの上部にある [グループとデプロイ] タブに移動します。
[グループの追加] ボタンを選択して、新しいグループを作成します。
一覧から [IoT Hub] タグと [デバイス クラス] を選択します。 次に [グループの作成] を選択します。
グループが作成された後、更新プログラムのコンプライアンス チャートとグループの一覧が更新されていることを確認します。 更新プログラムのコンプライアンス チャートには、さまざまなコンプライアンス対応状態 (最新の更新状態、利用可能な新しい更新プログラムがある、更新プログラムのインストールが進行中) にあるデバイスの数が表示されます。 更新プログラムのコンプライアンスの詳細についてはこちらを参照してください。
新しく作成したグループと、新しいグループ内のデバイスで利用可能な更新プログラムが表示されます。 グループのデバイス クラスの要件を満たしていないデバイスがある場合は、対応する無効なグループに表示されます。 このビューから新しいユーザー定義グループに最適な利用可能な更新プログラムをデプロイするには、グループの横にある [デプロイ] を選択します。
タグを追加する方法と更新プログラム グループを作成する方向の詳細については、こちらをご覧ください。
更新プログラムをデプロイする
グループが作成された後、デバイス グループで利用可能な新しい更新プログラムが表示され、[最適な更新プログラム] の下にその更新プログラムへのリンクが表示されます。 場合によっては、一度最新の情報に更新する必要があります。 更新プログラムのコンプライアンスの詳細についてはこちらを参照してください。
グループ名を選択してターゲット グループを選択します。 [グループの基本] の下にグループの詳細が表示されます。
デプロイを開始するには、[現在のデプロイ] タブに移動します。[使用できる更新プログラム] セクションで、目的の更新プログラムの横にある [デプロイ] リンクをクリックします。 特定のグループに最適な使用可能な更新プログラムには、最適 の強調表示が付けられます。
デプロイを直ちに開始するか、後で開始するようにスケジュールします。 [作成] を選択します。
ヒント
既定の開始日時は、現在の時刻から 24 時間後です。 もっと早くデプロイしたい場合は、異なる日時を選択してください。
デプロイの詳細 で、状態 が アクティブ に変わります。 デプロイされた更新プログラムには (デプロイ中) のマークが付きます。
コンプライアンス チャートを表示して、更新が進行中であることを確認します。
デバイスが正常に更新されると、コンプライアンス チャートとデプロイの詳細が、同じ内容を反映するように更新されていることがわかります。
更新プログラムのデプロイを監視する
これで、Ubuntu Server 18.04 x64 デバイス上で Device Update for IoT Hub を使用して、エンド ツー エンドのパッケージ更新が正常に完了しました。
リソースをクリーンアップする
不要になったら、デバイス更新アカウント、インスタンス、IoT ハブクリーンアップします。 [Azure へのデプロイ] ボタンを介して VM を作成した場合は、IoT Edge デバイスもクリーンアップします。 リソースをクリーンアップするには、個々のリソースに移動して [削除] を選択します。 デバイス更新アカウントをクリーンアップする前に、デバイス更新インスタンスをクリーンアップします。
次のステップ
次のチュートリアルを使用して、Device Update for IoT Hub の簡単なデモを実行します。
- イメージの更新: Raspberry Pi 3 B+ 参照 Yocto イメージの使用を開始することに関する記事。必要に応じて他のアーキテクチャ用の独自のイメージをビルドするために、オープン ソースを通じて拡張できます。
- プロキシの更新: ダウンストリーム デバイスの Device Update バイナリ エージェントの使用を開始する
- Ubuntu (18.04 x64) シミュレーター参照エージェントの使用を開始する
- Azure リアルタイム オペレーティング システムでの Device Update for Azure IoT Hub のチュートリアル