How to Use the MQTT Plug-in in JMeter
As we mentioned earlier, JMeter has built-in HTTP/HTTPS, TCP and other protocols, and has a plug-in extension mechanism.
MQTT is a mainstream protocol in the IoT world. Although it is not a protocol type that comes with JMeter, it is extremely common in IoT testing scenarios. In order to support the scale testing of the MQTT protocol, EMQ developed a JMeter-based open-source testing plug-in for the MQTT protocol.
After several iterations, the latest version of the JMeter MQTT plug-in is presently 2.0.2, which supports a variety of samplers, such as connection, message publish and message subscription, and can be combined to build more complex test scenarios.
This article will specifically introduce how to use the MQTT plug-in in JMeter.
Installing the plug-in
The installation of the MQTT plug-in is similar to other JMeter third-party plug-ins:
- Download the latest version of the plug-in mqtt-xmeter-2.0.2-jar-with-dependencies.jar from GitHub. The plug-in supports JMeter 3.2 and above.
- Copy the plug-in jar package to the plug-in directory of JMeter: $JMETER_HOME/lib/ext.
- Restart JMeter.
Main components in the plug-in
MQTT Connect Sampler
The Connect sampler simulates an IoT device and initiates an MQTT connection.
Server name or IP: The address of the MQTT server being tested.
Port number: Taking the EMQX Broker as an example, the default ports are 1883 for TCP connections, and 8883 for SSL connections. Please refer to the specific configuration of the server for the specific port.
MQTT version: Presently supports MQTT 3.1 and 3.1.1 versions.
Timeout: Connection timeout setting, in seconds.
Protocols: Supports TCP, SSL, WS and WSS connections to MQTT servers. When selecting an SSL or WSS encrypted channel connection, an one-way or two-way authentication (Dual) can be selected. If two-way authentication is required, specify the appropriate client certificate (p12 certificate) and the corresponding file protection password (Secret).
User authentication: If the MQTT server is configured for user authentication, provide the corresponding Username and Password.
ClientId: The identity of the virtual user. If “Add random suffix for ClientId” is checked, a uuid string will be added as a suffix to each ClientId and the whole virtual user identifier.
Keep alive(s): The interval for sending heartbeat signals. For example, 300 means that the client sends ping requests to the server every 300 seconds to keep the connection active.
Connect attempt max: The maximum number of reconnection attempts during the first connection. If this number is exceeded, the connection is considered failed. If the user wants to keep trying to reconnect, set this to -1.
Reconnect attempt max: The maximum number of reconnect attempts during subsequent connections. If this number is exceeded, the connection is considered failed. If the user wants to keep trying to reconnect, set this to -1.
Clean session: Set this option to false when the user wants to keep the session state between connections, or true when the user does not want to keep the session state in new connections.
MQTT Message Publish Sampler (MQTT Pub Sampler)
The message publish sampler reuses the MQTT connection established in the Connection Sampler to publish messages to the target MQTT server.
QoS Level: Quality of Service, with values 0, 1 and 2, representing AT_MOST_ONCE, AT_LEAST_ONCE and EXACTLY_ONCE, respectively, in the MQTT protocol specification.
Retained messages: If the user wants to use retained messages, set this option to true, and the MQTT server will store the retained messages published by the plug-in using given QoS. When the subscription occurs on the corresponding topic, the last retained message will be delivered directly to the subscriber. Therefore, the subscriber does not have to wait to get the latest status value of the publisher.
Topic name: The topic of the published message.
Add timestamp in payload: If checked, the present timestamp will be attached to the beginning of the published message body. Together with the 'Payload includes timestamp' option of the message subscription sampler, this can calculate the delay time reached by the message at the message receiving end. If unchecked, only the actual message body will be sent.
Payloads Message type: Three message types are presently supported
- String: Ordinary string.
- Hex String: A string is presented as a hexadecimal value, such as Hello, which can be represented as 48656C6C6F (where 48 corresponds to the letter H in the ASCII table, and so on). Typically, hexadecimal strings are used to construct non-textual message bodies, such as describing certain private protocol interactions, control information, etc.
- Random string with a fixed length: A random string of a specified length (in bytes) is generated as a message body.
MQTT Message Subscription Sampler (MQTT Sub Sampler)
The Message Pub Sampler reuses the MQTT connection established in the Connection Sampler to subscribe to messages from the target MQTT server.
QoS Level: Quality of Service, the meaning is the same as that for the Message Pub Sampler.
Topic name(s): The topic to which the subscribed message belongs. A single message subscription sampler can subscribe to multiple topics, separated by commas.
Payload includes timestamp: If checked, the send timestamp will be parsed from the beginning of the message body, which can be used to calculate the receive delay of the message with the Add timestamp in payload option of the message delivery sampler. If unchecked, merely the actual message body will be parsed.
Sample on: For the sampling method, the default is “specified elapsed time (ms)”, such as sampling every millisecond. The “number of received messages” can also be selected, such as sampling once for every specified number of messages received.
Debug response: If checked, the message content will be printed in the JMeter response. This option is mainly used for debugging purposes. It is not recommended to run the test formally when checked, in order to avoid affecting the test efficiency.
MQTT Disconnect Sampler (MQTT DisConnect)
Disconnects the MQTT connection established in the connection sampler.
For flexibility, the property values in the above sampler can refer to JMeter's system or custom variables.
This article introduced the various test components of the JMeter MQTT plug-in. The subsequent article will discuss in detail how to build test scripts with the MQTT plug-in for different test scenarios.