事前に準備するもの
- IoTデバイス(計測する値を出力します)
- AWSアカウント
[0] 事前説明
[0-1] IoT.kyoto VIS 構築例
IoTデバイスで計測した値を出力させ、データをAPIでDynamoDB(AWSが提供するNoSQLデータベース)に送信させるためにIAM Access KeyをIAM(AWSが提供するアイデンティティ管理・アクセス管理)で取得します
IoT.kyoto VISは、DynamoDBからIoTデバイスで計測したデータを取得し、リアルタイムでグラフ化することができます
[0-2] IoT.kyoto VIS を使用するために必要なデータ
たとえば、温度と照度を出力するIoTデバイスの場合に必要なデータ
- IoTデバイスを識別するIDとタイムスタンプは必須です
- 下表の場合、temperatureとbrightnessはIoTデバイスから出力される計測対象の値です
- IoTデバイスで計測したこれらのデータは
「[1] DynamoDB構築手順」でDynamoDBのテーブルを作成後、なんらかの手段で、テーブルに書き込みます。
更に、「[3] IoT.kyoto VIS ユーザー設定」で設定することで、リアルタイムでグラフ化することが出来ます
deviceID | time | temperature | light |
---|---|---|---|
01 | 2016-03-04 10:17:44 | 25.6 | 103 |
02 | 2016-03-04 10:17:44 | 22.1 | 216 |
01 | 2016-03-04 10:17:45 | 25.8 | 98 |
02 | 2016-03-04 10:17:45 | 21.9 | 210 |
タイムスタンプは下記6種類のうちのどれかをお使い下さい。画面表示時にUTCはJSTに自動変換されます。
[JST]
YYYY-MM-DD hh:mm:ss
YYYY/MM/DD hh:mm:ss
YYYY-MM-DDThh:mm:ss.sss+0900
[UTC]
YYYY-MM-DDThh:mm:ssZ
UNIXタイムスタンプ(整数10桁)
UNIXタイムスタンプ(整数13桁)
[0-3] AWS IoTを使用する場合の設定
- AWS IoTからDynamoDBにデータを書き込む場合、標準では下図のように「payload」キーに"humidity"や"light"などのキーがネストされて計測値が記録されます。「[4] IoT.kyoto VIS グラフ設定」で、"humidity"や"light"などのキーを指定することで、リアルタイムでグラフ化することができます
データフォーマット(例)
{
"thingName": "device001",
"timestamp": "1450505098624",
"payload": {
"humidity": 40.64,
"light": 487.52,
"temperature": 29.9,
"thingName": " device001"
}
}
[1] DynamoDB構築手順
1. AWSにサインインします
左上のオレンジの立方体のアイコンをクリックしてください
[DynamoDB]のコンソールをクリックして開いてください
2. リージョンを確認します
- 特に他のリージョンを選ぶ理由がない場合は[アジアパシフィック(東京)]を選択してください
3. DynamoDB のコンソール画面で[デーブルの作成] をクリックしてください
4. テーブル名に任意の名前をつけてください
5. プライマリキーのパーティションキーに任意の名前をつけてください
データ型はIoTデバイスが出力する値に合わせて「文字列」または「数値」を選んでください
IoTデバイスの特定に分かりやすい名前を付けてください
6. [ソートキーの追加]のチェックボックスをクリックしてチェックを入れてください
7. プライマリキーのソートキーに任意の名前をつけてください
時間の特定に分かりやすい名前を付けてください
データ型はIoTデバイスが出力する値に合わせて「文字列」または「数値」を選んでください
8. テーブル設定の[デフォルト設定の使用]のチェックボックスをクリックしてチェックを外します
9. プロビジョニングされたキャパシティの[読み込み容量ユニット]と[書き込み容量ユニット]のテーブル数を設定してください
- IoTデバイス2~3個までなら「読み込み容量ユニット」が5テーブル、「書き込み容量ユニット」が5テーブルで足ります
10. [作成]をクリックしてテーブル作成は完了です
[2] IAM Access Keyを取得する
1. Identity and Access Management(IAM)コンソールを開いてください
2. [ユーザー]をクリックして開き、[新規ユーザーの作成]をクリックし、任意の名前でユーザーを作成します
- [ユーザーごとにアクセスキーを生成]のチェックボックスにチェックが入っているかどうかを確認してください
- [作成]をクリックしてユーザーを作成します
3. [ユーザーのセキュリティ認証情報を非表示]をクリックして ID と Key を表示させます
表示されたアクセスキーID とシークレットアクセスキーを控えておいてください([認証情報のダウンロード]をクリックして保存してもよい)
[閉じる]をクリックして終了します
4. ユーザーの中から、作成したユーザー名をクリックします
5. [アクセス許可]をクリックして開き、[ポリシーのアタッチ]をクリックします
6. [AmazonDynamoDBReadOnlyAccess]のチェックボックスにチェックをいれ、[ポリシーのアタッチ]をクリックして、IAM の登録は完了です
- IAMでReadOnlyAccessに設定することで、DynamoDBからデータを取得することが許可されます
[3] IoT.kyoto VIS ユーザー設定
1. メールアドレスとパスワードを入力し、[ログイン]をクリックしてください
下記エラーメッセージが表示されますので、[OK]をクリックします
2. [ユーザー設定]をクリックします
メールアドレスには、IoTデバイスから取得した計測値が閾値を超えた場合に通知メールが届きます
通知用メールアドレス欄が空欄の場合、ログインIDのメールアドレスに通知されます
4. AWSアクセス設定をします
- AWSのアクセスキーIDとシークレットアクセスキーとリージョンのコードを入力してください
リージョンのコードは下図を参照にしてください。(2016/03/10時点)
最新のリージョンはリージョンとアベイラビリティーゾーンをご確認ください。
リージョンコード | リージョン名 |
---|---|
us-east-1 | US East (N. Virginia) |
us-west-2 | 米国西部(オレゴン) |
us-west-1 | 米国西部(北カリフォルニア) |
eu-west-1 | 欧州(アイルランド) |
eu-central-1 | 欧州(フランクフルト) |
ap-southeast-1 | アジアパシフィック(シンガポール) |
ap-northeast-1 | アジアパシフィック(東京) |
ap-southeast-2 | アジアパシフィック(シドニー) |
ap-northeast-2 | アジアパシフィック (ソウル) |
sa-east-1 | 南米(サンパウロ) |
5. dynamoDBテーブル設定をします
- AWSのDynamoDBで作成したテーブルの情報を入力します
[AWS>DynamoDB>テーブル]
- DynamoDBのテーブル設定は、AWSにログイン→DynamoDBのコンソール画面からテーブルを開く→[項目]から確認できます
6. テーブル名を入力してください
7. パーティションキーを入力後、StringかNumberかを選択してください
8. ソートキー(タイムスタンプ)を入力後、StringかNumberかを選択してください
9. タイムスタンプのフォーマットは下図6種類があります(UTCはJSTに自動変換されます)。
ソートキーに合わせて設定してください
10.グラフ表示数を選択してください。可能なグラフ表示数は最大3個までです
- グラフ表示数を3個に選択した場合
11. グラフアイコンを選択してください
- アイコンを適用させたいグラフを選択し、アイコン選択からグラフアイコンを選んでください
- 選択したグラフはグラフ画面でグラフタイトルの横に表示されます
12. AWS IoTを使用の場合は、[AWS IoT連携]のチェックボックスにチェックを入れてください
13. [更新]をクリックしてユーザー設定を完了させてください
[4] IoT.kyoto VIS グラフ設定
1. [グラフ]をクリックしてください
2. [パーティションキー]をクリックして、計測したいパーティションキーを選択してください
3. DynamoDBにパーティションキーを追加した場合は、反映されるまでに10分程かかるの場合があるので、早く表示したい場合はパーティションキーを直接入力して[追加]をクリックしてください
追加した後、2の手順と同じようにパーティションキーを選択してください。
4.[表示対象キー]を選択して、計測したい表示対象キーを選択してください
5.グラフ表示させたい[表示対象キー]がない場合は、[表示対象キー手入力]をクリックしてから入力し、[追加]をクリックしてください
追加した後、4の手順と同じように表示対象キーを選択してください。
6. ギアマークを選択して[グラフ設定]を表示させてください
7. [グラフ設定]では、[グラフ更新間隔(1~600秒)]、[グラフ1閾値]、[グラフ2閾値]、[グラフ3閾値]、[リアルタイムグラフ描画幅]の編集が出来ます
8.[リアルタイムグラフ描画幅]はグラフの横軸を設定します
- [グラフ更新間隔]に応じて選択できる[リアルタイムグラフ描画幅]が変わります
9.グラフ設定の編集が終わったら、[OK]をクリックして、編集を終了してください
10. レンジ設定を自動か手動に設定するかを、チェックボックスをクリックすると、選択可能になります
- 手動に設定する場合、グラフの縦軸の最小値と最大値を入力してレンジを設定してください
- レンジ設定を手動にすることによって、最小値と最大値が固定されたグラフが表示されます
12. レンジ設定を自動に設定した場合、最小値と最大値が取得した計測値の大きさによって変動します
13. グラフタイトルを記入し[保存]をクリックすることで、複数のパーティションキーを区別しやすくすることが出来ます
14.リアルタイムグラフの計測中に設定した閾値を超えた場合、異常履歴に発生日時の記録が残ります。[異常履歴]をクリックすることで確認することができます
15. 異常履歴の[発生日時]をクリックし、[OK]をクリックすると、画面をスクロールした一番下の右下のグラフに異常が発生した日時前後のグラフが表示されます
16. 日時指定を入力することで、指定した範囲のグラフを表示することができます
17. [日付]の入力欄をクリックするとカレンダーが表示されますので、指定したい日付を選択してください
18.時刻の書式は、ユーザー設定に登録した通りの書式で入力してください
19.設定した日付・時刻の以前、以降か前後かを選択してください
20.日時設定に間違いがなければ、[送信]をクリックしてください
21.右側に指定した範囲のグラフが表示されます