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

      Навалился непонятно откуда мусор:

      Как его теперь удалить?
      266_32432423423423.png

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

        @instalator:

        Навалился непонятно откуда мусор:

        Как его теперь удалить? `
        Может как то криво клиент "публикует" данные?

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

          @electric69:

          @instalator:

          Навалился непонятно откуда мусор:

          Как его теперь удалить? Может как то криво клиент "публикует" данные?
          Может быть был глюк. но почему нету кнопки удаления переменной?

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

            @instalator:

            @electric69:

            @instalator:

            Навалился непонятно откуда мусор:

            Как его теперь удалить? Может как то криво клиент "публикует" данные?
            Может быть был глюк. но почему нету кнопки удаления переменной? `
            Удалить можно только узел без детей… А там ещё много уровней.

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

              @Bluefox:

              Удалить можно только узел без детей… А там ещё много уровней. `
              Дети есть присматрись там вместо кнопок полоски отображаются

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

                @instalator:

                @Bluefox:

                Удалить можно только узел без детей… А там ещё много уровней. Дети есть присматрись там вместо кнопок полоски отображаются
                Я советую удалить mqtt и установить заново. Сохрани настройки только.

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

                  @Bluefox:

                  Я советую удалить mqtt и установить заново. Сохрани настройки только. `
                  Удалил, поставил все ок.

                  Что то заглючило. Появилась одна мусорная переменная. Попытался снова удалить mqtt не удалаяется.

                  ! $ ./iobroker del mqtt.0
                  ! ERROR:
                  ! events.js:72
                  ! throw er; // Unhandled 'error' event
                  ! ^
                  ! Error: listen EADDRINUSE
                  ! at errnoException (net.js:905:11)
                  ! at Server._listen2 (net.js:1043:14)
                  ! at listen (net.js:1065:10)
                  ! at Server.listen (net.js:1139:5)
                  ! at _initWebServer (c:\ioBroker\node_modules\iobroker.js-controller\lib\objectsInMemServer.js:958:24)
                  ! at c:\ioBroker\node_modules\iobroker.js-controller\lib\objectsInMemServer.js:139:9
                  ! at new ObjectsInMemServer (c:\ioBroker\node_modules\iobroker.js-controller\lib\objectsInMemServer.js:146:7)
                  ! at null._onTimeout (c:\ioBroker\node_modules\iobroker.js-controller\lib\setup.js:1233:27)
                  ! at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                  ! ERROR: process exited with code 8

                  Это после рестарта Web и Mqtt:

                  ! mqtt-0 2015-06-02 16:34:13 info 2
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 info Client [undefined] closed
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:18 debug statesDB connected
                  ! mqtt-0 2015-06-02 16:34:18 debug objectDB connected
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  ! mqtt-0 2015-06-02 16:34:13 warn [undefined] Error: read ECONNRESET
                  266_2342342342.png

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

                    Удалил сначала WEB потом MQTT.

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

                      @instalator:

                      Удалил сначала WEB потом MQTT. `
                      Я почему то думал, что адаптер WEB и MQTT друг от друга не зависят))

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

                        Нашел косяк в работе драйвера, точнее глюк.

                        Стенд у меня получился такой:

                        "Ардуина71" подписывается на топик "/common/led". На 6-ой ноге светодиод, должен включаться/отключаться.

                        "Ардуина72" публикует в топик "/common/led" в зависимости от состояния кнопок (баттон1 включить, баттон2 отключить).

                        По идее если нажать кн1 на "арудуина72" (передний фронт), то светодиод на "ардуине71" должен загореться, если нажать кн2 (передний фронт) - потухнуть.

                        Но на деле лишь иногда зажигается и гастет, т.е. почти не срабатывает…

                        В логе видно, что брокер иногда (почти вседа) не отправляет данные (за символами // - мои коменты 😉 😞

                        ! mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:43 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:42 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1", и ничего.... mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:40 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:39 info Send to client [arduinoPLC71] "common/led": 1 //<-- и вдруг оба-на - светодиод загорелся! mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:33 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:32 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:28 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:27 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:26 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:24 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:23 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:21 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:19 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:18 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 !
                        50_plc2_control_dido.zip
                        50_plc3.zip

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

                          @electric69:

                          Нашел косяк в работе драйвера, точнее глюк.

                          Стенд у меня получился такой:

                          "Ардуина71" подписывается на топик "/common/led". На 6-ой ноге светодиод, должен включаться/отключаться.

                          "Ардуина72" публикует в топик "/common/led" в зависимости от состояния кнопок (баттон1 включить, баттон2 отключить).

                          По идее если нажать кн1 на "арудуина72" (передний фронт), то светодиод на "ардуине71" должен загореться, если нажать кн2 (передний фронт) - потухнуть.

                          Но на деле лишь иногда зажигается и гастет, т.е. почти не срабатывает…

                          В логе видно, что брокер иногда (почти вседа) не отправляет данные (за символами // - мои коменты 😉 😞

                          ! mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:43 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:42 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1", и ничего.... mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:40 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:39 info Send to client [arduinoPLC71] "common/led": 1 //<-- и вдруг оба-на - светодиод загорелся! mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:33 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:32 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:28 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:27 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:26 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:24 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:23 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:21 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:19 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:18 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 ! `
                          т.е. у тебя два разных клиента подписались на один топик?

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

                            @instalator:

                            т.е. у тебя два разных клиента подписались на один топик? `
                            Именно.

                            Так можно сделать межконтроллерный обмен, посредником будет ioBroker.

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

                              @electric69:

                              Нашел косяк в работе драйвера, точнее глюк.

                              Стенд у меня получился такой:

                              "Ардуина71" подписывается на топик "/common/led". На 6-ой ноге светодиод, должен включаться/отключаться.

                              "Ардуина72" публикует в топик "/common/led" в зависимости от состояния кнопок (баттон1 включить, баттон2 отключить).

                              По идее если нажать кн1 на "арудуина72" (передний фронт), то светодиод на "ардуине71" должен загореться, если нажать кн2 (передний фронт) - потухнуть.

                              Но на деле лишь иногда зажигается и гастет, т.е. почти не срабатывает…

                              В логе видно, что брокер иногда (почти вседа) не отправляет данные (за символами // - мои коменты 😉 😞

                              ! mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:43 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:43 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:42 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1", и ничего.... mqtt-0 2015-06-03 21:28:41 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:40 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:40 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:39 info Send to client [arduinoPLC71] "common/led": 1 //<-- и вдруг оба-на - светодиод загорелся! mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:39 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:33 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:32 info Send to client [arduinoPLC71] "common/led": 0 //<-- и вдруг оба-на - светодиод потух! mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:32 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 //<-- отпустил кн1 mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 //<-- опубликовали "1" mqtt-0 2015-06-03 21:28:31 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 //<-- нажал кн1 (передний фронт) mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 //<-- отпустил кн2 mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 //<-- опубликовали "0" mqtt-0 2015-06-03 21:28:30 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 //<-- нажал кн2 (передний фронт) mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:29 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:28 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:27 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:27 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:26 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:26 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:25 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:25 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:24 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:23 info Send to client [arduinoPLC71] "common/led": 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:23 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:22 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:21 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 1 mqtt-0 2015-06-03 21:28:20 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 1 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 0 mqtt-0 2015-06-03 21:28:19 info Send to client [arduinoPLC71] "common/led": 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.common.led"(number): 0 mqtt-0 2015-06-03 21:28:19 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button2"(number): 1 mqtt-0 2015-06-03 21:28:18 info Client [arduinoPLC72] publishes "mqtt.0.arduinoPLC72.button1"(number): 0 ! `
                              Итак, проделал кучу опытов, установил чистый Node-red, пробовал москито - все работает вроде нормально!

                              Оказывается))

                              Надо просто снять галочку!

                              Вот при таких настройках межконтроллерный обмен работает, и кстати довольно шустро…
                              50_pic_140.jpg

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

                                Может и не в теме конечно…..

                                Просто оставлю это сдесь)

                                Все работало норм, только иногда после перепрошивки клиентов они не подключались к сети.

                                Работало в связке Arduino Uno + Ethernet shield W5100. (Все платы заказывались из Китая)

                                Подключены были через комутатор, пробовал менять и IP и MAC, менял патч корды, перепроверил весь код - ничего не помогало (некоторые клиенты работали норм).

                                Причем если подключить Arduino напрямую в роутер то они выходили на связь.

                                Веселье началось когда поставил новый свитч TP-LINK. Часть клиентов не подключалось вообще. Arduino не пинговались.

                                Бился почти 2 дня. Уже думал менять коммутатор.

                                В итоге я нашел ошибку, она оказалась в ethernet шилдах W5100.

                                В интернете информации по такой ошибке не нашел (Было конечно несколько тем и предлагались различные решения, но они не помогали...)

                                Пробовал даже переконфигурировать чип W5100 на работу на фиксированной скорости 10 и 100.

                                Вообщем будет полезно очень многим кто заказывает Arduino в китае.

                                Так вот: Китайцы видимо не понимают разницы в маркировке чип резисторов между 510 и 511 либо не нашлось под рукой 510 и подумали что 511 это одно и тоже ведь 1 на конце добавляет 0 т.е. получается те же 510. Если внимательно посмотреть справочники, то там четко указано, что 510 это 51 Ом, а 511 это уже 510 Ом.

                                Ну вообщем как выяснилось на нескольких (5 шт) платах они запаяли вместо 51 Ом (вообще по даташиту нужно 49) резисторы на 510 Ом.
                                266_img_511.jpg
                                Как видно на фотках эти резисторы стоят в цепи Ethernet TX, RX.

                                Под рукой нашлись сборки нужного размера только на 56 Ом. Пришлось запаять их.
                                266_img_560.jpg
                                И о чудо, все платы заработали как и положено.

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

                                  Пока возился в шкафу, видимо при перебоях в питании снова навалился мусор. Удалил драйвер, поставил заново, в объектах мусор ушел а вот в состояних непонятно как теперь удалить?

                                  Может драйвер подправить чтобы мысор не пропускал и не заводил переменные с мусором?
                                  266_sadsd.png
                                  305_view_2.txt
                                  305_view.jpg

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    Alekseym6 last edited by

                                    Использую модуль HanRun HR911105A и библиотеку UIPEthernet. С библиотекой Ethernet(как в примерах) не работает.

                                    IP получаю по DHSP. как уменьшить размер скетча http://forum.iobroker.com/download/file.php?id=1102 (PLC3.zip).

                                    вылазит за 30кБ. Если IP - статический то 27кБ. Или с какой библиотекой, меньшего размера, работает модуль HanRun HR911105A?
                                    462_ardfull_schema-600x317.png

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

                                      @Alekseym6:

                                      Использую модуль HanRun HR911105A и библиотеку UIPEthernet. С библиотекой Ethernet(как в примерах) не работает.

                                      IP получаю по DHSP. как уменьшить размер скетча http://forum.iobroker.com/download/file.php?id=1102 (PLC3.zip).

                                      вылазит за 30кБ. Если IP - статический то 27кБ. Или с какой библиотекой, меньшего размера, работает модуль HanRun HR911105A? `
                                      О_о, Alekseym6, насмешил, я даже прослезился)))

                                      HanRun HR911105A это маркировка http://www.electronshik.ru/item/hr911105a-552539!

                                      А модуль у тебя, судя по фото, скорее всего на чипе http://www.microchip.com/wwwproducts/Devices.aspx?product=ENC28J60, типа http://www.youtube.com/watch?v=nb-7gvvX5c8.

                                      В Arduino IDE используется библиотека https://github.com/knolleary/pubsubclient, там в документации написано:
                                      > The library cannot currently be used with hardware based on the ENC28J60 chip – such as the Nanode or the Nuelectronics Ethernet Shield. For those, there is an alternative library available – but I do not know what state that is in.
                                      Перевод в двух словах:

                                      Для чипа ENC28J60 не годится, надо использовать библиотеку https://github.com/njh/NanodeMQTT, но работает она или нет - хз…

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        Alekseym6 last edited by

                                        Верно на чипе ENC28J60, библиотека UIPEthernet рабочая. Размер скетча больше 27кБ. Как оптимизировать?

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

                                          @Alekseym6:

                                          Верно на чипе ENC28J60, библиотека UIPEthernet рабочая. Размер скетча больше 27кБ. Как оптимизировать? `
                                          1. Для не-экстрасенсов можно текст скетча?))

                                          2. Попробуйте набор библиотек, что я привел в цитате…

                                          1 Reply Last reply Reply Quote 0
                                          • A
                                            Alekseym6 last edited by

                                            линк на скетч я указал выше. Или вот он:

                                            ! ````
                                            /
                                            //------------------------------------------ Libraries ------------------------------------------//
                                            //Подключаем библиотеки
                                            #include <spi.h>
                                            #include <uipethernet.h> //Arduino-uip-master
                                            #include <pubsubclient.h> //https://github.com/knolleary/pubsubclient
                                            //---------------------------------------- End libraries ----------------------------------------//
                                            ! //------------------------------------------- Ethernet ------------------------------------------//
                                            //Глобальные константы для работы с сетью
                                            byte mac[] = { 0xDE,0xAD,0xBE,0xEF,0xFE,0xED };
                                            byte mqttserver[] = { };
                                            byte ip[] = { 192, 168, 0, 165 };
                                            byte gateway[] = { 192,168,0,1 };
                                            byte subnet[] = { 255,255,255,0 };
                                            EthernetClient ethClient;
                                            PubSubClient client(mqttserver, 1883, callback, ethClient);
                                            //----------------------------------------- End ethernet ----------------------------------------//
                                            ! //------------------------------------------- Sensors -------------------------------------------//
                                            #define LED_pin 6
                                            int analogPinA0 = 0;
                                            int analogPinA1 = 1;
                                            int analogPinA2 = 2;
                                            int SensorA0 = 0;
                                            int SensorA1 = 0;
                                            int SensorA2 = 0;
                                            char buff[20];
                                            //String PLC = "arduinoPLC71";
                                            unsigned long lastTime = 0;
                                            unsigned long poolTime = 5; // по-умолчанию интервал опроса 5 сек
                                            unsigned long timeout = 10; // по-умолчанию таймаут перед восстановлением соединения 10 сек
                                            boolean LED_st;
                                            //----------------------------------------- End Sensors -----------------------------------------//
                                            ! //###############################################################################################//
                                            //########################################## Functions ##########################################//
                                            //###############################################################################################//
                                            ! //------------------------------------------- Callback -----------------------------------------//
                                            //Функция обработки входящих соединений - прием данных по подписке
                                            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);
                                            //значение целлочисленное, преобразем к типу данных int
                                            //if (strTopic == "arduinoPLC71/timeout") {
                                            //timeout = strPayload.toInt();
                                            //}
                                            if (strTopic == "arduinoPLC71/pollTimer") {
                                            if (strPayload == "null" || strPayload == "0") {
                                            //sprintf(buff,"%d",poolTime);
                                            //client.publish("arduinoPLC71/pollTimer","0");
                                            }
                                            else {
                                            poolTime = strPayload.toInt();
                                            }
                                            }
                                            else if (strTopic == "common/led") {
                                            if (strPayload == "OFF" || strPayload == "0" || strPayload == "false") digitalWrite(LED_pin, HIGH);
                                            else if (strPayload == "ON" || strPayload == "1" || strPayload == "true") digitalWrite(LED_pin, LOW);
                                            }
                                            Serial.print (strTopic);
                                            Serial.print (" ");
                                            Serial.println (strPayload);
                                            Serial.println ("-------");
                                            }
                                            //----------------------------------------- End callback ---------------------------------------//
                                            ! //------------------------------------------- connect PLC --------------------------------------//
                                            //Функция connect PLC
                                            void connPLC() {
                                            Serial.print("Connect to MQTT-broker... ");
                                            if (client.connect("arduinoPLC71")) {
                                            Serial.println("success");
                                            client.publish("arduinoPLC71/status","online");
                                            client.subscribe("arduinoPLC71/pollTimer");
                                            //client.subscribe("arduinoPLC71/timeout");
                                            client.subscribe("common/led");
                                            }
                                            else {
                                            Serial.println("failed!");
                                            }
                                            }
                                            //----------------------------------------- End connect PLC ------------------------------------//
                                            ! //------------------------------------------ Void setup ----------------------------------------//
                                            void setup() {
                                            Serial.begin(57600);
                                            pinMode(LED_pin, OUTPUT);
                                            digitalWrite(LED_pin, HIGH);
                                            Serial.println("mqtt-client arduinoPLC71... ");
                                            //стартуем сетевое подключение
                                            if (Ethernet.begin(mac) == 0) {
                                            Serial.println("Failed to configure Ethernet using DHCP");
                                            Ethernet.begin(mac, ip, gateway, subnet);
                                            delay(3000);
                                            }
                                            Serial.print("PLC's IP: ");
                                            Serial.println(Ethernet.localIP());
                                            //Serial.print("Connect to MQTT-broker... ");
                                            //подключаемся к MQTT-брокеру
                                            connPLC();
                                            }
                                            //---------------------------------------- End void setup --------------------------------------//
                                            ! //------------------------------------------ Void loop -----------------------------------------//
                                            void loop() {
                                            client.loop(); //проверка входящих соединений по подписке
                                            //если соединение не активно
                                            if (!client.connected()) {
                                            //Serial.print("Reconnect to MQTT-broker... ");
                                            //пытаемся его восстановить
                                            connPLC();
                                            }
                                            //проверяем условие интервала измерений
                                            if (millis() > (lastTime + poolTime * 1000)) {
                                            lastTime = millis();
                                            //если соединение активно
                                            if (client.connected()) {
                                            //Serial.println(" ");
                                            //считываем данные и публикуем их
                                            SensorA0 = analogRead(analogPinA0);
                                            sprintf(buff,"%d",SensorA0); //if float dtostrf(SensorA0, 5, 2, buff);
                                            // Serial.println("Publish to MQTT-broker value sensor A0 is: ");
                                            // Serial.println(buff);
                                            client.publish("arduinoPLC71/sensorA0/value",buff);
                                            client.publish("arduinoPLC71/sensorA0/status","OK");
                                            SensorA1 = analogRead(analogPinA1);
                                            sprintf(buff,"%d",SensorA1); //if float dtostrf(SensorA0, 5, 2, buff);
                                            // Serial.print("Publish to MQTT-broker value sensor A1 is: ");
                                            // Serial.println(buff);
                                            client.publish("arduinoPLC71/sensorA1/value",buff);
                                            client.publish("arduinoPLC71/sensorA1/status","OK");
                                            SensorA2 = analogRead(analogPinA2);
                                            sprintf(buff,"%d",SensorA2); //if float dtostrf(SensorA0, 5, 2, buff);
                                            // Serial.print("Publish to MQTT-broker value sensor A2 is: ");
                                            // Serial.println(buff);
                                            client.publish("arduinoPLC71/sensorA2/value",buff);
                                            client.publish("arduinoPLC71/sensorA2/status","OK");
                                            //--------
                                            }
                                            }
                                            }
                                            //---------------------------------------- End void loop ---------------------------------------//</pubsubclient.h></uipethernet.h></spi.h>

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

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