How to configure two Mosquitto listeners with different protocols?

68 Views Asked by At

I'm trying to enable websocket on mosquitto 2.0.11 in Ubuntu 22.04. Here my /etc/mosquitto/mosquitto.conf:

pid_file /run/mosquitto/mosquitto.pid
per_listener_settings true
password_file /etc/mosquitto/pwd_mqtt
persistence true
persistence_location /var/lib/mosquitto/
log_dest file /var/log/mosquitto/mosquitto.log
include_dir /etc/mosquitto/conf.d
connection_messages true
log_timestamp true

listener 1883
protocol mqtt
allow_anonymous false

listener 8080
protocol websockets
allow_anonymous false

Starting it with: mosquitto -c /etc/mosquitto/mosquitto.conf -v it outputs in /var/log/mosquitto/mosquitto.log:

1707293771: mosquitto version 2.0.11 starting
1707293771: Config loaded from /etc/mosquitto/mosquitto.conf.
1707293771: Opening ipv4 listen socket on port 1883.
1707293771: Opening ipv6 listen socket on port 1883.
1707293771: Opening websockets listen socket on port 8080.
1707293771: Opening ipv4 listen socket on port 1883.
1707293771: Error: Address already in use

Why does it try to open again port 1883 on the second listener?

1

There are 1 best solutions below

2
Brits On BEST ANSWER

I've duplicated this with Mosquitto 2.0.18:

mosquitto-1  | 1707333576: mosquitto version 2.0.18 starting
mosquitto-1  | 1707333576: Config loaded from /mosquitto/config/mosquitto.conf.
mosquitto-1  | 1707333576: Opening ipv4 listen socket on port 1883.
mosquitto-1  | 1707333576: Opening ipv6 listen socket on port 1883.
mosquitto-1  | 1707333576: Opening websockets listen socket on port 8080.
mosquitto-1  | 1707333576: Opening ipv4 listen socket on port 1883.
mosquitto-1  | 1707333576: Error: Address in use
mosquitto-1 exited with code 

The issue appears to be that password_file is a per_listener setting, but in your config you have it placed above the listener lines, meaning that it applies to the default listener. To solve this either remove per_listener_settings true (it's not needed in your config as it stands), or move the password_file line i.e. (simplified things a little):

per_listener_settings true
connection_messages true
log_timestamp true

listener 1883
protocol mqtt
allow_anonymous false
password_file /mosquitto/config/pwd_mqtt

listener 8080
protocol websockets
allow_anonymous false
password_file /mosquitto/config/pwd_mqtt

See this issue for something similar.