场景介绍

今天程序猫带领大家如何实时获取树莓派传感器温湿度数据,并自动存储到数据库中。确保数据的持续性。

实现过程

硬件连接

树莓派4b连接GPIO引脚与DHT11传感器;
硬件只涉及树莓派、DHT11传感器。
DHT11的信号引脚连接树莓派的GPIO17, DHT11的Vdd(+)和GND引脚(-)分别连接树莓派的电源正极和GND引脚。
在这里插入图片描述

在这里插入图片描述

启动MQTT服务

终端启动Mosquitto服务

sudo systemctl start mosquitto

读取传感器数据存储数据库

在数据采集模块中添加数据库写入的逻辑,编写脚本代码sensor_save.py

import time
import board
import adafruit_dht
from datetime import datetime
import paho.mqtt.client as mqtt
import json
import sqlite3
from pathlib import Path# MQTT配置
broker = "192.168.137.31"
port = 1883
topic = "DHT11_message"# 传感器引脚配置
SENSOR_PIN = board.D17  # 使用CircuitPython标准命名(物理引脚11)# 数据库配置
DB_NAME = "sensor_data.db"
DB_TABLE = "environment_data"# 初始化数据库
def init_db():# 检查数据库文件是否存在,不存在则创建db_file = Path(DB_NAME)if not db_file.exists():conn = sqlite3.connect(DB_NAME)cursor = conn.cursor()cursor.execute(f"""CREATE TABLE {DB_TABLE} (id INTEGER PRIMARY KEY AUTOINCREMENT,timestamp TEXT NOT NULL,temperature REAL NOT NULL,humidity REAL NOT NULL)""")conn.commit()conn.close()print(f"数据库 {DB_NAME} 和表 {DB_TABLE} 创建成功")else:print(f"使用现有数据库 {DB_NAME}")# 写入数据到数据库
def write_to_db(timestamp, temperature, humidity):try:conn = sqlite3.connect(DB_NAME)cursor = conn.cursor()cursor.execute(f"""INSERT INTO {DB_TABLE} (timestamp, temperature, humidity)VALUES (?, ?, ?)""", (timestamp, temperature, humidity))conn.commit()conn.close()return Trueexcept sqlite3.Error as e:print(f"数据库写入错误: {e}")return False# 初始化MQTT客户端
client = mqtt.Client()
client.connect(broker, port)# 初始化数据库
init_db()try:# 添加 use_pulseio=False 参数dhtDevice = adafruit_dht.DHT11(SENSOR_PIN, use_pulseio=False)print("传感器初始化成功,开始数据采集......")while True:try:# 读取温湿度数据temperature = dhtDevice.temperaturehumidity = dhtDevice.humidity# 检查有效读数if temperature is None or humidity is None:raise RuntimeError("读取到无效值")# 获取当前时间戳recDate = datetime.now().strftime('%Y-%m-%d %H:%M:%S')# 1. 写入数据库if write_to_db(recDate, temperature, humidity):print(f"✓ [{recDate}] 数据库写入成功: 温度={temperature}°C, 湿度={humidity}%")else:print(f"✗ [{recDate}] 数据库写入失败")# 2. 准备MQTT消息并发送msg = json.dumps({'Tem': temperature,'Hum': humidity,'Date': recDate})result = client.publish(topic, msg)if result[0] == mqtt.MQTT_ERR_SUCCESS:print(f"✓ [{recDate}] MQTT发送成功: {msg}")else:print(f"✗ MQTT发送失败,错误码: {result[0]}")except RuntimeError as e:print(f"传感器读取错误: {e}")except Exception as e:print(f"意外错误: {e}")time.sleep(10.0)  # 采集间隔10sexcept KeyboardInterrupt:print("程序被用户终止")
except RuntimeError as e:print(f"初始化失败: {e}")exit(1)
finally:# 清理资源if 'dhtDevice' in locals():dhtDevice.exit()client.disconnect()print("资源已释放")

