質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.09%

ESP-WROOM-02(Arduino)からMilkcocoaへPushできない

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 424

chibita

score 12

前提・実現したいこと

ESP-WROOM-02開発ボード使用して、
アナログ値(センサー)をMilkcocoaへPushしたい。

発生している問題・エラーメッセージ

sendはonsendで通知は受け取れている。

pushしてもデータストアに保存されず、onpushでキャッチできていない。

MIlkcocoaのfreeboardでリアルタイムで通知状況を見ていても
sendは受信しているが、pushは受信できていない。

該当のソースコード

SSID等は書き換えてます。

#include <ESP8266WiFi.h>
#include <Milkcocoa.h>

//**********************************************************************
//定数宣言
//WiFi Access Point

#define WLAN_SSID "ssid"
#define WLAN_PASS "pass"

//Milkcocoa Setup
#define MILKCOCOA_APP_ID      "app_id"
#define MILKCOCOA_DATASTORE   "esp8266"
#define MILKCOCOA_SERVERPORT  1883
#define MILKCOCOA_API_KEY     "api_key"
#define MILKCOCOA_ARI_SELECT  "api_select"


// Create an ESP8266 WiFiClient class to connect to the MQTT server.
WiFiClient client;

const char MQTT_SERVER[] PROGMEM    = MILKCOCOA_APP_ID ".mlkcca.com";
const char MQTT_CLIENTID[] PROGMEM  = __TIME__ MILKCOCOA_APP_ID;

//Milkcocoa milkcocoa = Milkcocoa(&client, MQTT_SERVER, MILKCOCOA_SERVERPORT, MILKCOCOA_APP_ID, MQTT_CLIENTID);
Milkcocoa *milkcocoa = Milkcocoa::createWithApiKey(&client, MQTT_SERVER, MILKCOCOA_SERVERPORT, MILKCOCOA_APP_ID, MQTT_CLIENTID, MILKCOCOA_API_KEY, MILKCOCOA_ARI_SELECT);
//loop関数で使用
int loopCounter = 0;
//**********************************************************************

//Wi-Fi接続処理関数
void setupWiFi() {
  // Connect to WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(WLAN_SSID);

  //WiFi start
  WiFi.begin(WLAN_SSID, WLAN_PASS);
  int wifiCounter = 0;

  //WiFi接続完了までループ
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");

    //20回失敗したらリセット→再試行
    if(wifiCounter > 20) {
      Serial.println("Failed to connect WiFi. Reset now.");
      delay(500);
      ESP.deepSleep(2 * 1000 * 1000);
      delay(1000);
    }

    delay(50);
    wifiCounter++;
  }
  Serial.println("");
  Serial.println("WiFi connected");

  // 接続成功 IP address表示
  Serial.println(WiFi.localIP());
  Serial.println("=====================================");
  Serial.println("");
}

//Milkcocoa接続処理関数
void connectToMilkcocoa() {
  //接続できなかったら失敗したとみなして再起動
  if(!milkcocoa->loop()){
    Serial.println("Failed to connect Milkcocoa. Reset now.");
    delay(500);
    ESP.deepSleep(2 * 1000 * 1000);
    delay(1000);
  }
  Serial.println("connected Milkcocoa.");
}


//Milkcocoaにデータが書き込まれると呼び出される
//つまり送信成功→書き込まれたデータを取得しシリアル出力
//60分後に再起動
void onpush(DataElement *elem) {
  Serial.println("Onpush comming.");
  Serial.print("Get value: ");
  Serial.println(elem->getInt("moisture"));

  Serial.println("Sleep start, reset after 60 minutes.");
  delay(500);

  //Test 10秒
  ESP.deepSleep(10 * 1000 * 1000);

  //本稼働時は60分DeepSleep
  //  ESP.deepSleep(3600 * 1000 * 1000);
  delay(1000);
}


void onsend(DataElement *elem) {
  Serial.println("Onsend comming.");
}

