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
    209

  • 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.
  • P Offline
    P Offline
    Plaha
    wrote on last edited by
    #219

    @instalator:

    @Plaha:

    http://www.iobroker.net/docu/?page_id=4643&lang=ru
    Это я смотрел, там хорошо описана процедура по клиенту. А я хочу понять каким образом в сервере прописываются форматы топиков, реагирование на поступающую от клиентов информацию.

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

      @Plaha:

      @instalator:

      @Plaha:

      http://www.iobroker.net/docu/?page_id=4643&lang=ru
      Это я смотрел, там хорошо описана процедура по клиенту. А я хочу понять каким образом в сервере прописываются форматы топиков, реагирование на поступающую от клиентов информацию. ` никак не прописываются. Клиент публикует топики.

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

      http://blog.instalator.ru/

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

        При попытке отправить с помощью mosquitto_pub сообщения, получаю следующую ошибку на сервере:

        Error: not implemented

        С чем это связано?

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

          @Plaha:

          При попытке отправить с помощью mosquitto_pub сообщения, получаю следующую ошибку на сервере:

          Error: not implemented

          С чем это связано? ` на сервере иоб ошибка? Все в одной сети?

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

          http://blog.instalator.ru/

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

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

              @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 `
              Подозреваю не тот ты драйвер поставил. Настройки драйвера покажи

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

              http://blog.instalator.ru/

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

                @instalator:

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

                1 Reply Last reply
                0
                • 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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          96

                                          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