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. Announcements
  3. 💬 Building a Raspberry Pi Gateway

💬 Building a Raspberry Pi Gateway

Scheduled Pinned Locked Moved Announcements
1.1k Posts 173 Posters 428.3k Views 131 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.
  • AndurilA Anduril

    just cloned and read the --help, but still I don't know how to use.
    To make it a litte less abstract: I have a ethernet gateway (ESP8266) running at 192.168.38.19 with port 5003 to connect to. I want to have this accessible by a serial-only controller on the raspberry.

    I tried to do this config and make afterwards, but starting gave only FAILs...

    ./configure --my-gateway=ethernet --my-controller-ip-address=192.168.38.19 --my-serial-is-pty --my-serial-pty=/dev/ttyMySensorsGateway
    
    ~/MySensors$ sudo ./bin/mysgw -d
    mysgw: Starting gateway...
    mysgw: Protocol version - 2.1.0
    mysgw: MCO:BGN:INIT GW,CP=RNNG---,VER=2.1.0
    mysgw: TSF:LRT:OK
    mysgw: TSM:INIT
    mysgw: TSF:WUR:MS=0
    mysgw: !TSM:INIT:TSP FAIL
    mysgw: TSM:FAIL:CNT=1
    mysgw: TSM:FAIL:PDT
    mysgw: TSM:FAIL:RE-INIT
    mysgw: TSM:INIT
    mysgw: !TSM:INIT:TSP FAIL
    mysgw: TSM:FAIL:CNT=2
    mysgw: TSM:FAIL:PDT
    mysgw: TSM:FAIL:RE-INIT
    mysgw: TSM:INIT
    mysgw: !TSM:INIT:TSP FAIL
    mysgw: TSM:FAIL:CNT=3
    mysgw: TSM:FAIL:PDT
    mysgw: TSM:FAIL:RE-INIT
    mysgw: TSM:INIT
    mysgw: !TSM:INIT:TSP FAIL
    mysgw: TSM:FAIL:CNT=4
    mysgw: TSM:FAIL:PDT
    

    I think my config is wrong and it tries to connect to a nrf24 at the rpi. So what's the correct config for my case?

    Thanks in advance.

    gohanG Offline
    gohanG Offline
    gohan
    Mod
    wrote on last edited by
    #310

    @Anduril
    Why are you using an esp8266 as a serial gateway? Wouldn't it be easier to use a normal UNO?

    1 Reply Last reply
    0
    • AndurilA Offline
      AndurilA Offline
      Anduril
      wrote on last edited by
      #311

      I'm using a ESP8266 as ethernet gateway and want to have this connected as virtuall serial port to my raspberry pi so my controller can connect to that.

      gohanG 1 Reply Last reply
      0
      • lakshmcL Offline
        lakshmcL Offline
        lakshmc
        wrote on last edited by
        #312

        I using RPi2 and NRF24 for this. I followed the instructions, to clone the repo, and then added config
        ./configure --my-gateway=mqtt --my-controller-ip-address=127.0.0.1 --my-mqtt-publish-topic-prefix=mysensors-out --my-mqtt-subscribe-topic-prefix=mysensors-in --my-mqtt-client-id=mygateway1 --my-transport=nrf24

        make

        when i run with sudo ./bin/mysgw -d, it is failing to connect to MQTT. Can you please help?

        mysgw: Starting gateway...
        mysgw: Protocol version - 2.1.0
        mysgw: MCO:BGN:INIT GW,CP=RNNG---,VER=2.1.0
        mysgw: TSF:LRT:OK
        mysgw: TSM:INIT
        mysgw: TSF:WUR:MS=0
        mysgw: TSM:INIT:TSP OK
        mysgw: TSM:INIT:GW MODE
        mysgw: TSM:READY:ID=0,PAR=0,DIS=0
        mysgw: MCO:REG:NOT NEEDED
        mysgw: MCO:BGN:STP
        mysgw: MCO:BGN:INIT OK,TSP=1
        mysgw: Attempting MQTT connection...
        mysgw: connect: Connection refused
        mysgw: failed to connect
        mysgw: Attempting MQTT connection...
        mysgw: connect: Connection refused
        mysgw: failed to connect
        mysgw: Attempting MQTT connection...
        mysgw: connect: Connection refused
        mysgw: failed to connect
        mysgw: Attempting MQTT connection...
        mysgw: connect: Connection refused
        mysgw: failed to connect

        P 1 Reply Last reply
        0
        • AndurilA Anduril

          I'm using a ESP8266 as ethernet gateway and want to have this connected as virtuall serial port to my raspberry pi so my controller can connect to that.

          gohanG Offline
          gohanG Offline
          gohan
          Mod
          wrote on last edited by
          #313

          @Anduril

          Have you aver considered Using the GatewayESP8266MQTTClient? What controller are you trying to connect?

          1 Reply Last reply
          0
          • AndurilA Offline
            AndurilA Offline
            Anduril
            wrote on last edited by
            #314

            I use pimatic which does not have a native compatibility to ethernet or mqtt. Thats why my question came up on how to configure it to do this...

            Building a Raspberry Pi Gateway:

            If you are running a controller on the Raspberry Pi that doesn't support communication with the gateway through ethernet, you can use a virtual serial port:
            ./configure --my-gateway=serial --my-serial-is-pty --my-serial-pty=/dev/ttyMySensorsGateway

            mfalkviddM 1 Reply Last reply
            0
            • AndurilA Anduril

              I use pimatic which does not have a native compatibility to ethernet or mqtt. Thats why my question came up on how to configure it to do this...

              Building a Raspberry Pi Gateway:

              If you are running a controller on the Raspberry Pi that doesn't support communication with the gateway through ethernet, you can use a virtual serial port:
              ./configure --my-gateway=serial --my-serial-is-pty --my-serial-pty=/dev/ttyMySensorsGateway

              mfalkviddM Offline
              mfalkviddM Offline
              mfalkvidd
              Mod
              wrote on last edited by
              #315

              @Anduril you might be able to use nodered or socat to convert the tcp connection to a serial port.
              https://linux.die.net/man/1/socat
              https://nodered.org/

              1 Reply Last reply
              0
              • AndurilA Offline
                AndurilA Offline
                Anduril
                wrote on last edited by
                #316

                that's what I tried in the past and am using now (socat), but it does not reconnect and has some other drawbacks. Reading of an officially supported way sounded interesting

                1 Reply Last reply
                0
                • lakshmcL lakshmc

                  I using RPi2 and NRF24 for this. I followed the instructions, to clone the repo, and then added config
                  ./configure --my-gateway=mqtt --my-controller-ip-address=127.0.0.1 --my-mqtt-publish-topic-prefix=mysensors-out --my-mqtt-subscribe-topic-prefix=mysensors-in --my-mqtt-client-id=mygateway1 --my-transport=nrf24

                  make

                  when i run with sudo ./bin/mysgw -d, it is failing to connect to MQTT. Can you please help?

                  mysgw: Starting gateway...
                  mysgw: Protocol version - 2.1.0
                  mysgw: MCO:BGN:INIT GW,CP=RNNG---,VER=2.1.0
                  mysgw: TSF:LRT:OK
                  mysgw: TSM:INIT
                  mysgw: TSF:WUR:MS=0
                  mysgw: TSM:INIT:TSP OK
                  mysgw: TSM:INIT:GW MODE
                  mysgw: TSM:READY:ID=0,PAR=0,DIS=0
                  mysgw: MCO:REG:NOT NEEDED
                  mysgw: MCO:BGN:STP
                  mysgw: MCO:BGN:INIT OK,TSP=1
                  mysgw: Attempting MQTT connection...
                  mysgw: connect: Connection refused
                  mysgw: failed to connect
                  mysgw: Attempting MQTT connection...
                  mysgw: connect: Connection refused
                  mysgw: failed to connect
                  mysgw: Attempting MQTT connection...
                  mysgw: connect: Connection refused
                  mysgw: failed to connect
                  mysgw: Attempting MQTT connection...
                  mysgw: connect: Connection refused
                  mysgw: failed to connect

                  P Offline
                  P Offline
                  pete1450
                  wrote on last edited by pete1450
                  #317

                  @lakshmc Make sure you don't have the daemon running already

                  If not, I'm getting the same problem on the 2.1.1 that was just released. 2.1.0 was working "fine"(besides my suspecting a bug that doesn't let any inclusion happen, hence I tried the new version). Time to go back to the serial gateway right into the vera.

                  M 1 Reply Last reply
                  0
                  • P pete1450

                    @lakshmc Make sure you don't have the daemon running already

                    If not, I'm getting the same problem on the 2.1.1 that was just released. 2.1.0 was working "fine"(besides my suspecting a bug that doesn't let any inclusion happen, hence I tried the new version). Time to go back to the serial gateway right into the vera.

                    M Offline
                    M Offline
                    marceloaqno
                    Code Contributor
                    wrote on last edited by
                    #318

                    @pete1450 @lakshmc
                    Make sure you are not using an old version of mosquitto (or any other broker you're using):

                    $ mosquitto -h
                    mosquitto version 1.4.10 (build date 2016-09-20 11:02:07-0600)
                    

                    It's working fine with the 2.1.1 release:

                    [alarm@pi3 mysgw]$ sudo ./bin/mysgw -d
                    mysgw: Starting gateway...
                    mysgw: Protocol version - 2.1.1
                    mysgw: MCO:BGN:INIT GW,CP=RNNG---,VER=2.1.1
                    mysgw: TSF:LRT:OK
                    mysgw: TSM:INIT
                    mysgw: TSF:WUR:MS=0
                    mysgw: TSM:INIT:TSP OK
                    mysgw: TSM:INIT:GW MODE
                    mysgw: TSM:READY:ID=0,PAR=0,DIS=0
                    mysgw: MCO:REG:NOT NEEDED
                    mysgw: MCO:BGN:STP
                    mysgw: MCO:BGN:INIT OK,TSP=1
                    mysgw: Attempting MQTT connection...
                    mysgw: connected to 127.0.0.1
                    mysgw: MQTT connected
                    mysgw: Sending message on topic: mysensors-out/0/255/0/0/18
                    mysgw: TSF:MSG:READ,2-2-0,s=1,c=1,t=17,pt=7,l=5,sg=0:108.12
                    mysgw: TSF:MSG:ACK REQ
                    mysgw: TSF:MSG:SEND,0-0-2-2,s=1,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:108.12
                    mysgw: Sending message on topic: mysensors-out/2/1/1/0/17
                    mysgw: TSF:MSG:READ,2-2-0,s=2,c=1,t=17,pt=7,l=5,sg=0:48.31
                    mysgw: TSF:MSG:ACK REQ
                    mysgw: TSF:MSG:SEND,0-0-2-2,s=2,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:48.31
                    mysgw: Sending message on topic: mysensors-out/2/2/1/0/17
                    mysgw: TSF:MSG:READ,2-2-0,s=3,c=1,t=17,pt=7,l=5,sg=0:362.86
                    mysgw: TSF:MSG:ACK REQ
                    mysgw: TSF:MSG:SEND,0-0-2-2,s=3,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:362.86
                    mysgw: Sending message on topic: mysensors-out/2/3/1/0/17
                    
                    P 1 Reply Last reply
                    0
                    • M marceloaqno

                      @pete1450 @lakshmc
                      Make sure you are not using an old version of mosquitto (or any other broker you're using):

                      $ mosquitto -h
                      mosquitto version 1.4.10 (build date 2016-09-20 11:02:07-0600)
                      

                      It's working fine with the 2.1.1 release:

                      [alarm@pi3 mysgw]$ sudo ./bin/mysgw -d
                      mysgw: Starting gateway...
                      mysgw: Protocol version - 2.1.1
                      mysgw: MCO:BGN:INIT GW,CP=RNNG---,VER=2.1.1
                      mysgw: TSF:LRT:OK
                      mysgw: TSM:INIT
                      mysgw: TSF:WUR:MS=0
                      mysgw: TSM:INIT:TSP OK
                      mysgw: TSM:INIT:GW MODE
                      mysgw: TSM:READY:ID=0,PAR=0,DIS=0
                      mysgw: MCO:REG:NOT NEEDED
                      mysgw: MCO:BGN:STP
                      mysgw: MCO:BGN:INIT OK,TSP=1
                      mysgw: Attempting MQTT connection...
                      mysgw: connected to 127.0.0.1
                      mysgw: MQTT connected
                      mysgw: Sending message on topic: mysensors-out/0/255/0/0/18
                      mysgw: TSF:MSG:READ,2-2-0,s=1,c=1,t=17,pt=7,l=5,sg=0:108.12
                      mysgw: TSF:MSG:ACK REQ
                      mysgw: TSF:MSG:SEND,0-0-2-2,s=1,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:108.12
                      mysgw: Sending message on topic: mysensors-out/2/1/1/0/17
                      mysgw: TSF:MSG:READ,2-2-0,s=2,c=1,t=17,pt=7,l=5,sg=0:48.31
                      mysgw: TSF:MSG:ACK REQ
                      mysgw: TSF:MSG:SEND,0-0-2-2,s=2,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:48.31
                      mysgw: Sending message on topic: mysensors-out/2/2/1/0/17
                      mysgw: TSF:MSG:READ,2-2-0,s=3,c=1,t=17,pt=7,l=5,sg=0:362.86
                      mysgw: TSF:MSG:ACK REQ
                      mysgw: TSF:MSG:SEND,0-0-2-2,s=3,c=1,t=17,pt=7,l=5,sg=0,ft=0,st=OK:362.86
                      mysgw: Sending message on topic: mysensors-out/2/3/1/0/17
                      
                      P Offline
                      P Offline
                      pete1450
                      wrote on last edited by
                      #319

                      @marceloaqno I should have specified, I'm getting the connection errors with the ethernet gateway.

                      M 1 Reply Last reply
                      0
                      • P pete1450

                        @marceloaqno I should have specified, I'm getting the connection errors with the ethernet gateway.

                        M Offline
                        M Offline
                        marceloaqno
                        Code Contributor
                        wrote on last edited by
                        #320

                        @pete1450 Could you send the debug log with the connection errors?

                        P 1 Reply Last reply
                        0
                        • lakshmcL Offline
                          lakshmcL Offline
                          lakshmc
                          wrote on last edited by
                          #321

                          @marceloaqno After installing broker and gateway fresh, seems to be working. Thanks for your help.

                          1 Reply Last reply
                          0
                          • M marceloaqno

                            @pete1450 Could you send the debug log with the connection errors?

                            P Offline
                            P Offline
                            pete1450
                            wrote on last edited by
                            #322

                            @marceloaqno
                            Ran as root and made sure I didn't have mysgw already running:

                            rm -r MySensors/
                            git clone https://github.com/mysensors/MySensors.git --branch master
                            cd MySensors/
                            ./configure --my-controller-ip-address=192.168.1.136 --my-port=5003 --my-rf24-irq-pin=15
                            make
                            
                            
                            root@raspberrypi:~/downloads/MySensors# ./bin/mysgw -d
                            mysgw: Starting gateway...
                            mysgw: Protocol version - 2.1.1
                            mysgw: MCO:BGN:INIT GW,CP=RNNG--Q,VER=2.1.1
                            mysgw: TSF:LRT:OK
                            mysgw: TSM:INIT
                            mysgw: TSF:WUR:MS=0
                            mysgw: TSM:INIT:TSP OK
                            mysgw: TSM:INIT:GW MODE
                            mysgw: TSM:READY:ID=0,PAR=0,DIS=0
                            mysgw: MCO:REG:NOT NEEDED
                            mysgw: connect: Connection refused
                            mysgw: failed to connect
                            mysgw: Eth: connect
                            
                            M 1 Reply Last reply
                            0
                            • b0rmannB Offline
                              b0rmannB Offline
                              b0rmann
                              wrote on last edited by
                              #323

                              every few days mysgw randomly dies :(

                              Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:READ,5-5-0,s=255,c=3,t=21,pt=1,l=1,sg=0:0
                              Jan 19 06:40:01 pi mysgw[17960]: Sending message on topic: mysensors/out/1/5/255/3/0/21
                              Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:READ,0-5-255,s=255,c=3,t=20,pt=0,l=0,sg=0:
                              Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:BC
                              Jan 19 06:40:01 pi systemd[1]: mysgw.service: main process exited, code=killed, status=11/SEGV
                              Jan 19 06:40:01 pi systemd[1]: Unit mysgw.service entered failed state.
                              
                              
                              M 1 Reply Last reply
                              0
                              • P pete1450

                                @marceloaqno
                                Ran as root and made sure I didn't have mysgw already running:

                                rm -r MySensors/
                                git clone https://github.com/mysensors/MySensors.git --branch master
                                cd MySensors/
                                ./configure --my-controller-ip-address=192.168.1.136 --my-port=5003 --my-rf24-irq-pin=15
                                make
                                
                                
                                root@raspberrypi:~/downloads/MySensors# ./bin/mysgw -d
                                mysgw: Starting gateway...
                                mysgw: Protocol version - 2.1.1
                                mysgw: MCO:BGN:INIT GW,CP=RNNG--Q,VER=2.1.1
                                mysgw: TSF:LRT:OK
                                mysgw: TSM:INIT
                                mysgw: TSF:WUR:MS=0
                                mysgw: TSM:INIT:TSP OK
                                mysgw: TSM:INIT:GW MODE
                                mysgw: TSM:READY:ID=0,PAR=0,DIS=0
                                mysgw: MCO:REG:NOT NEEDED
                                mysgw: connect: Connection refused
                                mysgw: failed to connect
                                mysgw: Eth: connect
                                
                                M Offline
                                M Offline
                                marceloaqno
                                Code Contributor
                                wrote on last edited by
                                #324

                                @pete1450 If you use the --my-controller-ip-address= option, the gateway will act as a client and attempt to conect to the supplied ip and port. If you want the gateway to open port 5003, omit this option.

                                P 1 Reply Last reply
                                0
                                • AndurilA Offline
                                  AndurilA Offline
                                  Anduril
                                  wrote on last edited by
                                  #325

                                  @marceloaqno what is the correct configure option to make this gatway connect to an ethernet gateway and let a serial-only-controller connect to it. I suppose to use the pty option, but didn't got this working. As said above, socat and nodered are no option.

                                  M 1 Reply Last reply
                                  0
                                  • M marceloaqno

                                    @pete1450 If you use the --my-controller-ip-address= option, the gateway will act as a client and attempt to conect to the supplied ip and port. If you want the gateway to open port 5003, omit this option.

                                    P Offline
                                    P Offline
                                    pete1450
                                    wrote on last edited by pete1450
                                    #326

                                    @marceloaqno Well that fixed the connection issue. Now I'm just back to square one where pressing start doesn't do anything. Why do I not need to specify my controllers ip? That is the ip for my veralite. Whats the use case for that option.

                                    M 1 Reply Last reply
                                    0
                                    • b0rmannB b0rmann

                                      every few days mysgw randomly dies :(

                                      Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:READ,5-5-0,s=255,c=3,t=21,pt=1,l=1,sg=0:0
                                      Jan 19 06:40:01 pi mysgw[17960]: Sending message on topic: mysensors/out/1/5/255/3/0/21
                                      Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:READ,0-5-255,s=255,c=3,t=20,pt=0,l=0,sg=0:
                                      Jan 19 06:40:01 pi mysgw[17960]: TSF:MSG:BC
                                      Jan 19 06:40:01 pi systemd[1]: mysgw.service: main process exited, code=killed, status=11/SEGV
                                      Jan 19 06:40:01 pi systemd[1]: Unit mysgw.service entered failed state.
                                      
                                      
                                      M Offline
                                      M Offline
                                      marceloaqno
                                      Code Contributor
                                      wrote on last edited by
                                      #327

                                      @b0rmann Could you provide the following information?

                                      • Your RPi model and which linux distribution you are using.
                                      • gcc version
                                      • The version and options you used to build the gateway (./configure --option)
                                      • The number of nodes on your network that sends messages to the gateway.
                                      • The broker you are using for MQTT and its version
                                      1 Reply Last reply
                                      1
                                      • AndurilA Anduril

                                        @marceloaqno what is the correct configure option to make this gatway connect to an ethernet gateway and let a serial-only-controller connect to it. I suppose to use the pty option, but didn't got this working. As said above, socat and nodered are no option.

                                        M Offline
                                        M Offline
                                        marceloaqno
                                        Code Contributor
                                        wrote on last edited by
                                        #328

                                        @Anduril Sorry, the gateway does not support what you're trying to do.

                                        1 Reply Last reply
                                        0
                                        • P pete1450

                                          @marceloaqno Well that fixed the connection issue. Now I'm just back to square one where pressing start doesn't do anything. Why do I not need to specify my controllers ip? That is the ip for my veralite. Whats the use case for that option.

                                          M Offline
                                          M Offline
                                          marceloaqno
                                          Code Contributor
                                          wrote on last edited by
                                          #329

                                          @pete1450
                                          I can't help you with this, I've never used the Vera controller. You need to search in the Vera settings where you set this option. If Vera supports being a server and opening a port for the gateway to connect, then you use the --my-controller-ip-address option.

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


                                          17

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.1k

                                          Posts


                                          Copyright 2025 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