विषयसूची:
- आपूर्ति
- चरण 1: Arduino कोड को ESP32-CAM. पर अपलोड करें
- चरण 2: तार ऊपर
- चरण 3: Python3 स्क्रिप्ट
- चरण 4: MySQL सर्वर
- चरण 5: वेबसर्वर
- चरण 6: 3डी प्रिंटेड हाउसिंग
- चरण 7: अंतिम परिणाम
वीडियो: ESP32-DHT22-MQTT-MySQL-PHP का उपयोग कर तापमान और आर्द्रता: 7 कदम
2024 लेखक: John Day | [email protected]. अंतिम बार संशोधित: 2024-01-30 09:20
मेरी प्रेमिका को कांच का घर चाहिए था, इसलिए मैंने उसे बना दिया। लेकिन मुझे ग्लासहाउस के अंदर एक तापमान और आर्द्रता सेंसर चाहिए था। इसलिए, मैंने उदाहरणों के लिए गुगल किया और प्रयोग करना शुरू कर दिया।
मेरा निष्कर्ष यह था कि मुझे जो भी उदाहरण मिले, वे ठीक वैसे नहीं थे जैसा मैं बनाना चाहता था। मैंने कोड के बहुत से छोटे हिस्सों को पकड़ा और उन्हें जोड़ दिया। मुझे अपना पहला वर्किंग बिल्ड पूरा करने में काफी समय लगा क्योंकि अधिकांश उदाहरणों के दस्तावेज़ीकरण को समझना मेरे लिए बहुत मुश्किल था या उन्होंने ऐसा हिस्सा मान लिया जो मुझे पता होना चाहिए ?? लेकिन मुझे कुछ नहीं पता था (अभी तक)
इसलिए मैं इस निर्देश का निर्माण करता हूं। शाब्दिक रूप से सभी को समझने के लिए एक "शुरुआत-अंत तक" ट्यूटोरियल। (कम से कम मुझे आशा है?)
यह काम किस प्रकार करता है …
अंतिम उत्पाद एक ESP32-CAM है जिसमें एक DHT22 सेंसर जुड़ा हुआ है जो इसे 18650 बैटरी से शक्ति प्राप्त करता है। हर तीन मिनट में यह तापमान और आर्द्रता को पढ़ता है और इसे वाईफाई पर बाहरी एमक्यूटीटी सर्वर पर भेजता है और फिर आवश्यकतानुसार कम बैटरी का उपयोग करने के लिए सो जाता है (तीन मिनट के लिए)।
एक डेबियन सर्वर पर, (जो मुझे लगता है कि एक रास्पबेरी पाई भी हो सकता है) मेरे पास python3, एक MQTT सर्वर, एक MySQL सर्वर और एक वेबसर्वर है।
पायथन 3 स्क्रिप्ट एक सेवा के रूप में चलती है और जब भी इसे एमक्यूटीटी संदेश प्राप्त होता है, तो यह पिछली प्रविष्टियों (इंडेक्स नंबर) की गणना करता है और इसे एक से बढ़ाता है। फिर यह MQTT संदेश से तापमान और आर्द्रता के मूल्यों को पढ़ता है। यह झूठे मानों की जांच करता है और जब भी मान सही होते हैं, तो यह मूल्यों को नए इंडेक्स नंबर और वर्तमान दिनांक और समय के साथ एक MySQL सर्वर पर भेजता है।
वेबसर्वर के पास एक PHP स्क्रिप्ट है जो MySQL सर्वर से मानों को पढ़ती है और Google चार्ट का उपयोग करके इससे एक अच्छा ग्राफ बनाती है। (उदाहरण)
आपूर्ति
मेरे द्वारा उपयोग किए जाने वाले भाग निम्नलिखित हैं:
- ESP32-CAM (इसका कारण मैंने कैम संस्करण का उपयोग किया है क्योंकि इसमें एक बाहरी एंटीना कनेक्टर है। संभवतः अन्य ESP32 भी हैं जिनका आप उपयोग कर सकते हैं)
- बाहरी एंटीना
-
AM2302 DHT22 सेंसर (इसमें एक अंतर्निर्मित अवरोधक है, इसलिए आपको केवल तीन तारों की आवश्यकता है)
https://www.amazon.de/gp/product/B07CM2VLBK/ref=p…
- १८६५० बैटरी शील्ड v3
- 18650 बैटरी (NCR18650B)
- पुराना माइक्रो USB केबल (ESP32 को बैटरी शील्ड से जोड़ने के लिए)
- कुछ छोटे जम्पर तार
अतिरिक्त आवश्यकता:
-
यूएसबी से टीटीएल कनेक्टर (चित्र)
https://www.amazon.de/FT232RL-Seriell-Unterst%C3%…
- सोल्डरिंग आयरन
- 3D प्रिंटर (केवल हाउसिंग केस के लिए आवश्यक)
चरण 1: Arduino कोड को ESP32-CAM. पर अपलोड करें
तो चलिए शुरू करते हैं!
Arduino कोड को ESP32-CAM में अपलोड करने के लिए, आपको ऊपर दिए गए स्कीमैटिक्स का उपयोग करके USBtoTTL कनेक्टर को ESP32 से कनेक्ट करना होगा।
Arduino कोड है:
/* DHT22 सेंसर से तापमान और आर्द्रता को पढ़ने के लिए बस एक छोटा सा कार्यक्रम और
इसे एमक्यूटीटी को पास करें। बी. डुइजनहौवर जून, ८, २०२० */ #include #include #include #define wifi_ssid "****WIFI_SSID***" //wifi ssid #define wifi_password "****WIFI_PASSWORD***" //wifi पासवर्ड #define mqtt_server "***SERVER_NAME***" // सर्वर का नाम या IP #define mqtt_user "****MQTT_USER***" // यूजरनेम #define mqtt_password "***MQTT_PASSWORD***" // पासवर्ड #डिफाइन टॉपिक "ग्लासहाउस" /dhtreadings" #define debug_topic "ग्लासहाउस/डीबग" // डिबगिंग के लिए विषय /* डीपस्लीप के लिए परिभाषाएं */ #डिफाइन uS_TO_S_FACTOR 1000000 /* माइक्रो सेकेंड से सेकेंड के लिए कन्वर्जन फैक्टर */ #define TIME_TO_SLEEP 180 /* Time ESP32 सो जाएगा 5 मिनट के लिए (सेकंड में) */ बूल डिबग = सच; // लॉग संदेश प्रदर्शित करें यदि सही है #DHT22_PIN 14 dht DHT को परिभाषित करें; वाईफाई क्लाइंट एस्प क्लाइंट; PubSubClient क्लाइंट (espClient); चार डेटा [८०]; शून्य सेटअप () {Serial.begin(११५२००); setup_wifi (); // वाईफाई नेटवर्क क्लाइंट से कनेक्ट करें। सेटसेवर (mqtt_server, 1883); // MQTT कनेक्शन कॉन्फ़िगर करें, यदि आवश्यक हो तो पोर्ट बदलें। अगर (! क्लाइंट। कनेक्टेड ()) {फिर से कनेक्ट करें (); } // डेटा पढ़ें int chk = DHT.read22 (DHT22_PIN); फ्लोट टी = डीएचटी। तापमान; फ्लोट एच = डीएचटी। आर्द्रता; स्ट्रिंग dhtReadings = "{"तापमान\":\"" + स्ट्रिंग (टी) + "\", \"आर्द्रता\":\"" + स्ट्रिंग (एच) + "\"}"; dhtReadings.toCharArray (डेटा, (dhtReadings.length () + 1)); अगर (डीबग) { सीरियल.प्रिंट ("तापमान:"); सीरियल.प्रिंट (टी); सीरियल.प्रिंट ("| आर्द्रता:"); सीरियल.प्रिंट्लन (एच); } // MQTT विषयों क्लाइंट के लिए मान प्रकाशित करें। प्रकाशित करें (विषय, डेटा); // विषय पर रीडिंग प्रकाशित करें (ग्लासहाउस / dhtreadings) अगर (डीबग) {Serial.println ("एमक्यूटीटी को रीडिंग भेजी गई।"); } esp_sleep_enable_timer_wakeup (TIME_TO_SLEEP * uS_TO_S_FACTOR); // सो जाओ Serial.println ("सेटअप ESP32 प्रत्येक के लिए सोने के लिए" + स्ट्रिंग (TIME_TO_SLEEP) + "सेकंड"); Serial.println ("अब सामान्य रूप से सोने जा रहे हैं।"); esp_deep_sleep_start (); } // वाईफाई शून्य से सेटअप कनेक्शन setup_wifi () {देरी (20); सीरियल.प्रिंट्लन (); Serial.print ("कनेक्ट कर रहा है"); Serial.println (wifi_ssid); वाईफाई.बेगिन (वाईफाई_एसएसआईडी, वाईफाई_पासवर्ड); जबकि (WiFi.status() != WL_CONNECTED) {देरी (100); सीरियल.प्रिंट ("।"); } सीरियल.प्रिंट्लन (""); Serial.println ("वाईफाई ठीक है"); Serial.print ("=> ESP32 नया IP पता है:"); सीरियल.प्रिंट (वाईफाई.लोकलआईपी ()); सीरियल.प्रिंट्लन (""); } // अगर कनेक्शन खो गया है तो वाईफाई से फिर से कनेक्ट करें शून्य फिर से कनेक्ट करें () {जबकि (! क्लाइंट। कनेक्टेड ()) {सीरियल.प्रिंट ("एमक्यूटीटी ब्रोकर से कनेक्ट हो रहा है …"); if (client.connect("ESP32Client", mqtt_user, mqtt_password)) { Serial.println ("OK"); } और { सीरियल.प्रिंट ("[त्रुटि] कनेक्ट नहीं है:"); सीरियल.प्रिंट (क्लाइंट.स्टेट ()); Serial.println ("पुन: प्रयास करने से पहले 5 सेकंड प्रतीक्षा करें।"); देरी (5000); } } } शून्य लूप () { }
और फिर, क्रेडेंशियल्स को अपने क्रेडेंशियल्स से बदलना न भूलें
चरण 2: तार ऊपर
बिजली के लिए, मैंने एक पुराने यूएसबी केबल का इस्तेमाल किया, जिसमें से मैंने यूएसबी-ए कनेक्टर को काट दिया। यूएसबी केबल में चार तार होते हैं, हमें केवल काले और लाल तार चाहिए।
तो, ऊपर दिए गए शेड्यूल के अनुसार सब कुछ कनेक्ट करें।
चरण 3: Python3 स्क्रिप्ट
Python3 स्क्रिप्ट उस स्थान पर जाती है जहाँ यह रूट उपयोगकर्ता के लिए सुलभ है।
मैंने इस स्क्रिप्ट के लिए /root/scripts/glasshouse/glasshouse.py का उपयोग किया। पायथन लिपि की सामग्री है:
# Python3 स्क्रिप्ट MQTT से कनेक्ट करने के लिए, मान पढ़ें और उन्हें MySQL में लिखें
# # बी डुइजनहौवर # जून, 8 वीं 2020 # # संस्करण: 1.0 # # आयात paho.mqtt.client के रूप में mqtt आयात json आयात pymysql pymysql.install_as_MySQLdb () डेटाटाइम आयात डेटाटाइम से MySQLdb आयात करें db= MySQLdb.connect("localhost", "ग्लासहाउस", "***MYSQL_USERNAME***", "***MYSQL_PASSWORD***") कर्सर = db.cursor () ब्रोकर_एड्रेस = "लोकलहोस्ट" # ब्रोकर एड्रेस पोर्ट = 1883 # ब्रोकर पोर्ट यूजर = "** *MQTT_USERNAME***" #कनेक्शन यूजरनेम पासवर्ड = "***MQTT_PASSWORD***" #कनेक्शन पासवर्ड def on_connect (क्लाइंट, यूजरडेटा, फ्लैग, आरसी): # क्लाइंट ब्रोकर प्रिंट से कनेक्ट होने पर कॉलबैक ("कनेक्टेड" परिणाम कोड के साथ {0}.format(str(rc))) # कनेक्शन प्रयास क्लाइंट का प्रिंट परिणाम। सर्वर से प्रकाशित संदेश प्राप्त होता है। कर्सर.निष्पादन ("सेंसरडेटा से * चुनें") अंक = इंट (कर्सर.रोकाउंट) न्यूरो = अंक + 1 अब = डेटाटाइम। अब () formatted_date = now.strftime('%Y-%m-%d %H:% M:%S') पेलोड = json.loads(msg.payload.decode('utf-8')) प्रिंट ("नई पंक्ति:"+str(newrow)) तापमान = फ्लोट (पेलोड ["तापमान"]) आर्द्रता = फ्लोट (पेलोड ["आर्द्रता"]) प्रिंट ("तापमान:" + str (तापमान)) प्रिंट ("आर्द्रता:" + str (आर्द्रता)) प्रिंट ("दिनांक समय:" + str (formatted_date)) अगर ((तापमान) > -20) और (तापमान = 0) और (आर्द्रता <= 100)): cur = db.cursor() cur.execute("INSERT INTO Glasshouse.sensordata (idx, तापमान, आर्द्रता, टाइमस्टैम्प) VALUES ("+str" (newrow)+", "+str(temperature)+", "+str(humidity)+", %s)", (formatted_date)) db.commit () प्रिंट ("डेटा प्राप्त और MySQL में आयात किया गया") अन्य: प्रिंट ("डेटा सीमा से अधिक है और MySQL में आयात नहीं किया गया है") क्लाइंट = mqtt. Client ("duijnhouwer-com-ग्लासहाउस-स्क्रिप्ट") क्लाइंट.username_pw_set (उपयोगकर्ता, पासवर्ड = पासवर्ड) क्लाइंट। on_connect = on_connect # कॉलबैक फ़ंक्शन को परिभाषित करें के लिये सफल कनेक्शन client.on_message = on_message # संदेश प्राप्त करने के लिए कॉलबैक फ़ंक्शन को परिभाषित करें क्लाइंट। कनेक्ट (ब्रोकर_एड्रेस, पोर्ट = पोर्ट) # ब्रोकर क्लाइंट से कनेक्ट करें। लूप_फॉरएवर () # नेटवर्किंग डेमॉन शुरू करें
MySQL यूज़रनेम और पासवर्ड और MQTT यूज़रनेम और पासवर्ड को अपने क्रेडेंशियल में बदलना न भूलें
आप दो फाइलें बनाकर स्क्रिप्ट को एक सेवा के रूप में चला सकते हैं।
निम्नलिखित सामग्री के साथ पहला "/etc/init/glasshouse.conf" है:
रनलेवल पर शुरू करें [2345]
रनलेवल पर रुकें [!2345] निष्पादन /रूट/स्क्रिप्ट/ग्लासहाउस/ग्लासहाउस.py
दूसरा निम्नलिखित सामग्री के साथ "/etc/systemd/system/multi-user.target.wants/glasshouse.service" है:
[इकाई]
विवरण=ग्लासहाउस निगरानी सेवा के बाद=multi-user.target [सेवा] प्रकार=सरल पुनरारंभ=हमेशा पुनरारंभ करेंसेक=1 ExecStart=/usr/bin/python3 /root/scripts/glasshouse/glasshouse.py [इंस्टॉल करें] वांटेडबाय=मल्टी-यूजर.लक्ष्य
आप निम्न आदेश का उपयोग करके इसे सेवा के रूप में चला सकते हैं:
systemctl ग्लासहाउस सक्षम करें
और इसका उपयोग शुरू करें:
systemctl ग्लासहाउस शुरू करें
चरण 4: MySQL सर्वर
आपको इसमें सिर्फ एक टेबल के साथ एक नया MySQL डेटाबेस बनाना है।
तालिका बनाने के लिए कोड है:
तालिका बनाएं `सेंसरडेटा` (`idx` int(११) डिफॉल्ट न्यूल, `तापमान` फ्लोट डिफॉल्ट न्यूल, `आर्द्रता` फ्लोट डिफॉल्ट न्यूल, `टाइमस्टैम्प` डेटाटाइम डिफॉल्ट न्यूल) इंजन = इनो डीबी डिफॉल्ट चार्ट = utf8;
चरण 5: वेबसर्वर
वेबसर्वर में दो फ़ाइलें होती हैं, index.php फ़ाइल और एक config.ini फ़ाइल
config.ini फ़ाइल की सामग्री है:
[डेटाबेस]
db_host = "लोकलहोस्ट" db_name = "ग्लासहाउस" db_table = "सेंसरडेटा" db_user = "***DATABASE_USER***" db_password = "***DATABASE_PASSWORD ***"
जहां ऑफकोर्स आप ***DATABASE_USER*** और ***DATABASE_PASSWORD*** को अपने स्वयं के क्रेडेंशियल से प्रतिस्थापित करते हैं।
google.charts.load('current', {'packages':['corechart']}); google.charts.setOnLoadCallback(drawChart); फ़ंक्शन ड्रॉचार्ट () { var डेटा = google.visualization.arrayToDataTable ([// ['टाइमस्टैम्प', 'तापमान', 'आर्द्रता', 'हीट इंडेक्स'], ['टाइमस्टैम्प', 'तापमान', 'आर्द्रता'], query($sql); # इस समय - लूप प्रारूप और सभी पुनर्प्राप्त डेटा को ['टाइमस्टैम्प', 'तापमान', 'आर्द्रता'] रास्ते में डाल दें। जबकि ($row = $result->fetch_assoc()) { $timestamp_rest = सबस्ट्र ($ पंक्ति ["टाइमस्टैम्प"], 10, 6); गूंज "['"। $ टाइमस्टैम्प_रेस्ट।"', "। $ पंक्ति ['तापमान']।", "। $ पंक्ति ['आर्द्रता']। "], "; // गूंज "['".$timestamp_rest।"', ".$row['temperature'].", ".$row['humidity'].", ".$row['heatindex ']।"], "; } ?>]); // घुमावदार रेखा var विकल्प = {शीर्षक: 'तापमान और आर्द्रता', वक्र प्रकार: 'फ़ंक्शन', किंवदंती: {स्थिति: 'नीचे'}, hAxis: {slantedText: true, slantedTextAngle: 45}}; // घुमावदार चार्ट वर चार्ट = नया google.visualization. LineChart (दस्तावेज़.getElementById ('वक्र_चार्ट')); चार्ट। ड्रा (डेटा, विकल्प); } // ड्रॉचार्ट से अंत ब्रैकेट //
चरण 6: 3डी प्रिंटेड हाउसिंग
आवास के लिए, मैंने दो अलग-अलग आवासों का उपयोग किया, एक ESP32-CAM और DHT22 के लिए एक साथ और एक 18650 बैटरी शील्ड के लिए।
चरण 7: अंतिम परिणाम
अंतिम परिणाम ऊपर की तस्वीरों में भी दिखाया गया है।
और जब भी बैटरी खाली हो, आप इसे मिनी यूएसबी केबल से चार्ज कर सकते हैं।
सिफारिश की:
M5STACK Visuino का उपयोग करके M5StickC ESP32 पर तापमान, आर्द्रता और दबाव कैसे प्रदर्शित करें - करने में आसान: 6 कदम
M5STACK Visuino का उपयोग करके M5StickC ESP32 पर तापमान, आर्द्रता और दबाव कैसे प्रदर्शित करें - करने में आसान: इस ट्यूटोरियल में हम सीखेंगे कि ESP32 M5Stack StickC को Arduino IDE और Visuino के साथ कैसे प्रोग्राम करें ताकि ENV सेंसर (DHT12) का उपयोग करके तापमान, आर्द्रता और दबाव प्रदर्शित किया जा सके। बीएमपी२८०, बीएमएम१५०)
AWS और ESP32 का उपयोग करके तापमान और आर्द्रता चेतावनी: 11 कदम
AWS और ESP32 का उपयोग करके तापमान और आर्द्रता चेतावनी: इस ट्यूटोरियल में, हम तापमान और आर्द्रता सेंसर का उपयोग करके विभिन्न तापमान और आर्द्रता डेटा को मापेंगे। आप यह भी सीखेंगे कि इस डेटा को AWS को कैसे भेजा जाए
स्थानीय वेबसर्वर पर DHT11 का उपयोग करते हुए ESP8266 Nodemcu तापमान निगरानी - अपने ब्राउज़र पर कमरे का तापमान और आर्द्रता प्राप्त करें: 6 कदम
स्थानीय वेबसर्वर पर DHT11 का उपयोग करते हुए ESP8266 Nodemcu तापमान निगरानी | अपने ब्राउज़र पर कमरे का तापमान और आर्द्रता प्राप्त करें: नमस्कार दोस्तों आज हम एक नमी और amp; ESP ८२६६ NODEMCU का उपयोग कर तापमान निगरानी प्रणाली & DHT11 तापमान सेंसर। तापमान और आर्द्रता DHT11 सेंसर & यह एक ब्राउज़र पर देखा जा सकता है कि कौन सा वेबपेज प्रबंधित होगा
DT11 तापमान सेंसर के साथ वेब सर्वर के लिए ESP8266 NodeMCU एक्सेस प्वाइंट (AP) और ब्राउज़र में प्रिंटिंग तापमान और आर्द्रता: 5 कदम
DT11 तापमान सेंसर और ब्राउज़र में मुद्रण तापमान और आर्द्रता के साथ वेब सर्वर के लिए ESP8266 NodeMCU एक्सेस प्वाइंट (AP) ESP8266 द्वारा होस्ट किए गए वेबसर्वर तक पहुंचकर वाईफाई पर कोई भी उपकरण लेकिन एकमात्र समस्या यह है कि हमें एक काम करने वाले राउटर की आवश्यकता है
Arduino के साथ DHT11 तापमान सेंसर का उपयोग कैसे करें और तापमान गर्मी और आर्द्रता प्रिंट करें: 5 कदम
Arduino और प्रिंट तापमान गर्मी और आर्द्रता के साथ DHT11 तापमान सेंसर का उपयोग कैसे करें: DHT11 सेंसर का उपयोग तापमान और आर्द्रता को मापने के लिए किया जाता है। वे बहुत लोकप्रिय इलेक्ट्रॉनिक्स शौक़ीन हैं। DHT11 आर्द्रता और तापमान सेंसर आपके DIY इलेक्ट्रॉनिक्स परियोजनाओं में आर्द्रता और तापमान डेटा जोड़ना वास्तव में आसान बनाता है। यह प्रति