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

    Do I read that correctly, does this gateway also gives a ethernet link to a serial-only controller? How do I have to configure ip and port? In the build section I see no option to set them.

    T Offline
    T Offline
    Tag
    wrote on last edited by
    #308

    @Anduril
    you will get all the build options for the mysgw with the command

    ./configure -help
    

    Here you can configure all options like serial and ethernet

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

      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 1 Reply Last reply
      0
      • 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
                                          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