ESP8266 глубокий сон и MQTT

Я работаю над проектом, в котором я перевожу свою плату в режим глубокого сна, и она просыпается по прерыванию от датчика. Когда он выйдет из глубокого сна, я хотел бы отправить сообщение моему MQTT-брокеру. Проводка работает, прерывание работает, а код нет.

Когда я использую опубликованный код, в консоли все выглядит нормально, я получаю все операторы печати, что заставляет меня предположить, что он работает. Однако мой брокер MQTT не показывает никаких сообщений. Но если я перенесу «sendMQTTMessage()» в функцию цикла, все будет работать нормально, и сообщения дойдут до моего брокера.

Будем очень благодарны за любые предложения

#include <ESP8266WiFi.h>
#include <PubSubClient.h>

const char* ssid = "*";
const char* ss_pswd = "*";
const char* mqtt_server = "*";
WiFiClient EspClient;
PubSubClient client(EspClient);

void wifi_setup() {
  Serial.print("Connecting to: ");
  Serial.println(ssid);
  WiFi.begin(ssid, ss_pswd);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.println(".");
  }
  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}
void reconnect() {
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    String ClientId = "ESP8266";
    ClientId += String(random(0xffff), HEX);
    if (client.connect(ClientId.c_str())) {
      Serial.println("connected");
      client.publish("outtopic", "hello world, finally");
      client.subscribe("/room/test");
    } else {
      Serial.print("failed, rc=");
      Serial.println(client.state());
      Serial.println("Try again...");
      delay(5000);
    }
  }
}
void sendMQTTMessage() {
  Serial.println("sending your message");
  if (!client.connected()) {
    reconnect();
  }
  client.publish("belmont/sensor/pir/hallway", "on");
}
void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived: ");
  Serial.println(topic);
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
}
void setup() {
  Serial.begin(115200);
  wifi_setup();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
  sendMQTTMessage();
  Serial.println("going into deep sleep");
  ESP.deepSleep(10 * 1000000);
}

void loop() {
// sendMQTTMessage();
// задержка(5000);
}

, 👍3

Обсуждение

мому брокеру приходят сообщения ..... так в чем же на самом деле проблема и каков ваш вопрос?, @jsotola

Они проходят через моего брокера только тогда, когда я помещаю «sendMQTTMessage()» внутри функции цикла БЕЗ перевода ее в глубокий сон. В ту минуту, когда я начинаю использовать глубокий сон, я не получаю сообщений от брокера., @Paul Carlson

выводится ли какая-либо из «Попытка подключения MQTT...»?, @Jaromanda X

попробуйте задержку после отправки, @Juraj


1 ответ


1

На самом деле ответ на этот вопрос получит Юрай. Дело в том, что мне не хватало задержки. Оглядываясь назад, это имеет смысл, поскольку, хотя я выполняю задачи по порядку, система отключается до того, как будет отправлено фактическое сообщение. Я добавил задержку (1000) между sendMQTTMessage() и ESP.deepsleep(), и это сработало.

,