Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. ioBroker драйвера
    5. Драйвер Mqtt + Arduino

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Драйвер Mqtt + Arduino

    This topic has been deleted. Only users with topic management privileges can see it.
    • P
      Plaha last edited by

      @instalator:

      Ненужны никакие маскиты, драйвер скмодостаточен. И запускает сервер. Проблема с твоим клиентом, он не подписывается наверное? Или отключается от сервера. На вкладке объекты в mqtt.0 топик не появился? `
      В объектах у меня следующее:
      3048_image.jpg

      1 Reply Last reply Reply Quote 0
      • P
        Plaha last edited by

        @instalator:

        Проблема с твоим клиентом, он не подписывается наверное? Или отключается от сервера. На вкладке объекты в mqtt.0 топик не появился? `
        Для проверки работы я использую стандартную команду отправки данных:

        mosquitto_pub -h localhost -p 1883 -t '/test' -m '0'

        В ответ получаю следующее сообщение, которое я писал выше.

        1 Reply Last reply Reply Quote 0
        • P
          Plaha last edited by

          Переустановил iobroker с нуля, на чистую систему.

          Делал все по этой инструкии: http://www.iobroker.net/docu/?page_id=3489&lang=ru, не настраивал только IP, так как он зарезервирован на роутере.

          В итоге ничего не изменилось.

          Подскажите, можно ли как-то включить "режим отладки", для поиска причин?

          Не понятно, почему в статусе пишет: Соединение с mqtt: нет?
          3048_image.jpg
          3048_image.jpg

          1 Reply Last reply Reply Quote 0
          • I
            instalator last edited by

            @Plaha:

            Переустановил iobroker с нуля, на чистую систему.

            Делал все по этой инструкии: http://www.iobroker.net/docu/?page_id=3489&lang=ru, не настраивал только IP, так как он зарезервирован на роутере.

            В итоге ничего не изменилось.

            Подскажите, можно ли как-то включить "режим отладки", для поиска причин?

            Не понятно, почему в статусе пишет: Соединение с mqtt: нет? `
            Я же тебе писал что проблема в клиенте а не в иоб и драйвере.

            Чтобы было соединение клиент должен быть подписан на топики.

            1 Reply Last reply Reply Quote 0
            • P
              Plaha last edited by

              @instalator:

              Я же тебе писал что проблема в клиенте а не в иоб и драйвере.

              Чтобы было соединение клиент должен быть подписан на топики. `

              Ниже код, который пытается подключиться, ошибка та же: Client error [test1/1]: Error: not implemented

              #include <esp8266wifi.h>
              #include <wificlientsecure.h>
              #include <pubsubclient.h>
              
              const char* ssid = "";
              const char*password = "";
              const char *mqtt_server = "10.1.1.1";
              const int mqtt_port = 1883; 
              unsigned int send_interval = 10;
              unsigned long last_time = 0; 
              char buff[20];
              
              int pin13 = 13; 
              
              WiFiClient ethClient;
              
              void callback(char* topic, byte* payload, unsigned int length);
              
              PubSubClient client(mqtt_server, mqtt_port, callback, ethClient);
              
              void callback(char* topic, byte* payload, unsigned int length) {
                Serial.println ("");
                Serial.println ("-------");
                Serial.println ("New callback of MQTT-broker");
                //преобразуем тему(topic) и значение (payload) в строку
                payload[length] = '\0';
                String strTopic = String(topic);
                String strPayload = String((char*)payload);
                //Исследуем что "прилетело" от сервера по подписке:
                //Управление светодиодом
                if (strTopic == "test1/setdat") {
                  if (strPayload == "off" || strPayload == "0" || strPayload == "false") digitalWrite(pin13, LOW);
                  if (strPayload == "on" || strPayload == "1" || strPayload == "true") digitalWrite(pin13, HIGH);
                }
                Serial.print (strTopic);
                Serial.print (" ");
                Serial.println (strPayload);
                Serial.println ("-------");
                Serial.println ("");
              }
              
              void wifiConnect() {
                WiFi.begin(ssid, password);
                while (WiFi.status() != WL_CONNECTED) {
                  delay(300);
                  Serial.print(".");
                  digitalWrite(pin13, 0);
                  delay(300);
                  digitalWrite(pin13, 1);
                  delay(300);
                }
              
                Serial.println("");
                Serial.println("WiFi connected");
                Serial.println("IP address: ");
                Serial.println(WiFi.localIP());
                digitalWrite(pin13, 0);
              }
              
              void setup() {
                Serial.begin(115200);
                Serial.begin(115200); 
                pinMode(pin13, OUTPUT); 
                delay(10); 
                wifiConnect();
              }
              
              void loop() {
                //Если соединение MQTT неактивно, то пытаемся установить его и опубликовать/подписаться
                if (!client.connected()) {
                  Serial.print("Connect to MQTT-boker... ");
                  //Подключаемся и публикуемся/подписываемся
                  if (client.connect("test1/1")) {
                    Serial.println("success");
                    //Значение с датчиков
                    client.publish("test1/1", "1");
                    //Подписываемся на переменную управления светодиодом
                    client.subscribe("test1/setdata");
                  } else {
                    //Если не подключились, ждем 10 секунд и пытаемся снова
                    Serial.print("Failed, rc=");
                    Serial.print(client.state());
                    Serial.println(" try again in 10 seconds");
                    delay (10000);
                  }
                  //Если соединение активно, то отправляем данные на сервер с заданным интервалом времени
                } else {
                  if (millis() > (last_time + send_interval * 1000)) {
                    last_time = millis();
                    client.publish("test1/1", "1");
                  }
                }
                //Проверка входящих соединений по подписке
                client.loop();
              }</pubsubclient.h></wificlientsecure.h></esp8266wifi.h>
              
              1 Reply Last reply Reply Quote 0
              • I
                instalator last edited by

                @Plaha:

                @instalator:

                Я же тебе писал что проблема в клиенте а не в иоб и драйвере.

                Чтобы было соединение клиент должен быть подписан на топики. `

                Ниже код, который пытается подключиться, ошибка та же: Client error [test1/1]: Error: not implemented

                #include <esp8266wifi.h>
                #include <wificlientsecure.h>
                #include <pubsubclient.h>
                
                const char* ssid = "";
                const char*password = "";
                const char *mqtt_server = "10.1.1.1";
                const int mqtt_port = 1883; 
                unsigned int send_interval = 10;
                unsigned long last_time = 0; 
                char buff[20];
                
                int pin13 = 13; 
                
                WiFiClient ethClient;
                
                void callback(char* topic, byte* payload, unsigned int length);
                
                PubSubClient client(mqtt_server, mqtt_port, callback, ethClient);
                
                void callback(char* topic, byte* payload, unsigned int length) {
                  Serial.println ("");
                  Serial.println ("-------");
                  Serial.println ("New callback of MQTT-broker");
                  //преобразуем тему(topic) и значение (payload) в строку
                  payload[length] = '\0';
                  String strTopic = String(topic);
                  String strPayload = String((char*)payload);
                  //Исследуем что "прилетело" от сервера по подписке:
                  //Управление светодиодом
                  if (strTopic == "test1/setdat") {
                    if (strPayload == "off" || strPayload == "0" || strPayload == "false") digitalWrite(pin13, LOW);
                    if (strPayload == "on" || strPayload == "1" || strPayload == "true") digitalWrite(pin13, HIGH);
                  }
                  Serial.print (strTopic);
                  Serial.print (" ");
                  Serial.println (strPayload);
                  Serial.println ("-------");
                  Serial.println ("");
                }
                
                void wifiConnect() {
                  WiFi.begin(ssid, password);
                  while (WiFi.status() != WL_CONNECTED) {
                    delay(300);
                    Serial.print(".");
                    digitalWrite(pin13, 0);
                    delay(300);
                    digitalWrite(pin13, 1);
                    delay(300);
                  }
                
                  Serial.println("");
                  Serial.println("WiFi connected");
                  Serial.println("IP address: ");
                  Serial.println(WiFi.localIP());
                  digitalWrite(pin13, 0);
                }
                
                void setup() {
                  Serial.begin(115200);
                  Serial.begin(115200); 
                  pinMode(pin13, OUTPUT); 
                  delay(10); 
                  wifiConnect();
                }
                
                void loop() {
                  //Если соединение MQTT неактивно, то пытаемся установить его и опубликовать/подписаться
                  if (!client.connected()) {
                    Serial.print("Connect to MQTT-boker... ");
                    //Подключаемся и публикуемся/подписываемся
                    if (client.connect("test1/1")) {
                      Serial.println("success");
                      //Значение с датчиков
                      client.publish("test1/1", "1");
                      //Подписываемся на переменную управления светодиодом
                      client.subscribe("test1/setdata");
                    } else {
                      //Если не подключились, ждем 10 секунд и пытаемся снова
                      Serial.print("Failed, rc=");
                      Serial.print(client.state());
                      Serial.println(" try again in 10 seconds");
                      delay (10000);
                    }
                    //Если соединение активно, то отправляем данные на сервер с заданным интервалом времени
                  } else {
                    if (millis() > (last_time + send_interval * 1000)) {
                      last_time = millis();
                      client.publish("test1/1", "1");
                    }
                  }
                  //Проверка входящих соединений по подписке
                  client.loop();
                }</pubsubclient.h></wificlientsecure.h></esp8266wifi.h>
                ```` `  переведи драйвер в режим дебаг и скинь лог
                

                266_img_20170712_002411.jpg
                266_img_20170712_002500.jpg

                1 Reply Last reply Reply Quote 0
                • P
                  Plaha last edited by

                  Лог во вложении
                  3048_log.txt

                  1 Reply Last reply Reply Quote 0
                  • I
                    instalator last edited by

                    @Plaha:

                    Лог во вложении `
                    Даже не знаю что может быть.

                    Попробуй код изменить на :

                    if (client.connect("test")) {
                          Serial.println("success");
                          //Значение с датчиков
                          client.publish("test1/1", "1");
                          //Подписываемся на переменную управления светодиодом
                          client.subscribe("test1/#");
                        } 
                    
                    1 Reply Last reply Reply Quote 0
                    • P
                      Plaha last edited by

                      @instalator:

                      @Plaha:

                      Лог во вложении `
                      Даже не знаю что может быть.

                      Попробуй код изменить на :

                      if (client.connect("test")) {
                            Serial.println("success");
                            //Значение с датчиков
                            client.publish("test1/1", "1");
                            //Подписываемся на переменную управления светодиодом
                            client.subscribe("test1/#");
                          } 
                      ```` `  
                      

                      Все тоже самое 😞

                      Меня больше всего смущает статус драйвера "Соединение с mqtt: нет", такое ощущение что mqtt не стартует.

                      1 Reply Last reply Reply Quote 0
                      • I
                        instalator last edited by

                        @Plaha:

                        @instalator:

                        @Plaha:

                        Лог во вложении `
                        Даже не знаю что может быть.

                        Попробуй код изменить на :

                        if (client.connect("test")) {
                              Serial.println("success");
                              //Значение с датчиков
                              client.publish("test1/1", "1");
                              //Подписываемся на переменную управления светодиодом
                              client.subscribe("test1/#");
                            } 
                        ```` `  
                        

                        Все тоже самое 😞

                        Меня больше всего смущает статус драйвера "Соединение с mqtt: нет", такое ощущение что mqtt не стартует. `
                        Это статус соединения с клиентами, т.е. если какой либо клиент будет подписан то будет зеленый

                        1 Reply Last reply Reply Quote 0
                        • I
                          instalator last edited by

                          А у тебя файрволов нет никаких? Порт больше никто не держит?

                          1 Reply Last reply Reply Quote 0
                          • P
                            Plaha last edited by

                            @instalator:

                            А у тебя файрволов нет никаких? Порт больше никто не держит? `
                            Фаервол отключен, телнет на порт проходит, порты пробовал менять - не помогает. 😞

                            1 Reply Last reply Reply Quote 0
                            • P
                              Plaha last edited by

                              А эта проблема может быть из за Node?

                              А то на инструкиции разные по установке Node:

                              https://github.com/ioBroker/ioBroker/wi … ые-системы

                              http://www.iobroker.net/docu/?page_id=3489&lang=ru

                              1 Reply Last reply Reply Quote 0
                              • I
                                instalator last edited by

                                @Plaha:

                                А эта проблема может быть из за Node?

                                А то на инструкиции разные по установке Node:

                                https://github.com/ioBroker/ioBroker/wi … ые-системы

                                http://www.iobroker.net/docu/?page_id=3489&lang=ru ` а какая стоит? 4ю поставь.

                                1 Reply Last reply Reply Quote 0
                                • P
                                  Plaha last edited by

                                  @instalator:

                                  @Plaha:

                                  А эта проблема может быть из за Node?

                                  А то на инструкиции разные по установке Node:

                                  https://github.com/ioBroker/ioBroker/wi … ые-системы

                                  http://www.iobroker.net/docu/?page_id=3489&lang=ru а какая стоит? 4ю поставь.

                                  Показывает что стоит 0.12

                                  Попробую установить 4 версию, по результатам отпишусь.

                                  1 Reply Last reply Reply Quote 0
                                  • P
                                    Plaha last edited by

                                    @instalator:

                                    а какая стоит? 4ю поставь. `
                                    Спасибо!

                                    Вроде заработало, по крайней мере линуксовый клиент тачал подключаться.

                                    Вечером проверю с нормальным клиентом.

                                    Дело было в Node.

                                    1 Reply Last reply Reply Quote 0
                                    • First post
                                      Last post

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    773
                                    Online

                                    31.8k
                                    Users

                                    80.0k
                                    Topics

                                    1.3m
                                    Posts

                                    18
                                    244
                                    65710
                                    Loading More Posts
                                    • Oldest to Newest
                                    • Newest to Oldest
                                    • Most Votes
                                    Reply
                                    • Reply as topic
                                    Log in to reply
                                    Community
                                    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                    The ioBroker Community 2014-2023
                                    logo