
本文介绍从零开始搭建轻量级服务器,接收 arduino 通过 http 或 mqtt 上报的传感器数据,并将其持久化至 sqlite 数据库,供 java 应用实时读取与分析的完整实践路径。
构建一个可靠的数据通道,将 Arduino 采集的温湿度、光照、加速度等传感器数据上传至服务器,并被 Java 后端应用安全、高效地消费,是物联网项目中的典型需求。整个链路可分为三部分:Arduino 端数据上报 → 服务端接收与存储 → Java 应用查询使用。以下为可落地的技术方案:
一、服务端选型与部署(低成本起步)
你已注册域名(如 yourdomain.com),接下来需一台可公网访问的服务器。推荐选择:
- 入门级云服务器:DigitalOcean Droplet($5/月,1GB RAM)、AWS EC2 t2.micro(免费层12个月)或 Google Cloud e2-micro(始终免费);
- 操作系统:Ubuntu 22.04 LTS(稳定、社区支持强);
- 基础服务栈:Nginx(反向代理 + HTTPS 终结) + Flask/FastAPI(Python 轻量 Web 框架) + SQLite3(嵌入式数据库,零配置、适合中小吞吐)。
✅ 示例:在 Ubuntu 上快速启动一个接收端(使用 Flask): # server.py from flask import Flask, request, jsonify import sqlite3 import time
app = Flask(name)
def init_db(): conn = sqlite3.connect('sensors.db') conn.execute('''CREATE TABLE IF NOT EXISTS readings ( id INTEGER PRIMARY KEY AUTOINCREMENT, device_id TEXT NOT NULL, temperature REAL, humidity REAL, timestamp DATETIME DEFAULT CURRENT_TIMESTAMP )''') conn.commit() conn.close()
@app.route('/api/sensor', methods=['POST']) def receive_sensor(): try: data = request.get_json() conn = sqlite3.connect('sensors.db') conn.execute( "INSERT INTO readings (device_id, temperature, humidity) VALUES (?, ?, ?)", (data['device_id'], data['temp'], data['humi']) ) conn.commit() conn.close() return jsonify({"status": "success"}), 200 except Exception as e: return jsonify({"error": str(e)}), 400
if name == 'main': init_db() app.run(host='0.0.0.0:5000') # 生产环境请用 Gunicorn + Nginx
运行后,Arduino 可通过 HTTP POST 发送 JSON 数据:
```cpp
// Arduino ESP32 示例(使用 WiFiClientSecure)
const char* server = "yourdomain.com";
http.begin(client, "https://" + String(server) + "/api/sensor");
http.addHeader("Content-Type", "application/json");
String json = "{\"device_id\":\"esp32-01\",\"temp\":24.5,\"humi\":62.3}";
int httpCode = http.POST(json);二、通信协议选型建议
- HTTP(S) GET/POST:简单直接,适合低频(≤1次/秒)、单向上报;需注意 HTTPS 证书(用 Certbot 免费申请 Let's Encrypt 证书);
- MQTT(推荐进阶):若需双向交互(如远程校准、开关控制),选用 Mosquitto 服务器 + Arduino PubSubClient 库,Java 端用 Eclipse Paho 客户端订阅主题,实时性更高、资源占用更低。
三、Java 应用对接 SQLite
Java 侧无需额外服务,直接通过 JDBC 访问同步到本地或远程 SQLite 文件(注意:SQLite 不支持多进程高并发写入,生产中建议服务端提供 REST API 供 Java 调用):
立即学习“Java免费学习笔记(深入)”;
// Java 查询示例(使用 sqlite-jdbc)
String url = "jdbc:sqlite:sensors.db";
try (Connection conn = DriverManager.getConnection(url);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM readings ORDER BY timestamp DESC LIMIT 10")) {
while (rs.next()) {
System.out.printf("Device: %s | Temp: %.1f°C | Time: %s%n",
rs.getString("device_id"),
rs.getDouble("temperature"),
rs.getString("timestamp"));
}
}注意事项
- ? 域名需在云服务器上配置 A 记录指向公网 IP,并启用 HTTPS(Nginx + Certbot);
- ? 避免 Arduino 直连 SQLite(驱动缺失、文件锁问题),务必通过服务端中间层收发;
- ? 单机 SQLite 在日均万级写入下仍表现良好;超量建议平滑迁移至 PostgreSQL;
- ? 开发阶段可用 ngrok http 5000 快速暴露本地服务测试 Arduino 连接。
整套方案兼顾成本、可控性与可扩展性——从 GoDaddy 域名出发,仅需 1 小时即可完成端到端验证。后续可按需加入用户认证、数据可视化(如 Grafana)、告警推送等功能。