进入虚拟环境

树莓派终端输入命令:

source adafruit_env/bin/activate

运行脚本

python3  sensor_save.py

在这里插入图片描述
可以看到传感器数据采集写入数据库

安装DB Browser for SQLite‌工具

适用于Raspbian/Debian系统:
控制台输入命令:

sudo apt install sqlitebrowser

打开可视化工具,并打开sensor_data.db,查看表数据environment_data写入成功。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/92137.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/92137.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/92137.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux DNS缓存与Nginx DNS缓存运维文档

一、Linux DNS缓存机制与配置 1. Linux DNS缓存原理 Linux系统中的DNS缓存主要通过以下几种方式实现: ​** nscd(Name Service Caching Daemon)**​:系统级缓存服务,可缓存DNS解析、主机名解析等信息​dnsmasq​:轻量级DNS转发器和…

Java开发时出现的问题---并发与资源管理深层问题

Java 并发模型基于 JVM 内存模型(JMM),资源管理涉及 IO、线程、锁等关键组件。若对并发语义、资源生命周期理解不透彻,易引发死锁、内存泄漏、数据错乱等严重问题。1. 并发三大特性(可见性、原子性、有序性&#xff09…

从「同步」到「异步」:用 aiohttp 把 Python 网络 I/O 榨到极致

目录 一、写在前面:为什么 IO 是瓶颈 二、同步模型:requests 的忧伤 三、线程池:用并发掩盖阻塞 四、aiohttp:让「等待」非阻塞 4.1 安装与版本约定 4.2 异步客户端:asyncio aiohttp 4.3 错误处理与超时 4.4 …

MySQL 在麒麟系统上部署使用 + DBeaver 远程连接 + SQL 数据导入完整流程

🚀 MySQL 在麒麟系统上部署使用 DBeaver 远程连接 SQL 数据导入完整流程适用于国产操作系统(如:麒麟 / 统信 / Ubuntu)和 MySQL 8.0。包含远程配置、授权连接、SQL 导入、DBeaver连接配置等常见问题解决方案。📦 环境…

C语言-指针初级(指针定义、指针的作用、指针的计算、野指针、悬空指针、void类型指针)

本章概述思维导图:C语言指针指针是C语言中最强大但也最容易混淆的特性之一。它提供了直接操作内存地址的能力,使得C语言具有高效性和灵活性。下面我将详细介绍C语言指针的各个方面。指针定义指针的本质:指针是一个变量,其值为另一…

具身智能VLA困于“数据泥潭”,人类活动视频数据是否是“破局之钥”?

前言尽管当前的视觉-语言-动作(VLA)模型已展现出显著进展,但其在新场景和与复杂物体交互中的性能会显著下降,在遵循指令方面落后于像LLaVA 这样的大型多模态模型(LMM)。这种局限性源于现有VLA模型对存在固有…

CIO如何规划企业BI分析指标体系 —— 从经营出发到绩效管理

如果你是一家企业的CIO,要启动一个商业智能BI项目,负责规划整个项目的商业智能BI分析内容,你该如何入手准备?要有什么样的思路。如果是管理层、老板还不能清晰认识到商业智能BI的价值,也提不出很清晰的需求&#xff0c…

go学习笔记:panic是什么含义

anic 是 Go 语言中的一种运行时错误处理机制,用于处理程序中的异常情况。 基本含义 panic 会: 立即停止当前函数的执行 开始执行 defer 函数(如果有的话) 向上传播到调用栈,逐层执行 defer 如果到达 main 函数&am…

OpenLayers 入门指南【五】:Map 容器

文章目录 一、Map 对象核心参数 1. target 2. view 3. layers 4. controls 5. interactions 6. 其他重要参数 二、Map 对象常用方法 1. 图层管理 2. 控件管理 3. 交互管理 4. 视图与坐标操作 5. 事件监听 6. 覆盖物管理 7. 其他 三、总结 上一章节中我们通过修改OlMap.vue组件已…

关税战火中的技术方舟:新西兰证券交易所的破局之道 ——从15%关税冲击到跨塔斯曼结算联盟,解码下一代交易基础设施

一、今日焦点:全球关税震荡与新西兰的“技术自卫” 1. 特朗普关税大限落地,新西兰启动紧急游说 2025年8月1日,美国总统特朗普正式签署行政令,对贸易顺差国征收最低15%基准关税。新西兰贸易部长紧急声明:“将提出有力证…

windows内核研究(软件调试-软件断点)

软件调试软件断点调试的本质是什么?就是在被调试程序中触发异常,然后被调试程序就会向_DEBUG_OBJECT结构体添加调试事件,这里我们调试器就接管这个异常了(调试的过程就是异常处理的过程) 软件断点 在x64dbg中通过快捷键…

HarmonyOS】鸿蒙应用开发中常用的三方库介绍和使用示例

🌟 鸿蒙应用开发常用三方库指南(2025 最新版)适用版本:HarmonyOS NEXT / API 12 参考来源:HarmonyOS 三方库中心 截止至 2025 年 8 月 1 日,本文整理了当前社区中下载量高、稳定性强、生态完善的热门三方库…

【通识】C Sharp

1. 使用 \p{名称}构造匹配Unicode常规类别(该示例为Pd或“标点、短划线”类别)和命名块(IsGreek和IsBsicLatin命名块) using System; using system.Text.RegularExpressions; public class Example {public static void main() {s…

国内首个开源SCA社区——OpenSCA开源社区

OpenSCA开源社区成果说明项目背景智能时代,软件定义一切。随着开发模式的敏捷化转型,开源代码在软件制品中的占比越来越大,开源软件已然成为软件供应链的重要组成部分。由于其特殊性,开源代码的引入增加了软件应用的风险面&#x…

超聚变:智能体时代,AI原生重构城企数智化基因

2025 世界人工智能大会(WAIC)世博展览馆内,超聚变展台前人头攒动,其展示的AI落地全栈解决方案及上百个AI应用场景吸引了众多参观者驻足观看。这是今年WAIC大会火爆的一角,更是当下AI应用爆发的一个缩影。当人工智能发展…

Traccar:开源GPS追踪系统的核心价值与技术全景

Traccar:开源GPS追踪系统的核心价值与技术全景 —— 从设备兼容到企业级定位管理的开源实践 一、项目定位:多场景定位管理的开源基石 Traccar是一个高扩展性的开源GPS追踪平台,支持全球超过200种通信协议与2000款GPS设备(包括车…

编程与数学 03-002 计算机网络 20_计算机网络课程实验与实践

编程与数学 03-002 计算机网络 20_计算机网络课程实验与实践一、实验环境搭建(一)使用模拟器(如Cisco Packet Tracer)搭建网络实验环境(二)实验设备的配置与连接二、基础网络实验(一&#xff09…

15个命令上手Linux!

1、id,显示当前登录系统的用户信息2、pwd,显示当前工作目录的绝对路径3、ls,显示当前目录下的内容(ls -r:按反向顺序列出内容,ls -l:以详细列表形式显示)4、cd,切换工作目…

MongoDB分片技术实现

MongoDB分片技术实现概述MongoDB分片(Sharding)是MongoDB的水平扩展解决方案,通过将数据分布到多个分片(shard)上来处理大数据量和高吞吐量的需求。MongoDB分片架构1. 分片集群组件# MongoDB分片集群架构 version: 3.8…

Python开发环境PyCharm下载与安装

python下载 python下载地址: Download Python | Python.org 上面的下载速度慢的话,用下面的地址下载(window): https://download.csdn.net/download/liangmengbk/91580033 PyCharm下载 PyCharm下载地址&#xff1a…