Skip to content
  • MySensors
  • OpenHardware.io
  • Categories
  • Recent
  • Tags
  • Popular
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
Brand Logo
  1. Home
  2. Development
  3. Guide: Setting up and testing MQTT Client Gateway

Guide: Setting up and testing MQTT Client Gateway

Scheduled Pinned Locked Moved Development
78 Posts 18 Posters 53.1k Views 18 Watching
  • 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.
  • M mbj

    Finally I have the ESP8266 gateway running with Mosquitto and Openhab. Because the ESP8266 Gateway installation was painless and Mosquitto and Openhab the major problems I have posted some general info at this link in case anyone is interested, see http://forum.mysensors.org/topic/3005/switching-from-v1-5-mqtt-gateway-to-esp8266-mqtt-client-gateway.
    (Sorry if this is the wrong procedure but found no way to add other tags to a message in this thread).

    M Offline
    M Offline
    mbj
    wrote on last edited by
    #59

    @mbj said:

    Finally I have the ESP8266 gateway running with Mosquitto and Openhab. Because the ESP8266 Gateway installation was painless and Mosquitto and Openhab the major problems I have posted some general info at this link in case anyone is interested, see http://forum.mysensors.org/topic/3005/switching-from-v1-5-mqtt-gateway-to-esp8266-mqtt-client-gateway.
    (Sorry if this is the wrong procedure but found no way to add other tags to a message in this thread).

    Do not know if this info is of any interest but my ESP8266 MQTT gateway (based on a NodeMCU board) has been running without hiccups for almost a month now. So it has been very stable. I have also made a very short test using a Wemos D1 Mini for the gateway and this one seemed to be working as expected as well (not very surprised but you never know until it has been tested :-)).

    1 Reply Last reply
    0
    • D Offline
      D Offline
      DirkB19
      wrote on last edited by
      #60

      Hi,

      I've uploaded the GatewayW5100MQTTClient.ino to a UNO with W5100.

      I have changed IP adresses to my Mosquitto broker (on Raspberry Pi) as instructed.

      However,
      I don't see the gateway connecting to the Mosquitto (in the /var/log/mosquitto/mosquitto.log on RPI) and also I don't see anything in the serial monitor. I've got 10+ sensornodes that work well when using another gateway (to OpenHab).
      What am I overlooking here ?

      The same hardware UNO+W5100 worked before as MQTTgateway(+broker), so I'm guessing it's not the hardware?

      Any help is appreciated.
      Thanks,
      DirkB

      greglG M 2 Replies Last reply
      0
      • D DirkB19

        Hi,

        I've uploaded the GatewayW5100MQTTClient.ino to a UNO with W5100.

        I have changed IP adresses to my Mosquitto broker (on Raspberry Pi) as instructed.

        However,
        I don't see the gateway connecting to the Mosquitto (in the /var/log/mosquitto/mosquitto.log on RPI) and also I don't see anything in the serial monitor. I've got 10+ sensornodes that work well when using another gateway (to OpenHab).
        What am I overlooking here ?

        The same hardware UNO+W5100 worked before as MQTTgateway(+broker), so I'm guessing it's not the hardware?

        Any help is appreciated.
        Thanks,
        DirkB

        greglG Offline
        greglG Offline
        gregl
        Hero Member
        wrote on last edited by
        #61

        @DirkB19

        Hi Dirk - did you change the MAC address ( these need to be unique too and it could have the same one "DEADBEEFFEED" as your existing GW )

        1 Reply Last reply
        0
        • D DirkB19

          Hi,

          I've uploaded the GatewayW5100MQTTClient.ino to a UNO with W5100.

          I have changed IP adresses to my Mosquitto broker (on Raspberry Pi) as instructed.

          However,
          I don't see the gateway connecting to the Mosquitto (in the /var/log/mosquitto/mosquitto.log on RPI) and also I don't see anything in the serial monitor. I've got 10+ sensornodes that work well when using another gateway (to OpenHab).
          What am I overlooking here ?

          The same hardware UNO+W5100 worked before as MQTTgateway(+broker), so I'm guessing it's not the hardware?

          Any help is appreciated.
          Thanks,
          DirkB

          M Offline
          M Offline
          mbj
          wrote on last edited by
          #62

          @DirkB19 If you do not see anything in the serial monitor for the gateway then the problem must be with the gateway itself. Have you observed that there is a special #define MY_W5100_SPI_EN to uncomment when compiling for an Uno with the shield installed ? If not, you can try that.

          D 1 Reply Last reply
          0
          • M mbj

            @DirkB19 If you do not see anything in the serial monitor for the gateway then the problem must be with the gateway itself. Have you observed that there is a special #define MY_W5100_SPI_EN to uncomment when compiling for an Uno with the shield installed ? If not, you can try that.

            D Offline
            D Offline
            DirkB19
            wrote on last edited by
            #63

            @mbj said:

            MY_W5100_SPI_EN

            Sorry for this NOOB question, but where is this to be uncommented.
            I don't see it in the gateway sketch ?
            I use this sketch GatewayW5100MQTTClient.ino

            M 1 Reply Last reply
            0
            • D DirkB19

              @mbj said:

              MY_W5100_SPI_EN

              Sorry for this NOOB question, but where is this to be uncommented.
              I don't see it in the gateway sketch ?
              I use this sketch GatewayW5100MQTTClient.ino

              M Offline
              M Offline
              mbj
              wrote on last edited by
              #64

              @DirkB19

              It is looking like this, just uncomment the #define - line:

              // W5100 Ethernet module SPI enable (optional if using a shield/module that manages SPI_EN signal)
              //#define MY_W5100_SPI_EN 4

              D 1 Reply Last reply
              0
              • M mbj

                @DirkB19

                It is looking like this, just uncomment the #define - line:

                // W5100 Ethernet module SPI enable (optional if using a shield/module that manages SPI_EN signal)
                //#define MY_W5100_SPI_EN 4

                D Offline
                D Offline
                DirkB19
                wrote on last edited by
                #65

                @mbj

                Thanks for the help, but I'm still very confused because OK, I found the line to uncomment.
                I uncommented, but still nothing on serial monitor.
                So then I see lines below this in the sketch and I realize that my radio is wired as follows ;
                SCK -- Pin 13
                MISO -- Pin 12
                MOSI -- Pin 11
                CS -- Pin 6
                CE -- Pin 5
                ?
                But there's no Pins 14,15,16 to be found on my W5100/UNO ? So I'm very confused ...

                #if !defined(MY_W5100_SPI_EN) && !defined(ARDUINO_ARCH_SAMD)
                #define MY_SOFTSPI
                #define MY_SOFT_SPI_SCK_PIN 14
                #define MY_SOFT_SPI_MISO_PIN 16
                #define MY_SOFT_SPI_MOSI_PIN 15
                #endif

                // When W5100 is connected we have to move CE/CSN pins for NRF radio
                #define MY_RF24_CE_PIN 5
                #define MY_RF24_CS_PIN 6

                martinhjelmareM M 2 Replies Last reply
                0
                • D DirkB19

                  @mbj

                  Thanks for the help, but I'm still very confused because OK, I found the line to uncomment.
                  I uncommented, but still nothing on serial monitor.
                  So then I see lines below this in the sketch and I realize that my radio is wired as follows ;
                  SCK -- Pin 13
                  MISO -- Pin 12
                  MOSI -- Pin 11
                  CS -- Pin 6
                  CE -- Pin 5
                  ?
                  But there's no Pins 14,15,16 to be found on my W5100/UNO ? So I'm very confused ...

                  #if !defined(MY_W5100_SPI_EN) && !defined(ARDUINO_ARCH_SAMD)
                  #define MY_SOFTSPI
                  #define MY_SOFT_SPI_SCK_PIN 14
                  #define MY_SOFT_SPI_MISO_PIN 16
                  #define MY_SOFT_SPI_MOSI_PIN 15
                  #endif

                  // When W5100 is connected we have to move CE/CSN pins for NRF radio
                  #define MY_RF24_CE_PIN 5
                  #define MY_RF24_CS_PIN 6

                  martinhjelmareM Offline
                  martinhjelmareM Offline
                  martinhjelmare
                  Plugin Developer
                  wrote on last edited by martinhjelmare
                  #66

                  @DirkB19

                  In this case I think pin 14-16 are meant to be aliases for analog pins A0-A2.

                  Read the build page for the Ethernet gateway. You have to wire the radio in a non standard way in combination with the 5100.

                  But it's optional when using the shield. You could enable the SPI for that instead, like you were talking about a few posts up.

                  1 Reply Last reply
                  0
                  • D DirkB19

                    @mbj

                    Thanks for the help, but I'm still very confused because OK, I found the line to uncomment.
                    I uncommented, but still nothing on serial monitor.
                    So then I see lines below this in the sketch and I realize that my radio is wired as follows ;
                    SCK -- Pin 13
                    MISO -- Pin 12
                    MOSI -- Pin 11
                    CS -- Pin 6
                    CE -- Pin 5
                    ?
                    But there's no Pins 14,15,16 to be found on my W5100/UNO ? So I'm very confused ...

                    #if !defined(MY_W5100_SPI_EN) && !defined(ARDUINO_ARCH_SAMD)
                    #define MY_SOFTSPI
                    #define MY_SOFT_SPI_SCK_PIN 14
                    #define MY_SOFT_SPI_MISO_PIN 16
                    #define MY_SOFT_SPI_MOSI_PIN 15
                    #endif

                    // When W5100 is connected we have to move CE/CSN pins for NRF radio
                    #define MY_RF24_CE_PIN 5
                    #define MY_RF24_CS_PIN 6

                    M Offline
                    M Offline
                    mbj
                    wrote on last edited by mbj
                    #67

                    @DirkB19 The Arduino pinouts are, to say the least, confusing and it helps to look at one of the pinout sketches you can find on the net, for example http://marcusjenkins.com/wp-content/uploads/2014/06/ARDUINO_V2.png. So the pins are, as Martin said, (A0-A2) which must be exactly as you had them wired before if you had a "previous version" working MQTT Ethernet gateway. I have such a gateway (nowadays used as a spare) but built with a nano and a W5100 unit and it compiled and worked right away using the GatewayW5100MQTTClient.ino sketch from the development branch.

                    As you see nothing in the serial monitor there must be something else. Even if you upload the sketch to a completely barebone UNO without radio or anything else attached you will get a message in the serial monitor, in this case:

                    0;255;3;0;9;Starting gateway (RNNGA-, 2.0.0-beta)
                    0;255;3;0;9;Radio init failed. Check wiring.

                    So if you see nothing at all there is something really basic wrong.
                    Presumably your sketch compiles OK so I assume you have exchanged all Arduino libraries to the libraries which belong to the Mysensors development branch.

                    D 1 Reply Last reply
                    0
                    • M mbj

                      @DirkB19 The Arduino pinouts are, to say the least, confusing and it helps to look at one of the pinout sketches you can find on the net, for example http://marcusjenkins.com/wp-content/uploads/2014/06/ARDUINO_V2.png. So the pins are, as Martin said, (A0-A2) which must be exactly as you had them wired before if you had a "previous version" working MQTT Ethernet gateway. I have such a gateway (nowadays used as a spare) but built with a nano and a W5100 unit and it compiled and worked right away using the GatewayW5100MQTTClient.ino sketch from the development branch.

                      As you see nothing in the serial monitor there must be something else. Even if you upload the sketch to a completely barebone UNO without radio or anything else attached you will get a message in the serial monitor, in this case:

                      0;255;3;0;9;Starting gateway (RNNGA-, 2.0.0-beta)
                      0;255;3;0;9;Radio init failed. Check wiring.

                      So if you see nothing at all there is something really basic wrong.
                      Presumably your sketch compiles OK so I assume you have exchanged all Arduino libraries to the libraries which belong to the Mysensors development branch.

                      D Offline
                      D Offline
                      DirkB19
                      wrote on last edited by
                      #68

                      @mbj

                      Aha !! Finally, it WORKS :)
                      mbj gave me the right hint about using the development libraries !!!

                      So for others to learn from my mistakes, to get a UNO&W5100 shield to work with this MQTT Client Gateway sketch, you need your nRF24 radio connected to these pins nrs. on the W5100 shield ;
                      SCK -- Pin 13
                      MISO -- Pin 12
                      MOSI -- Pin 11
                      CS -- Pin 6
                      CE -- Pin 5

                      AND (!) you need to install the libraries from the development branch.
                      (I first removed the 1.5 libraries)

                      I just hope that installing the libraries from development branch will not get me into trouble with my the rest of my nodes (upladed with 1.5).

                      Is there an easy way to switch between 1.5 & development branch libraries when uploading sketches ?

                      Anyway, thanks to all those who responded and special thanks to mbj.

                      Some things are so obvious, but for newbies (like me) it can be a struggle ...

                      martinhjelmareM 1 Reply Last reply
                      1
                      • D DirkB19

                        @mbj

                        Aha !! Finally, it WORKS :)
                        mbj gave me the right hint about using the development libraries !!!

                        So for others to learn from my mistakes, to get a UNO&W5100 shield to work with this MQTT Client Gateway sketch, you need your nRF24 radio connected to these pins nrs. on the W5100 shield ;
                        SCK -- Pin 13
                        MISO -- Pin 12
                        MOSI -- Pin 11
                        CS -- Pin 6
                        CE -- Pin 5

                        AND (!) you need to install the libraries from the development branch.
                        (I first removed the 1.5 libraries)

                        I just hope that installing the libraries from development branch will not get me into trouble with my the rest of my nodes (upladed with 1.5).

                        Is there an easy way to switch between 1.5 & development branch libraries when uploading sketches ?

                        Anyway, thanks to all those who responded and special thanks to mbj.

                        Some things are so obvious, but for newbies (like me) it can be a struggle ...

                        martinhjelmareM Offline
                        martinhjelmareM Offline
                        martinhjelmare
                        Plugin Developer
                        wrote on last edited by
                        #69

                        @DirkB19

                        You can use git to easily change between different branches with libraries and sketches.

                        The take home message from the first sentence in the top post of this thread, is that dev branch libs are required with this sketch.

                        You should take care not to mix old style sketches with dev branch library and vice versa. Node to node to gateway comm should be OK as long as all nodes and gateway know the message types being used.

                        1 Reply Last reply
                        0
                        • M Offline
                          M Offline
                          moskovskiy82
                          wrote on last edited by
                          #70

                          In most examples for the openhab i see the examples being put like

                          Dimmer Light_R {mqtt=">[server:/mySensors/118/0/V_DIMMER:state:*:default]"}

                          Is there a way with the MQTT client gateway to have the messages defined as
                          V_DIMMER e.t.c?

                          27maximilian2 1 Reply Last reply
                          0
                          • M moskovskiy82

                            In most examples for the openhab i see the examples being put like

                            Dimmer Light_R {mqtt=">[server:/mySensors/118/0/V_DIMMER:state:*:default]"}

                            Is there a way with the MQTT client gateway to have the messages defined as
                            V_DIMMER e.t.c?

                            27maximilian2 Offline
                            27maximilian2 Offline
                            27maximilian
                            wrote on last edited by
                            #71

                            @moskovskiy82

                            I believe these examples are mostly referring to the older MQTT (Broker) Gateway. As @hek said in post #1 the client gateway resembles the serial protocol. The difference between the two is on the one hand a slightly modified topic structure and on the other hand that instead of names the topics make use of the number representation of the message types (see the Serial API).

                            In your example you would have to use 3 instead of V_DIMMER as CMD-TYPE in your topic-configuration.

                            If you are wondering whether there is a library which you can included in your items-file in openhab such that you can use the name representation instead of the values for the message type, then I am afraid I don't have a solution for you. I am, moreover, pretty sure that this won't be possible with the mqtt-binding but would require a specific mysensors binding for openhab.

                            1 Reply Last reply
                            0
                            • M Offline
                              M Offline
                              moskovskiy82
                              wrote on last edited by
                              #72

                              And for the better understanding - why were the inbound and outbound topics separated? Are there any drawbacks in unifiing when using openhab as a controller?

                              1 Reply Last reply
                              0
                              • hekH Offline
                                hekH Offline
                                hek
                                Admin
                                wrote on last edited by
                                #73

                                If they weren't separated all outgoing messages would be looped back to the gateway.

                                1 Reply Last reply
                                0
                                • 27maximilian2 Offline
                                  27maximilian2 Offline
                                  27maximilian
                                  wrote on last edited by 27maximilian
                                  #74

                                  Update: I guess I was answering while @hek also posted his answer.

                                  I didn't do it, so I can only guess. But I believe this was done because otherwise the MQTT-topic would not include any information who the recipient is. This would on the one hand (1) make the GW send every message from a sensor back to the sensor and on the other hand (2) could cause infinite loops with controllers such as openhab.

                                  Regarding (1), imagine the topic-strucutre would be like:

                                  mysensors/6/1/1/0/0
                                  

                                  for a temperature sensors with node id 6 and child id 1 without the in/out separation. If the sensor now sends a message with the temperature, e.g. 23, to the GW, then the GW posts a message with the payload 23 to the topic. However, because there is no in/out separation, the GW listens to all messages on the topic

                                  mysensors/#
                                  

                                  and hence receives it own message, which it then sends back to the originating sensor. Not only would this double the traffic in your radio network, it might also be problematic for bidirectional sensors, such as a relay, because it would also cause an infinite loop.

                                  Regarding the infinite loop, I will use (2) as an example but the same would happen for a bidirectional sensor. Consider you would have a relay sensors, that can be locally or remotely trigged, as for example a lights relay with switch. In openhab this relay could be defined like this:

                                  Switch LIGHT_test {mqtt=">[mosqMQTT:mysensors/2/1/1/0/2:command:*:default],>[mosqMQTT:mysensors/2/1/1/0/2:command:default]"}
                                  

                                  Imagine the local switch is trigged on the relay, then the sensor sends a message to the GW, which posts this message on the mqtt-topic:

                                  mysensors/2/1/1/0/2
                                  

                                  The OH receives this message, updates the state of this item but also posts a message on the topic because of the item configuration, which would generate an infinite loop. If the sensor would do the same then we would have an infinite loop, in which the number of messages would double each iteration.

                                  1 Reply Last reply
                                  0
                                  • M Offline
                                    M Offline
                                    moskovskiy82
                                    wrote on last edited by
                                    #75

                                    @27maximilian
                                    Ok got the point. But in your example with the local button on the relay. How would one define the item in openhab?
                                    Seems two items need to be defined - buton with the gateway-in topic and a relay with gateway-out topic? And than implement a rule to update the relay status when the button state was changed? As otherwise the controller wouldn't know the state of the relay?

                                    Seems i will face exact same problem as in this topic when i finish the code MQTT Dimmer

                                    1 Reply Last reply
                                    0
                                    • 27maximilian2 Offline
                                      27maximilian2 Offline
                                      27maximilian
                                      wrote on last edited by
                                      #76

                                      I am not sure because I never did this myself but I would try to not only use the command class but also the state class in OH.

                                      Something like this could work:

                                      Switch LIGHT_test {mqtt=">[mosqMQTT:mysensors-in/2/1/1/0/2:command:*:default],<[mosqMQTT:mysensors-out/2/1/1/0/2:state:default]"}
                                      

                                      Please be aware that this is just an idea. I never implemented this so far, neither did I test the code. The syntax could be wrong or it might conceptually not work.

                                      1 Reply Last reply
                                      0
                                      • Martin TellblomM Offline
                                        Martin TellblomM Offline
                                        Martin Tellblom
                                        wrote on last edited by
                                        #77

                                        I use this gateway 2.0 and I'm very pleased with it, but...... I would like to be able to use it as a network gateway as well.
                                        Is this possible?

                                        MySensors MQTT Client Gateway, Openhab, Dashing, Razberry, 1-wire

                                        1 Reply Last reply
                                        0
                                        • S Offline
                                          S Offline
                                          Samuel235
                                          Hardware Contributor
                                          wrote on last edited by
                                          #78

                                          Sorry if i shouldn't be bringing an old thread back to life, however it is a sticky and therefor I assume you guys would be okay with this being brought up to date.

                                          I have a pretty simple question really;

                                          My W5100GatewayMQTTClient is in a loop, as shown below on the serial monitor, it seems to be reconnecting to the MQTT server every 8-10 seconds. Is this normal behaviour or not? I'm by no means asking for a solution (if i get one i will be sure to post here for others to revert back to if needed), but if you would like to suggest something, then it would be appreciated. I'm looking more for just a confirmation of if this is normal behaviour as of MySensors 2.1 or not.

                                          I used to run this client gateway back when MySensors V1.6 was in the development branch back in late 2015 and It didn't do anything like this back then.

                                          MySensors 2.1.1
                                          Controller - OpenHAB (Virtual Machine)
                                          Gateway - Arduino Mega MQTT Gateway W5100

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


                                          20

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.0k

                                          Posts


                                          Copyright 2019 TBD   |   Forum Guidelines   |   Privacy Policy   |   Terms of Service
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • MySensors
                                          • OpenHardware.io
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular