【物聯網】基于樹莓派的物聯網開發【22】——樹莓派獲取傳感器數據實時存儲實戰

場景介紹

今天程序貓帶領大家如何實時獲取樹莓派傳感器溫濕度數據,并自動存儲到數據庫中。確保數據的持續性。

實現過程

硬件連接

樹莓派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…