この文書の現在のバージョンと選択したバージョンの差分を表示します。
両方とも前のリビジョン 前のリビジョン 次のリビジョン | 前のリビジョン | ||
raspberry_pi:aws_iot [2017/10/26 05:01] fifi |
raspberry_pi:aws_iot [2017/11/01 00:17] (現在) fifi |
||
---|---|---|---|
ライン 2: | ライン 2: | ||
## aws チュートリアル | ## aws チュートリアル | ||
- | [Raspberry Pi の接続](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/iot-sdk-setup.html) | + | - IAMユーザを作成 |
+ | - 必要なポリシーをつける | ||
+ | - S3ならS3FullAccess | ||
+ | - S3にバケットを作る | ||
+ | - (重要) バケットポリシーの設定 | ||
- | - [AWS IoT SDK チュートリアル](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/sdk-tutorials.html) | + | ``` |
- | - [Raspberry Pi の接続](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/sdk-tutorials.html) | + | { |
- | - [AWS IoT Embedded C SDK の使用 - AWS IoT](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/iot-embedded-c-sdk.html) | + | "Id": "Policy1509494334229", |
- | - [AWS IoT Device SDK for JavaScript を使用する - AWS IoT](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/iot-device-sdk-node.html) | + | "Version": "2012-10-17", |
+ | "Statement": [ | ||
+ | { | ||
+ | "Sid": "Stmt1509494331498", | ||
+ | "Action": "s3:*", | ||
+ | "Effect": "Allow", | ||
+ | "Resource": "arn:aws:s3:::pmonitor1/*", | ||
+ | "Principal": { | ||
+ | "AWS": [ | ||
+ | "*" | ||
+ | ] | ||
+ | } | ||
+ | } | ||
+ | ] | ||
+ | } | ||
+ | ``` | ||
- | + | 送ってみる | |
- | - __done__ [Raspberry Pi の接続](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/sdk-tutorials.html) | + | ``` |
- | - AWS Iot コンソールにサインインする | + | aws s3 cp s3-text.txt s3://<your-bucket>/ |
- | - __done__ モノを作る | + | |
- | - __done__ REST APIエンドポイント ag7srsxum1sn0.iot.us-west-2.amazonaws.com | + | |
- | - __done__ 証明書の発行 | + | |
- | - __done__ ポリシーの作成 | + | |
- | - __done__ 証明書にポリシーをアタッチ | + | |
- | - __done__ 証明書にモノをアタッチ | + | |
- | + | ||
- | - [AWS IoT Embedded C SDK の使用 - AWS IoT](http://docs.aws.amazon.com/ja_jp/iot/latest/developerguide/iot-embedded-c-sdk.html) | + | |
- | - 証明書の名前を変更しておく? | + | |
- | - ディレクトリに証明書番号 | + | |
- | - private.pem.key, public.pem.key, certificate.pem.crt, root-CA.crt | + | |
- | - __done__ これで、Raspberry Pi は AWS IoT Device SDK for C を使用して AWS IoT に接続されました。 | + | |
- | - ルールを作成する | + | |
- | + | ||
- | - __失敗__ [IoTを使って畑を監視する 2015.12.20](https://tech.recruit-mp.co.jp/iot/farm-monitoring-with-iot/) | + | |
- | - iot_client.jsが動かない。nodojsが分からないのでエラーの原因が分からん。古そう。 | + | |
- | - __here__ pythonでやってみる。 | + | |
- | - [AWS IOT SDK](https://aws.amazon.com/jp/iot/sdk/) | + | |
- | - できた!! requre('sys')を消すことでうごいた! | + | |
- | - __失敗__ DynamoDBの使い方が分からない。基本からチュートリアルをしないとだめ。一旦中断 | + | |
- | + | ||
- | ## 成功方法 | + | |
``` | ``` | ||
- | モノを作成 | ||
- | 名前:raspi_41_1 | ||
- | ルールを作成 | ||
- | 名前:raspiRule_41_1 | ||
- | メッセージのリソース | ||
- | 属性:*, トピックフィルター:topic/sns, 条件:空欄 | ||
- | [アクションの追加]クリック | ||
- | 「SNSプッシュ通知としてメッセージを送信する」を選択 | ||
- | SNSターゲット:iot-sns_test (作成する) | ||
- | 次のページ | ||
- | メッセージ形式:初期値のまま(JSONにした方が良かった?) | ||
- | IAMロール名:[新しいロールの作成]クリック | ||
- | [新しいロールの作成]クリック | ||
- | IAMロール名:aws_iot_sns_test | ||
- | [新しいロールの作成]クリック | ||
- | [ルールを作成する]クリック | ||
- | SNSトピックの作成 | ||
- | SNSターゲットで[新しいリソースを作成する]クリック | ||
- | [Create new topic]クリック | ||
- | Topic name:iot-sns_test | ||
- | [Create Topic]クリック | ||
- | リストから iot-sns_test を選択 | ||
- | [Create subscription]クリック | ||
- | Topic ARN:初期値のまま | ||
- | Protocol:Email | ||
- | Endpoint:(送信先のメールアドレス) | ||
- | [Create subscription]クリック | ||
- | 受信したメールの Confirm Subscription をクリック | ||
- | ポリシーの作成 | ||
- | 名前:raspiPolicy | ||
- | アクション:iot:* | ||
- | リソースARN:* | ||
- | 許可:ON | ||
- | [作成]クリック | ||
- | |||
- | |||
- | |||
- | 証明書の作成 | ||
- | 1-Click証明書作成の[証明書の作成]クリック | ||
- | 生成された「このモノの証明書」「プライベートキー」をダウンロード | ||
- | ルートCA証明書もダウンロード (名前を rootCA.pem にした) | ||
- | [ポリシーのアタッチ]クリック | ||
- | raspiPolicyを選択して[完了]クリック | ||
- | 左のメニュー セキュリティ/証明書 から証明書を選択 | ||
- | アクション - モノをアタッチする で raspi_41_1 をアタッチ | ||
- | アクション - 有効化 | ||
- | |||
- | |||
- | Raspberry Pi 3 からデータ送信 | ||
- | Mosquittoクライアントを使用 | ||
- | sudo apt-get install -y mosquitto-clients | ||
- | 5分毎に気温、気圧、湿度を取得して送信 | ||
- | |||
- | |||
- | import time | ||
- | from subprocess import check_call | ||
- | from sense_hat import SenseHat | ||
- | sense = SenseHat() | ||
- | |||
- | while True: | ||
- | t = round(sense.get_temperature(), 1) | ||
- | p = round(sense.get_pressure(), 1) | ||
- | h = round(sense.get_humidity(), 1) | ||
- | |||
- | msg = "{'message':" + "'Temperature:%s, Pressure:%s, Humidity:%s'" % (t,p,h) + "}" | ||
- | |||
- | check_call(["mosquitto_pub", "--cafile", "rootCA.pem", "--cert", "4f2df38695-certificate.pem.crt", "--key", "4f2df38695-private.pem.key", | ||
- | "-h", "ajm28n1yz8oj0.iot.ap-northeast-1.amazonaws.com", "-p", "8883", "-q", "1", "-d", "-t", "topic/sns", "-m", msg]) | ||
- | |||
- | sense.show_message(msg, scroll_speed=0.05) | ||
- | sense.clear() | ||
- | |||
- | time.sleep(300) | ||
- | |||
- | |||
- | |||
- | |||
- | |||
- | -> 登録したメールアドレスにメールが送られてきた! | ||
- | {'message':'Temperature:35.3, Pressure:1016.9, Humidity:46.6'} | ||
- | |||
- | ``` | ||