【实战分享】DTU设备高并发数据接入全流程(Redis + RabbitMQ + 数据库)🚀
今天,我们来聊聊一个典型物联网场景:多台DTU设备,每隔5秒发送JSON数据到服务器,如何设计一条高效、可扩展的数据处理链路。
一、项目场景概述 📊
-
设备规模:数千 ~ 上万台
-
数据上报频率:每5秒一次
-
数据格式:JSON
-
协议:HTTP/TCP
-
服务器语言:Java / Spring Boot
-
消息队列:RabbitMQ
-
核心需求:
- 高并发吞吐 ✅
- 数据不丢失、不重复 ✅
- 系统高可用、可横向扩展 ✅
如果直接把每个请求写入数据库,数据库很快就会成为瓶颈💥,因此我们需要一条高可用、削峰填谷、异步解耦的处理链路。
二、整体架构设计 🏗️
text
DTU设备
↓
Spring Boot接入服务(HTTP/TCP)
↓
Redis校验层(去重 + 合法性校验)
↓
RabbitMQ消息队列(削峰填谷)
↓
消费者服务(批量处理)
↓
数据库(MySQL / 时序数据库)
核心思想:
- 前置过滤:Redis拦截无效数据
- 异步解耦:消息队列削峰,保护数据库
- 批量入库:提升数据库写入效率
三、JSON数据示例 💡
DTU上报数据格式:
json
{
"deviceId": "DTU_10001",
"timestamp": 1710000000,
"temperature": 26.5,
"pm25": 35,
"status": "normal"
}
- 高频上报
- 数据量大
- 可能存在重复或异常数据
四、Spring Boot接入层设计 ⚡
使用 Spring Boot 接收 HTTP 请求,并快速将数据异步交给处理流程:
java
@RestController
@RequestMapping("/dtu")
public class DtuController {
@Autowired
private DtuService dtuService;
@PostMapping("/upload")
public ResponseEntity<String> upload(@RequestBody DtuData data) {
// 异步处理,立即返回
dtuService.handleData(data);
return ResponseEntity.ok("ok");
}
}
五、Redis校验层 🔥
Redis是系统第一道防线:
5.1 数据去重
java
String key = "dtu:" + data.getDeviceId() + ":" + (data.getTimestamp()/5);
Boolean isNew = redisTemplate.opsForValue().setIfAbsent(key, "1", 10, TimeUnit.SECONDS);
if (!isNew) {
return; // 重复数据,丢弃
}
5.2 设备合法性校验
java
Boolean exists = redisTemplate.hasKey("device:" + data.getDeviceId());
if (!exists) {
return; // 非法设备
}
5.3 在线状态维护(心跳)
java
redisTemplate.opsForValue().set("device:online:" + data.getDeviceId(), "1", 30, TimeUnit.SECONDS);
六、RabbitMQ消息队列 🎯
6.1 生产者发送
java
@Autowired
private RabbitTemplate rabbitTemplate;
public void sendToQueue(DtuData data) {
rabbitTemplate.convertAndSend("dtu_exchange", "dtu_routingKey", data);
}
💡 设计原则:
- 队列持久化
- 消息确认(ACK)
- 死信队列处理异常
6.2 消费者设计
java
@Component
@RabbitListener(queues = "dtu_queue")
public class DtuConsumer {
@Autowired
private DtuRepository repository;
private List<DtuData> batch = new ArrayList<>();
@RabbitHandler
public void receive(DtuData data) {
batch.add(data);
if (batch.size() >= 100) {
repository.saveAll(batch);
batch.clear();
}
}
}
- 异步批量处理
- 幂等性设计防止重复写入
七、数据库设计建议 🛠️
- MySQL + 分库分表
- 或时序数据库(InfluxDB / TimescaleDB)
- 索引建议:
(device_id, timestamp) - 冷热数据分离提升查询效率
八、全链路流程总结 🌈
text
1️⃣ DTU设备每5秒上报JSON数据
2️⃣ Spring Boot接收并解析
3️⃣ Redis进行去重和设备校验
4️⃣ 合法数据发送到RabbitMQ
5️⃣ 消费者批量处理
6️⃣ 数据入库
九、高可用与性能优化要点 ⚡
- Redis去重 → 避免重复写入
- RabbitMQ异步削峰 → 避免数据库压力
- 批量入库 → 提升吞吐
- 幂等性设计 → 防止重复消费
- 服务水平扩展 → 接入服务 + MQ + 数据库可横向扩展
🔟 总结 ✨
通过 Spring Boot + Redis + RabbitMQ + 数据库 的组合,我们实现了:
- 高并发DTU数据接入
- 数据不丢失、不重复
- 系统可扩展、高可用
这是一个典型的 高可用物联网数据接入解决方案,适合智慧环保、智慧城市、工业IoT等场景。
💡 小结:
- 前置过滤 → Redis
- 异步解耦 → RabbitMQ
- 批量处理 → 数据库
让高频DTU数据在千万QPS场景下也能平稳落地。🚀