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

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Драйвер Mqtt + Arduino

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

      @Plaha:

      @instalator:

      на сервере иоб ошибка? Все в одной сети? `
      Да, на сервере в логах:

      mqtt.0 2017-07-10 11:07:49.871 info Client [mosqpub/8739-iot.securi] closed

      mqtt.0 2017-07-10 11:07:49.870 warn Client error [mosqpub/8739-iot]: Error: not implemented

      mqtt.0 2017-07-10 11:07:49.869 info Client [mosqpub/8739-iot] connected

      Я отправляю сообщение с севера, где установлени iobroker.

      Еще почему то в Настройках драйвера, драйвер mqtt помечен желтым цветом. В статусе написано "Соединение с mqtt: нет", хотя в логах пишется что сервер вроде как поднят:

      mqtt.0 2017-07-10 10:06:02.615 info Starting MQTT server on port 1883 `
      Подозреваю не тот ты драйвер поставил. Настройки драйвера покажи

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

        @instalator:

        Подозреваю не тот ты драйвер поставил. Настройки драйвера покажи `
        3048_image.jpg
        3048_image.jpg

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

          @Plaha:

          @instalator:

          Подозреваю не тот ты драйвер поставил. Настройки драйвера покажи
          Вроде все норм. Сними ещё три галки в настройках.

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

            @instalator:

            Вроде все норм. Сними ещё три галки в настройках. `
            Снял, ничего не изменилось. Может необходимо какие библиотеки на сервер поставить или какой нибудь mosquitto??

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

              @Plaha:

              @instalator:

              Вроде все норм. Сними ещё три галки в настройках. Снял, ничего не изменилось. Может необходимо какие библиотеки на сервер поставить или какой нибудь mosquitto??
              Ненужны никакие маскиты, драйвер скмодостаточен. И запускает сервер. Проблема с твоим клиентом, он не подписывается наверное? Или отключается от сервера. На вкладке объекты в mqtt.0 топик не появился?

              1 Reply Last reply Reply Quote 0
              • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            932
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            18
                                            244
                                            63415
                                            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