Mosquitto: WebSockets

How to connect to MQTT using WebSockets

👋 Welcome to the Stackhero documentation!

Stackhero offers a ready-to-use Mosquitto MQTT cloud solution that provides a host of benefits, including:

  • Unlimited message exchanges and transfers.
  • Unlimited devices authentication via an external API.
  • Advanced ACLs on topics, users and actions.
  • Customizable domain name secured with HTTPS (for example, https://mqtt.your-company.com).
  • Effortless updates with just a click.
  • Optimal performance and robust security powered by a private and dedicated VM.

Save time and simplify your life: it only takes 5 minutes to try Stackhero's Mosquitto MQTT cloud hosting solution!

You have two main options for connecting to Mosquitto: the native MQTT protocol or WebSockets.

The MQTT protocol is widely recognized for its lightweight design, which makes it especially suitable for IoT devices and resource-constrained environments. However, most web browsers do not support direct MQTT connections. This is where WebSockets are useful, as they allow you to run MQTT over a WebSocket connection, making it possible to interact with MQTT servers from your browser-based applications.

To get started with WebSockets, you can simply enable the "WebSocket support" option in your Stackhero dashboard. Once this feature is active, you just need to point your client to the WebSocket URL: wss://<XXXXXX>.stackhero-network.com:443. This replaces the standard MQTT secure URL, which looks like: mqtts://<XXXXXX>.stackhero-network.com.

If your application is written in JavaScript, you might want to explore the MQTT.js library. It is a flexible choice that works both in Node.js environments and directly in the browser. The library documentation and source code are available here: https://github.com/mqttjs/MQTT.js.

You can find a practical demonstration of how to connect a web application to an MQTT server using WebSockets in this example repository: https://github.com/stackhero-io/mqttWebSocketGettingStarted.

When trying out this example, remember to update the src/index.html file with your own server url, username, and password.

MQTT WebSocket exampleMQTT WebSocket example

Remember to activate WebSocket support in the Stackhero dashboard before proceeding.