Wemos D1 ESP8266, MQTT-соединение ioBroker (Raspberry Pi 3, модель B) не удалось - PullRequest
0 голосов
/ 12 февраля 2019

У меня Raspberry Pi 3 Model B с ioBroker (Raspbian light Stretch) в качестве брокера MQTT и Wemos D1 ESP 8266 с тестовым скриптом.Оба устройства подключены к сети через Wi-Fi.

Хорошие новости:

1) Я могу отправить сигнал MQTT с телефона (приложения myMQTT), и он будет отображаться в ioBrokerлоги (телефон подключен к Wi-Fi, MicroTik).Я могу отправить сигнал MQTT со своего ноутбука (подключенного к Wi-Fi или Ethernet).Я могу отправить успешный сигнал MQTT с виртуального сервера Debian (на vmware).

2) Wemos D1 успешно подключается к тестовому серверу test.mosquitto.org.

Плохие новости: WemosD1 не хочет подключаться к ioBroker в локальной сети и сообщает об ошибке «Попытка подключения MQTT ... не удалась, rc = -2 повторить попытку через 5 секунд».

Почему все устройства, кроме Wemos D1 ESP 8266успешно подключиться к брокеру mqtt?Может ли быть дело в брандмауэре?Подскажите, пожалуйста, что мне делать, чтобы решить эту проблему.

/*
 Basic ESP8266 MQTT example

 This sketch demonstrates the capabilities of the pubsub library in combination
 with the ESP8266 board/library.

 It connects to an MQTT server then:
  - publishes "hello world" to the topic "outTopic" every two seconds
  - subscribes to the topic "inTopic", printing out any messages
    it receives. NB - it assumes the received payloads are strings not binary
  - If the first character of the topic "inTopic" is an 1, switch ON the ESP Led,
    else switch it off

 It will reconnect to the server if the connection is lost using a blocking
 reconnect function. See the 'mqtt_reconnect_nonblocking' example for how to
 achieve the same result without blocking the main loop.

 To install the ESP8266 board, (using Arduino 1.6.4+):
  - Add the following 3rd party board manager under "File -> Preferences -> Additional Boards Manager URLs":
       http://arduino.esp8266.com/stable/package_esp8266com_index.json
  - Open the "Tools -> Board -> Board Manager" and click install for the ESP8266"
  - Select your ESP8266 in "Tools -> Board"

*/

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

// Update these with values suitable for your network.

const char* ssid = "XXX";
const char* password = "XXX";
const char* mqtt_server = "test.mosquitto.org";

WiFiClient espClient;
PubSubClient client(espClient);
long lastMsg = 0;
char msg[50];
int value = 0;

void setup_wifi() {

  delay(5000);
  // We start by connecting to a WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);
  WiFi.mode (WIFI_STA);
  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(1000);
    Serial.print(".");
  }

  randomSeed(micros());

  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println();

  // Switch on the LED if an 1 was received as first character
  if ((char)payload[0] == '1') {
    digitalWrite(BUILTIN_LED, LOW);   // Turn the LED on (Note that LOW is the voltage level
    // but actually the LED is on; this is because
    // it is active low on the ESP-01)
  } else {
    digitalWrite(BUILTIN_LED, HIGH);  // Turn the LED off by making the voltage HIGH
  }

}

void reconnect() {
  // Loop until we're reconnected
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    // Create a random client ID
    String clientId = "ESP8266Client-";
    clientId += String(random(0xffff), HEX);
    // Attempt to connect
    if (client.connect(clientId.c_str())) {
      Serial.println("connected");
      // Once connected, publish an announcement...
      client.publish("outTopic", "hello world");
      // ... and resubscribe
      client.subscribe("inTopic");
    } else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(1000);
    }
  }
}

void setup() {
  pinMode(BUILTIN_LED, OUTPUT);     // Initialize the BUILTIN_LED pin as an output
  Serial.begin(115200);
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
}

void loop() {

  if (!client.connected()) {
    reconnect();
  }
  client.loop();

  long now = millis();
  if (now - lastMsg > 2000) {
    lastMsg = now;
    ++value;
    snprintf (msg, 50, "hello world #%ld", value);
    Serial.print("Publish message: ");
    Serial.println(msg);
    client.publish("outTopic", msg);
  }
}

Скриншоты: 1) netstat -tulpn |grep LISTEN

2) Журнал ioBrocker

3) Arduino IDE

ОБНОВЛЕНИЕ:

Я не нашел, где можно изменить или отключить порт прослушивания 1883 tcp6.

Но мне удалось установить соединение между устройствами, заменив маршрутизатор Mikrotik на Keenetic.

Теперь нам нужно выяснить, что не так с настройками роутера.

1 Ответ

0 голосов
/ 13 февраля 2019

Ваш скриншот:

enter image description here

показывает, что ioBroker прослушивает интерфейс обратной связи IPv4 (127.0.0.1) для портов 9000 и 9001 и включенинтерфейс tcp6 (IPv6) для портов 8081, 8082 и 1883.

Это означает, что он доступен только через IPv4 из программ, работающих на том же сервере, или из программ, работающих на компьютерах, способных передавать IPv6.

ESP8266 не способен говорить по IPv6.

Вам необходимо перенастроить ioBroker для прослушивания 0.0.0.0:mqtt, чтобы программное обеспечение IPv4 могло достигнуть его.

...