How fast can you publish MQTT messages?
现在许多的智能硬件应用都需要从传感器获得相应的数据,处理后把这些数据传递到后端。为了能够评估这些应用的性能,首先我们需要解决以下的问题:
1. 每秒从网关发送到后端的信息数
2. 在反应模块和纯Java环境中创建解决方案的比较
3. 如何在多核的环境下并行收发和处理数据的进程
在本次的测试中我们使用Raspberry Pi 2 (Model B),具体的参数如下:
Quad-core Broadcom BCM 2836 CPU
900 MHz
1GB RAM
从网关发送消息到后端
我们使用MQTT协议将信息发送到后端,使用在爱尔兰的AWS数据中心作为MQTT的服务器。由于我们的网关设定在挪威的特隆赫姆,所以传输的距离跨越了整个北海。
下图是测试应用的配置:
信息将会以1,2,5…10000的信息组的模式发送,并记录发送的时间。
首先,这个实验说明了在qos=0和qos=2时的显著的差异。在MQTT是可以设置qos的(quality of service)。当qos=0时,信息是没有保证送达和认证的,当qos=2时,信息是保证送达并且不会有重复。如果没有以上的配置,qos=2时每秒平均可以送达8到9条认证的消息,而当qos=0时每秒平均可送达1000条,是qos=2时的100多倍。这并不是件很稀奇的情形,主要还是因为后者不需要花大量