//**********************************************************************

//初期処理
void setup() {
  //シリアル出力起動
  Serial.begin(115200);
  delay(10);

  //Wi-Fi接続処理
  setupWiFi();

  //Milkcocoa 接続
  if( milkcocoa->on(MILKCOCOA_DATASTORE, "push", onpush) ){
    Serial.println("Milkcocoa on sucesss○");
  }
  else {
    Serial.println("Milkcocoa on failure×");
  }

  if( milkcocoa->on(MILKCOCOA_DATASTORE, "send", onsend) ){
    Serial.println("Milkcocoa on send sucesss○");
  }
  else {
    Serial.println("Milkcocoa on send failure×");
  }
  Serial.println();
}


//メイン処理
void loop() {
  int sensorValue = 0;

  //Milkcocoa接続処理
  connectToMilkcocoa();

  delay(1000);

  //土壌湿度センサー値取得
  sensorValue = analogRead(A0);
  Serial.print("Moisture Sensor Value:");
  Serial.println(sensorValue);  

  //Milkcocoaへのデータ作成
  DataElement elem = DataElement();
  elem.setValue("moisture", sensorValue);

  //作成データ送信(1回目のループのときのみ)
  if(loopCounter == 0){
    milkcocoa->push(MILKCOCOA_DATASTORE, &elem);
    delay(10000);
//    milkcocoa->send(MILKCOCOA_DATASTORE, &elem);
  }


  //ループが10回呼ばれたら失敗したとみなす
  if(loopCounter > 10){
    Serial.println("Failed to push data to Milkcocoa. Reset now.");
    delay(500);
    //Max値失敗したらリセット→再試行
    ESP.deepSleep(2 * 1000 * 1000);
    delay(1000);
  }
  loopCounter++;
}

シリアルモニタの出力内容

Connecting to aterm-1ee3cb-g
.......
WiFi connected
192.168.10.9
=====================================

Milkcocoa on sucesss○
Milkcocoa on send sucesss○

Connecting to MQTT... MQTT Connected!
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:8
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
connected Milkcocoa.
Moisture Sensor Value:9
Failed to push data to Milkcocoa. Reset now.

試したこと

・接続にAPI Key認証ありなしでも変わらない。(いづれもsendはできている)
・push後にdelayかけても変わらない。
・ボードマネージャを変えてもできない
2.3.0
2.4.0-rc2
2.4.0(コンパイルエラーになる)
2.5.1(コンパイルエラーになる)
2.5.2(コンパイルエラーになる)

補足情報(FW/ツールのバージョンなど)

Arduino IDE:1.8.9
ボードマネージャ:2.3.0/2.4.0-rc2
ESP-WROOM-02開発ボード
秋月電子通商さんの開発ボードを使用しています。
http://akizukidenshi.com/catalog/g/gK-12236/

どうか皆様の知恵をお借り致したく。
宜しくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

0

Milkcocoaの記事を見てたら、無料プランではpush数に上限があるというはなしですが、
そこらへんは大丈夫でしょうか

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/06/01 09:01

    y_waiwai様
    ご回答ありがとうございます。

    上限数の件は以下ですね。
    https://mlkcca.com/price.html

    メッセージ数は20件程度のsendをしたのみで、上限には程遠いです。

    初めからpushがされずデータストアには何も追加されないので保存データ数の上限にも達してません。

    接続数は1台のみ。

    ご指摘の内容については問題無いと思います。

    ルーターの1883ポート解放も試しましたがこれも該当しませんでした。

    色々と調べてますが、困り果ててます。

    過去記事は問題なく動いているとの内容ばかりで…。

    何がいけないのでしょう?

    キャンセル

0

アプリを作り直してみてはどうでしょうか?
同じような現象になり、新しくアプリを作ってみると、データストアに正しく追加・更新されるようになりました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/06/26 22:10

    KKinoshita様
    ご回答ありがとうございます。
    新しく作り直して、再度試してみます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.09%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる