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

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    Драйвер Mqtt + Arduino

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

      Это в void loop записать? Сейчас ваш пример скачаю. Где то читал что это ещё проблемы ENC28J60, вообще кода почти нет а при компиляции 85% забито. Можно как то библиотеку облегчить но для меня это темный лес 😢

      Чего то сделал

      #include <spi.h>
      #include <uipethernet.h>                                  // UIP Ethernet Library to support ENC28J60 ethernet module. 
      #include <pubsubclient.h>                                 // MQTT publisher/subscriber client library
      #include <wire.h>
      #include <liquidcrystal_i2c.h>                            // i2C bus converter compatible library for LCD
      
      LiquidCrystal_I2C lcd(0x27,16,2);
      
      byte mac[]    = {  0xDE, 0xED, 0xBA, 0xFE, 0xFE, 0xED }; // Set the mac address for the arduino nano mcu 
      byte server[] = { 192, 168, 1, 11 };                     // Set MQTT broker server IP address
      //char server[] = "xxx.xxxxxxx.xxx";                       // Set MQTT broker server domain address 
      byte ip[]     = { 192, 168, 1, 16 };                     // Set the IP address for the arduino nano mcu 
      
      #define id_connect "LCD-accumulator_tanks_1"
      #define Prefix_subscribe "myhome/Boiler_room/"
      
      unsigned long lastTime = 0;
      unsigned long timeout = 10; // по-умолчанию таймаут перед восстановлением соединения 10 сек
      
      void callback(char* topic, byte* payload, unsigned int length) {
        payload[length] = '\0';
        String strTopic = String(topic);
        String strPayload = String((char*)payload);
          if (strcmp(topic, "myhome/Boiler_room/Temp_accum_tanks_1_1")==0){
          lcd.setCursor(3,0);
          lcd.print(strPayload);
          //lcd.print((char)223);
          }
          if (strcmp(topic, "myhome/Boiler_room/Temp_accum_tanks_1_2")==0){
          lcd.setCursor(3,1);
          lcd.print(strPayload);
          //lcd.print((char)223);
          }
          if (strcmp(topic, "myhome/Boiler_room/Temp_accum_tanks_1_3")==0){
          lcd.setCursor(12,0);
          lcd.print(strPayload);
          //lcd.print((char)223);
          }
          if (strcmp(topic, "myhome/Boiler_room/Temp_accum_tanks_1_4")==0){
          lcd.setCursor(12,1);
          lcd.print(strPayload);
          //lcd.print((char)223);
          } 
      }
      
      EthernetClient ethClient;
      PubSubClient client(server, 1883, callback, ethClient);
      
      void setup() {
        lcd.init();
        lcd.backlight();
        lcd.clear();
        lcd.setCursor(0,0);
        lcd.print("T1:");
        lcd.setCursor(0,1);
        lcd.print("T2:");
        lcd.setCursor(9,0);
        lcd.print("T3:");
        lcd.setCursor(9,1);
        lcd.print("T4:");
      
        Ethernet.begin(mac, ip);
        if (client.connect(id_connect)) {                    // Check the MQTT broker connectivity
          client.publish("myhome/Boiler_room/Temp_accum_tanks_1_1", " ");
          client.publish("myhome/Boiler_room/Temp_accum_tanks_1_2", " ");
          client.publish("myhome/Boiler_room/Temp_accum_tanks_1_3", " ");
          client.publish("myhome/Boiler_room/Temp_accum_tanks_1_4", " ");
          client.subscribe("myhome/Boiler_room/#");
        }
      }
      
      void loop() {
        client.loop();
          if (!client.connected()) {
            if (client.connect(id_connect)) {
            client.subscribe("myhome/Boiler_room/#");
            }
          }
      //Если соединение не активно в течении таймаута, восстанавливаем
          if(millis() > (lastTime + timeout*1000)) {
          lastTime = millis();
            if (!client.connected()) {
      //Разрываем коннект
            client.disconnect();
      //пытаемся восстановить
            if (client.connect(id_connect)) {
      //Публикуем, подписываемся заново
            client.subscribe("myhome/Boiler_room/#");
            }
          }
        }
      }</liquidcrystal_i2c.h></wire.h></pubsubclient.h></uipethernet.h></spi.h>
      
      1 Reply Last reply Reply Quote 0
      • H
        Haus last edited by

        Увы результата недал, гдето через 5 часов пропала связь 😞

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

          @Haus:

          Увы результата недал, гдето через 5 часов пропала связь 😞 `
          Когда связь пропадает ардуина пингуется вообще? Езернет шилд какой пользуешь?

          1 Reply Last reply Reply Quote 0
          • H
            Haus last edited by

            @instalator:

            @Haus:

            Увы результата недал, гдето через 5 часов пропала связь 😞 Когда связь пропадает ардуина пингуется вообще? Езернет шилд какой пользуешь?
            Не пингуется, ENC28J60

            mqtt-0	2016-01-12 19:45:55	info	Client [LCD-accumulator_tanks_1] closed
            mqtt-0	2016-01-12 19:45:55	warn	[LCD-accumulator_tanks_1] Error: read ETIMEDOUT
            sayit-0	2016-01-12 19:30:11	info	saying: Дисплей. Пропала связь!
            sayit-0	2016-01-12 19:30:07	info	saying: /opt/iobroker/node_modules/iobroker.sayit/gong.mp3
            javascript-0	2016-01-12 19:30:07	info	script.js.Ping_0_say: Дисплей. Пропала связь!
            

            Если рестартануть драйвер результата 0, если ресетнуть ардуину всё работает

            Может я код который предложил electric69 не так прописал?

            1 Reply Last reply Reply Quote 0
            • E
              electric69 last edited by

              @Haus:

              Не пингуется, ENC28J60 `
              Если не пингуется, то код вообще не причем…

              Попробуйте без MQTT, просто по HTTP погонять - будет ли работать.

              Или просто залить скетч тестовый из библиотеки изернета, пустить пинг тестовый и проверить через часов 5-10 будет ли пинговаться, может "дело не в бобине" ))

              1 Reply Last reply Reply Quote 0
              • B
                bondrogeen last edited by

                Подскажите пожалуйста в чем может быть проблема.

                iobroker подключен в качестве клиента к CloudMQTT

                CloudMQTT поступают данные с планшета, на странице CloudMQTT отображаются корректно.

                admin/DEXP Ursus 8E2 mini 3G/sensors/battery 100

                admin/DEXP Ursus 8E2 mini 3G/sensors/bright 166

                admin/DEXP Ursus 8E2 mini 3G/sensors/temp %TEMP

                admin/DEXP Ursus 8E2 mini 3G/sensors/time 22.46

                admin/DEXP Ursus 8E2 mini 3G/sensors/date 22.01.2016

                admin/DEXP Ursus 8E2 mini 3G/sensors/wifi >>> SCAN <<<

                admin/DEXP Ursus 8E2 mini 3G/sensors/device DEXP Ursus 8E2 mini 3G

                admin/DEXP Ursus 8E2 mini 3G/sensors/uptime 353479

                admin/DEXP Ursus 8E2 mini 3G/sensors/ram 58MB

                admin/DEXP Ursus 8E2 mini 3G/sensors/statusblue off

                admin/DEXP Ursus 8E2 mini 3G/sensors/statusscreen on

                а вот в iobrokere нет значений

                380_12124.jpg

                но если публикуешь в корне то отображается правильно

                test 6576

                1 Reply Last reply Reply Quote 0
                • H
                  Haus last edited by

                  @bondrogeen:

                  Подскажите пожалуйста в чем может быть проблема.

                  iobroker подключен в качестве клиента к CloudMQTT

                  CloudMQTT поступают данные с планшета, на странице CloudMQTT отображаются корректно.

                  admin/DEXP Ursus 8E2 mini 3G/sensors/battery 100

                  admin/DEXP Ursus 8E2 mini 3G/sensors/bright 166

                  admin/DEXP Ursus 8E2 mini 3G/sensors/temp %TEMP

                  admin/DEXP Ursus 8E2 mini 3G/sensors/time 22.46

                  admin/DEXP Ursus 8E2 mini 3G/sensors/date 22.01.2016

                  admin/DEXP Ursus 8E2 mini 3G/sensors/wifi >>> SCAN <<<

                  admin/DEXP Ursus 8E2 mini 3G/sensors/device DEXP Ursus 8E2 mini 3G

                  admin/DEXP Ursus 8E2 mini 3G/sensors/uptime 353479

                  admin/DEXP Ursus 8E2 mini 3G/sensors/ram 58MB

                  admin/DEXP Ursus 8E2 mini 3G/sensors/statusblue off

                  admin/DEXP Ursus 8E2 mini 3G/sensors/statusscreen on

                  а вот в iobrokere нет значений

                  но если публикуешь в корне то отображается правильно

                  test 6576 `
                  Наверно дело в структуре, вот так выглядит у меня
                  443_screencapture-192-168-1-11-8081-1453552081222.png

                  1 Reply Last reply Reply Quote 0
                  • B
                    bondrogeen last edited by

                    В режиме брокера именно такая структура и у меня, а вот как клиент получается так.

                    Как брокер локально по сети нормально все передается.

                    Решил попробовать через cloudmqtt.com и подключится как клиент и тут такие проблемы.

                    380_3333.jpg
                    может что тут нужно поставить?

                    1 Reply Last reply Reply Quote 0
                    • H
                      Haus last edited by

                      @bondrogeen:

                      В режиме брокера именно такая структура и у меня, а вот как клиент получается так.

                      Как брокер локально по сети нормально все передается.

                      Решил попробовать через cloudmqtt.com и подключится как клиент и тут такие проблемы.

                      filename="3333.jpg" index="0">~~
                      может что тут нужно поставить? `
                      Там внизу есть кнопка "проверить настройки" может она чем поможет, посмотри у немцев там много инфы только google так коряво переводит 🙂

                      1 Reply Last reply Reply Quote 0
                      • B
                        bondrogeen last edited by

                        нажимал я на нее только не чего не происходит

                        1 Reply Last reply Reply Quote 0
                        • H
                          Haus last edited by

                          @bondrogeen:

                          нажимал я на нее только не чего не происходит `
                          Есть помощь по драйверу. Правда на аглицком. https://github.com/ioBroker/ioBroker.mqtt#configuration

                          1 Reply Last reply Reply Quote 0
                          • B
                            bondrogeen last edited by

                            читал, но не чего нового для себя не узнал

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

                              @bondrogeen:

                              В режиме брокера именно такая структура и у меня, а вот как клиент получается так.

                              Как брокер локально по сети нормально все передается.

                              Решил попробовать через cloudmqtt.com и подключится как клиент и тут такие проблемы.

                              filename="3333.jpg" index="0">~~
                              может что тут нужно поставить? `
                              Может из за пробелов в именах переменных?

                              1 Reply Last reply Reply Quote 0
                              • B
                                bondrogeen last edited by

                                имена менял, пробовал по разному.

                                И главное iobroker на сервер отправляет корректные данные.

                                лог с сервера

                                system/adapter/mqtt/0/alive true

                                system/adapter/mqtt/0/connected true

                                system/adapter/mqtt/0/memHeapUsed 8.25

                                system/adapter/mqtt/0/memHeapTotal 18.74

                                system/adapter/mqtt/0/memRss 27.73

                                system/adapter/mqtt/0/uptime 0

                                system/adapter/mqtt/upload 0

                                system/adapter/history/0/alive true

                                system/adapter/history/0/connected true

                                system/adapter/history/0/memHeapUsed 11.47

                                system/adapter/history/0/memHeapTotal 18.74

                                system/adapter/history/0/memRss 29.48

                                system/adapter/history/0/uptime 331

                                system/adapter/history/upload 0

                                system/host/Roman-PC/alive true

                                system/host/Roman-PC/load 0

                                system/host/Roman-PC/uptime 331

                                system/host/Roman-PC/memRss 104.86

                                system/host/Roman-PC/memHeapTotal 78.13

                                system/host/Roman-PC/memHeapUsed 54.86

                                system/host/Roman-PC/mem 56

                                system/adapter/admin/0/alive true

                                system/adapter/admin/0/connected true

                                system/adapter/admin/0/memHeapUsed 24.37

                                system/adapter/admin/0/memHeapTotal 55.52

                                system/adapter/admin/0/memRss 71.23

                                system/adapter/admin/0/uptime 331

                                1 Reply Last reply Reply Quote 0
                                • B
                                  bondrogeen last edited by

                                  Сегодня пробовал на другом сервисе (брокере)

                                  Получается название всего топика присваивается как переменная.

                                  380_3333.jpg

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

                                    @bondrogeen:

                                    имена менял, пробовал по разному.

                                    И главное iobroker на сервер отправляет корректные данные.

                                    лог с сервера

                                    system/adapter/mqtt/0/alive true

                                    system/adapter/mqtt/0/connected true

                                    system/adapter/mqtt/0/memHeapUsed 8.25

                                    system/adapter/mqtt/0/memHeapTotal 18.74

                                    system/adapter/mqtt/0/memRss 27.73

                                    system/adapter/mqtt/0/uptime 0

                                    system/adapter/mqtt/upload 0

                                    system/adapter/history/0/alive true

                                    system/adapter/history/0/connected true

                                    system/adapter/history/0/memHeapUsed 11.47

                                    system/adapter/history/0/memHeapTotal 18.74

                                    system/adapter/history/0/memRss 29.48

                                    system/adapter/history/0/uptime 331

                                    system/adapter/history/upload 0

                                    system/host/Roman-PC/alive true

                                    system/host/Roman-PC/load 0

                                    system/host/Roman-PC/uptime 331

                                    system/host/Roman-PC/memRss 104.86

                                    system/host/Roman-PC/memHeapTotal 78.13

                                    system/host/Roman-PC/memHeapUsed 54.86

                                    system/host/Roman-PC/mem 56

                                    system/adapter/admin/0/alive true

                                    system/adapter/admin/0/connected true

                                    system/adapter/admin/0/memHeapUsed 24.37

                                    system/adapter/admin/0/memHeapTotal 55.52

                                    system/adapter/admin/0/memRss 71.23

                                    system/adapter/admin/0/uptime 331 `
                                    Лог ниочем.

                                    Получается iobroker не может подписаться

                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      bondrogeen last edited by

                                      Это лог с сервера CloudMQTT

                                      Данные получены от ibrokera

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

                                      380_1223.jpg

                                      Хотя во вкладке "состояния" значения отображаются.

                                      380_12234.jpg

                                      А в обьектах нет

                                      380_122345.jpg

                                      CloudMQTT

                                      1 Reply Last reply Reply Quote 0
                                      • Bluefox
                                        Bluefox last edited by

                                        @bondrogeen:

                                        Сегодня пробовал на другом сервисе (брокере)

                                        Получается название всего топика присваивается как переменная.

                                        filename="3333.jpg" index="0">~~ `
                                        Сегодня переписываю mqtt. Была полная путаница с конвертацией имён.

                                        1 Reply Last reply Reply Quote 0
                                        • B
                                          bondrogeen last edited by

                                          Спасибо, что ответили, очень жду результата.
                                          3514_alexa2_matthias.log

                                          1 Reply Last reply Reply Quote 0
                                          • H
                                            Haus last edited by

                                            @Bluefox:

                                            Сегодня переписываю mqtt. Была полная путаница с конвертацией имён. `
                                            Тут ещё такая
                                            443_screencapture-192-168-1-11-8081-1453659259576.png
                                            и ещё попутно
                                            443_screencapture-192-168-1-11-8081-1453659706003.png
                                            смотрю много новых драйверов, процесс идёт 🙂

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            781
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

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