Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. ioBroker драйвера
  5. Драйвер Mqtt + Arduino

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    207

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    7.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

Драйвер Mqtt + Arduino

Драйвер Mqtt + Arduino

Scheduled Pinned Locked Moved ioBroker драйвера
244 Posts 18 Posters 76.4k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • I Offline
    I Offline
    instalator
    wrote on last edited by
    #226

    @Plaha:

    @instalator:

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

    Высокий уровень Децибел вреден для здоровья!

    http://blog.instalator.ru/

    1 Reply Last reply
    0
    • P Offline
      P Offline
      Plaha
      wrote on last edited by
      #227

      @instalator:

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

      1 Reply Last reply
      0
      • I Offline
        I Offline
        instalator
        wrote on last edited by
        #228

        @Plaha:

        @instalator:

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

        Высокий уровень Децибел вреден для здоровья!

        http://blog.instalator.ru/

        1 Reply Last reply
        0
        • P Offline
          P Offline
          Plaha
          wrote on last edited by
          #229

          @instalator:

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

          1 Reply Last reply
          0
          • P Offline
            P Offline
            Plaha
            wrote on last edited by
            #230

            @instalator:

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

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

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

            1 Reply Last reply
            0
            • P Offline
              P Offline
              Plaha
              wrote on last edited by
              #231

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

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

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

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

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

              1 Reply Last reply
              0
              • I Offline
                I Offline
                instalator
                wrote on last edited by
                #232

                @Plaha:

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

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

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

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

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

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

                Высокий уровень Децибел вреден для здоровья!

                http://blog.instalator.ru/

                1 Reply Last reply
                0
                • P Offline
                  P Offline
                  Plaha
                  wrote on last edited by
                  #233

                  @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
                  0
                  • I Offline
                    I Offline
                    instalator
                    wrote on last edited by
                    #234

                    @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

                    Высокий уровень Децибел вреден для здоровья!

                    http://blog.instalator.ru/

                    1 Reply Last reply
                    0
                    • P Offline
                      P Offline
                      Plaha
                      wrote on last edited by
                      #235

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

                      1 Reply Last reply
                      0
                      • I Offline
                        I Offline
                        instalator
                        wrote on last edited by
                        #236

                        @Plaha:

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

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

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

                        Высокий уровень Децибел вреден для здоровья!

                        http://blog.instalator.ru/

                        1 Reply Last reply
                        0
                        • P Offline
                          P Offline
                          Plaha
                          wrote on last edited by
                          #237

                          @instalator:

                          @Plaha:

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

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

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

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

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

                          1 Reply Last reply
                          0
                          • I Offline
                            I Offline
                            instalator
                            wrote on last edited by
                            #238

                            @Plaha:

                            @instalator:

                            @Plaha:

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

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

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

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

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

                            Высокий уровень Децибел вреден для здоровья!

                            http://blog.instalator.ru/

                            1 Reply Last reply
                            0
                            • I Offline
                              I Offline
                              instalator
                              wrote on last edited by
                              #239

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

                              Высокий уровень Децибел вреден для здоровья!

                              http://blog.instalator.ru/

                              1 Reply Last reply
                              0
                              • P Offline
                                P Offline
                                Plaha
                                wrote on last edited by
                                #240

                                @instalator:

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

                                1 Reply Last reply
                                0
                                • P Offline
                                  P Offline
                                  Plaha
                                  wrote on last edited by
                                  #241

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

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

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

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

                                  1 Reply Last reply
                                  0
                                  • I Offline
                                    I Offline
                                    instalator
                                    wrote on last edited by
                                    #242

                                    @Plaha:

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

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

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

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

                                    Высокий уровень Децибел вреден для здоровья!

                                    http://blog.instalator.ru/

                                    1 Reply Last reply
                                    0
                                    • P Offline
                                      P Offline
                                      Plaha
                                      wrote on last edited by
                                      #243

                                      @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
                                      0
                                      • P Offline
                                        P Offline
                                        Plaha
                                        wrote on last edited by
                                        #244

                                        @instalator:

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

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

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

                                        Дело было в Node.

                                        1 Reply Last reply
                                        0
                                        Reply
                                        • Reply as topic
                                        Log in to reply
                                        • Oldest to Newest
                                        • Newest to Oldest
                                        • Most Votes


                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        109

                                        Online

                                        32.4k

                                        Users

                                        81.3k

                                        Topics

                                        1.3m

                                        Posts
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                        ioBroker Community 2014-2025
                                        logo
                                        • Login

                                        • Don't have an account? Register

                                        • Login or register to search.
                                        • First post
                                          Last post
                                        0
                                        • Recent
                                        • Tags
                                        • Unread 0
                                        • Categories
                                        • Unreplied
                                        • Popular
                                        • GitHub
                                        • Docu
                                        • Hilfe