数据存储设计

一对一消息存储

image

  1. Publish 端发布一条消息;
  2. Backend 将消息记录数据库中;
  3. Subscribe 端订阅主题;
  4. Backend 从数据库中获取该主题的消息;
  5. 发送消息给 Subscribe 端;
  6. Subscribe 端确认后 Backend 从数据库中移除该消息;

一对多消息存储

image

  1. Publish 端发布一条消息;
  2. Backend 将消息记录在数据库中;
  3. Subscribe1 和 Subscribe2 订阅主题;
  4. Backend 从数据库中获取该主题的消息;
  5. 发送消息给 Subscribe1 和 Subscribe2;
  6. Backend记录Subscribe1 和 Subscribe2 已读消息位置,下次获取消息从该位置开始。

客户端在线状态存储

EMQ X 存储支持将设备上下线状态,直接存储到Redis或数据库。

客户端代理订阅

EMQ X 存储支持代理订阅功能。设备客户端上线时,由存储模块直接从数据库,代理加载订阅主题。

存储插件列表

EMQ X 支持 MQTT 消息直接存储 Redis、MySQL、PostgreSQL、MongoDB、Cassandra、DynamoDB、InfluxDB、OpenTSDB 数据库:

存储插件配置文件说明
emqx_backend_redisemqx_backend_redis.confRedis 消息存储
emqx_backend_mysqlemqx_backend_mysql.confMySQL 消息存储
emqx_backend_pgsqlemqx_backend_pgsql.confPostgreSQL 消息存储
emqx_backend_mongoemqx_backend_mongo.confMongoDB 消息存储
emqx_backend_cassaemqx_backend_cassa.confCassandra 消息存储
emqx_backend_dynamoemqx_backend_dynamo.confDynamoDB 消息存储
emqx_backend_influxdbemqx_backend_influxdb.confInfluxDB 消息存储
emqx_backend_opentsdbemqx_backend_opentsdb.confOpenTSDB 消息存储