Πίνακας περιεχομένων:
2025 Συγγραφέας: John Day | [email protected]. Τελευταία τροποποίηση: 2025-01-23 14:39
Εισαγωγή
Το μπάρμπεκιου αναφέρεται συνήθως στην αργή διαδικασία χρήσης έμμεσης θερμότητας για να μαγειρέψετε τα αγαπημένα σας κρέατα. Αν και αυτή η μέθοδος μαγειρέματος είναι εξαιρετικά δημοφιλής-ειδικά στις ΗΠΑ-έχει ό, τι μερικοί μπορεί να θεωρήσουν ως μια αρκετά σοβαρή αδυναμία: απαιτεί ώρες ημι-διαυγούς προσοχής για να παρακολουθήσετε τη θερμοκρασία του λάκκου και του φαγητού σας. Εισαγάγετε: Raspberry Pi.
Το Πρωτότυπο Έργο
Η αρχική πηγή για αυτό το έργο μπορεί να βρεθεί εδώ: https://old.reddit.com/r/raspberry_pi/comments/a0… Η ουσία είναι ότι ο χρήστης reddit Produkt μπόρεσε να μεταδώσει δεδομένα θερμοκρασίας τροφίμων και λάκκων από σχετικά φθηνά, διατίθενται στο εμπόριο ασύρματα θερμόμετρα σε ένα Raspberry Pi (το οποίο είχε προσαρτήσει στις καρφίτσες GPIO του μια μικρή μονάδα RF). Στο αρχικό έργο (που συνδέεται παραπάνω), ο Produkt είχε τα δεδομένα του αποθηκευμένα σε μια βάση δεδομένων sqlite και εμφανιζόταν σε έναν τοπικά φιλοξενούμενο ιστότοπο apache2 php.
Αυτή η λύση λύνει ήδη το αρχικό πρόβλημα που αναφέρθηκε στην εισαγωγή αυτού του ιστολογίου: μπορείτε τώρα να παρακολουθείτε τη θερμοκρασία των τροφίμων και των λακκοειδών σας από απόσταση με ένα πρόγραμμα περιήγησης ιστού. Τι γίνεται όμως αν θέλουμε να επεκταθούμε σε αυτό; Εισαγάγετε: GridDB.
Προμήθειες
Raspberry Pi4
Μονάδα ασύρματου δέκτη SUNKEE 433Mhz Superheterodyne
Βήμα 1: GridDB Web API & FluentD
Μόλις είδα αυτό το έργο, η πρώτη μου σκέψη - μετά το αρχικό κύμα ενθουσιασμού - ήταν να σκεφτώ τρόπους για να επεκτείνω τη λειτουργικότητα. Χρησιμοποιώντας το GridDB και το πρόσθετο Grafana, προσπάθησα να οπτικοποιήσω τα δεδομένα των τροφίμων και των pit μου. Από εκεί και πέρα, ήθελα να δημιουργήσω σχολιασμούς Grafana για να αναζητήσω τυχόν ανώμαλα σημεία δεδομένων - δεν μπορώ να έχω απανθρακωμένο κρέας!
Για να ξεκινήσω, έπρεπε να χρησιμοποιήσω τον κωδικό C από το αρχικό έργο για να διαβάσω τα δεδομένα που προέρχονται από το ασύρματο θερμόμετρο και να δημοσιεύσω αυτά τα δεδομένα στον διακομιστή μου GridDB. Για να ξεκινήσει αυτό, έκανα ένα διακομιστή GridDB στο Azure χρησιμοποιώντας μια εικονική μηχανή CentOS. Ο ευκολότερος τρόπος για την κοινή χρήση δεδομένων από το μηχάνημά μας (Raspberry Pi) στον διακομιστή cloud μας ήταν μέσω του GridDB Web API. Έτσι, σε αυτό το vm, έστησα το WebAPI του GridDB μαζί με το Fluentd και το συνοδευτικό σύνδεσμο GridDB.
Πριν από την πραγματική αποστολή δεδομένων στο cloud, έπρεπε να δημιουργήσω το βασικό σχήμα για το δοχείο BBQ Pi. Το σύνολο δεδομένων που έρχεται είναι εξαιρετικά απλό: έχουμε δύο αισθητήρες θερμοκρασίας, έναν αναγνωριστικό μαγειρέματος και, φυσικά, τη χρονική σήμανση. Έτσι το σχήμα μας μοιάζει με αυτό:
timeseries = gridstore.put_container ("bbqpi", [("χρόνος", griddb. GS_TYPE_TIMESTAMP), ("cookid", griddb. GS_TYPE_INT), ("probe1", griddb. GS_TYPE_INT), ("probe2", griddb. GS_TYPE_INT)] griddb. GT
Για να δημιουργήσω αυτό το δοχείο χρονομετρητών, χρησιμοποίησα απλώς το WebAPI (θύρα 8080):
curl -X POST -βασικό -u admin: admin -H "Content -type: application/json" -d
'{"container_name": "bbqpi", "container_type": "TIME_SERIES", / "rowkey": true, "columns": [{"name": "time", "type": "TIMESTAMP"}, {"name": "cookid", "type": "INTEGER"}, {"name": "probe1", "type": "INTEGER"}, {"name": "probe2", "type": "INTEGER"}]} '\ https:// localhost: 8080/griddb/v2/defaultCluster/dbs/public/containers
Με το δοχείο που δημιουργήθηκε, χρειάστηκε να χρησιμοποιήσω το Fluentd (θύρα 8888) για να δημοσιεύσω πραγματικά δεδομένα στο κοντέινερ μας. Ακολουθεί μια εντολή CURL που δημοσιεύει μερικά εικονικά δεδομένα:
curl -X POST -d 'json = {"date": "2020-01-01T12: 08: 21.112Z", "cookid": "1", "probe1": "150", "probe2": "140" } 'https:// localhost: 8888/griddb
Από εκεί, έπρεπε να προσθέσω τον αρχικό κώδικα για να στείλω ένα αίτημα POST HTTP κάθε φορά που το Pi μας διάβαζε δεδομένα από το λάκκο μας (περίπου μία φορά ~ 12 δευτερόλεπτα).
Ως δευτερεύουσα σημείωση: γράφοντας αυτόν τον κώδικα με έμαθε να εκτιμώ πόσο λεκτική μπορεί να είναι η γλώσσα C:
int postData (χρόνος char , int cookid, int probe1, int probe2, char url )
{CURL *curl; CURLcode res; / * Στα παράθυρα, αυτό θα κάνει εκκίνηση των αντικειμένων σε βιτρίνα */ curl_global_init (CURL_GLOBAL_ALL); char errbuf [CURL_ERROR_SIZE] = {0,}; πράκτορας char [1024] = {0,}; char json [1000]; snprintf (json, 200, "json = {" date / ": \"%s.112Z / ", \" cookid / ": \"%d / ", \" probe1 / ": \"%d / ", / "probe2 \": / "%d \"} ", time, cookid, probe1, probe2); / * λάβετε μια λαβή μπούκλας */ curl = curl_easy_init (); if (curl) { /* Ορίστε πρώτα τη διεύθυνση URL που πρόκειται να λάβει το POST μας. Αυτή η διεύθυνση URL μπορεί εξίσου να είναι https:// URL, εάν αυτό είναι που πρέπει να λαμβάνει τα δεδομένα. */ snprintf (agent, sizeof agent, "libcurl/%s", curl_version_info (CURLVERSION_NOW)-> έκδοση); πράκτορας [sizeof agent - 1] = 0; curl_easy_setopt (μπούκλα, CURLOPT_USERAGENT, πράκτορας); curl_easy_setopt (μπούκλα, CURLOPT_URL, url); curl_easy_setopt (curl, CURLOPT_USERNAME, "admin"); curl_easy_setopt (curl, CURLOPT_PASSWORD, "admin"); curl_easy_setopt (μπούκλα, CURLOPT_VERBOSE, 1L); curl_easy_setopt (μπούκλα, CURLOPT_ERRORBUFFER, errbuf); curl_easy_setopt (μπούκλα, CURLOPT_POSTFIELDS, json); / * Εκτελέστε το αίτημα, το res θα λάβει τον κωδικό επιστροφής */ res = curl_easy_perform (curl)? εάν (res! = CURLE_OK) {size_t len = strlen (errbuf); fprintf (stderr, "\ nlibcurl: (%d)", res); αν (len) fprintf (stderr, "%s%s", errbuf, ((errbuf [len - 1]! = '\ n')? "\ n": "")); fprintf (stderr, "%s / n / n", curl_easy_strerror (res)); πήγα να καθαρίσω? } καθαρισμός: curl_easy_cleanup (μπούκλα); curl_global_cleanup (); επιστροφή 0? }}
Με αυτήν τη συνάρτηση γραμμένη, έπρεπε απλώς να την εκτελέσω την ίδια στιγμή που δημοσιεύονταν τα δεδομένα sqlite:
εάν (goodData == 1) {
εάν (last_db_write == 0 || (secs-last_db_write> = 10)) {snprintf (sql, 100, "ΕΙΣΑΓΩΓΕ ΣΕ αναγνώσεις (cookid, time, probe1, probe2) VALUES (%d, '%s',%d, %d); ", cookID, buff, probe1, probe2); printf ("%s / n", sql); rc = sqlite3_exec (db, sql, callback, 0, & zErrMsg); if (rc! = SQLITE_OK) {printf ("Σφάλμα SQL: %s / n", zErrMsg); } else {last_db_write = secs; } char url = "https://xx.xx.xx.xx: 8888/griddb"; postData (buff, cookID, probe1, probe2, url); }}
Για να βεβαιωθείτε ότι τα δεδομένα σας πράγματι εισάγονται στον διακομιστή σας, μπορείτε να εκτελέσετε την ακόλουθη εντολή για να αναζητήσετε τη βάση δεδομένων σας και να δείτε τα αποτελέσματα:
curl -X POST -βασικό -u admin: admin -H "Content -type: application/json" -d '{"limit": 1000}' https:// localhost: 8080/griddb/v2/defaultCluster/dbs/ δημόσια/εμπορευματοκιβώτια/bbqpi/σειρές
Βήμα 2: Grafana
Με τον κωδικό στη θέση του, τώρα όταν χρησιμοποιούμε την αρχική διαδικτυακή πύλη για να ξεκινήσουμε ένα "μαγείρεμα", θα αποθηκεύουμε ταυτόχρονα τα δεδομένα θερμοκρασίας στον διακομιστή μας GridDB.
Το επόμενο βήμα θα είναι η οπτικοποίηση των δεδομένων μας χρησιμοποιώντας το Grafana. Για να το κάνουμε αυτό, ακολουθήσαμε τις πληροφορίες από αυτό το ιστολόγιο: εδώ. Το ωραίο με αυτήν την υλοποίηση είναι ότι είναι εξαιρετικά εύκολο να δούμε τα δεδομένα μας σε ένα ωραίο γράφημα. Προσθέτει επίσης σχολιασμούς.
Οι σχολιασμοί που συζητούνται στο ιστολόγιο μας καθιστούν εξαιρετικά εύκολο να παρακολουθούμε πότε κάτι δεν πάει καλά είτε με το φαγητό μας είτε με το ίδιο το λάκκο. Στην περίπτωσή μου, μαγείρευα κοντά μοσχαρίσια παϊδάκια. Με αυτά, δεν ήθελα η θερμοκρασία στο λάκκο να αυξηθεί πέρα από τους 275 βαθμούς Φαρενάιτ. Αν έβλεπα τη θερμοκρασία να υπερβαίνει αυτό, θα μπορούσα να σβήσω έναν καυστήρα και να αφήσω τη θερμότητα να πέσει ξανά:
Είχα έναν παρόμοιο κανόνα για τον αισθητήρα που παρακολουθούσε πραγματικά το ίδιο το φαγητό: εάν το φαγητό έφτανε σε εσωτερική θερμοκρασία 203 βαθμών Φαρενάιτ, τα πλευρά ήταν έτοιμα. Μπορείτε να δείτε τον μοναδικό σχολιασμό στο τέλος του μάγειρα εδώ:
Συνολικά, ο μάγειρας μου πήρε μόνο περίπου 4 ώρες περίπου, αλλά αυτό το είδος ρύθμισης θα ήταν πραγματικά εξαιρετικό αν μαγείρευα κάτι που θα απαιτούσε ακόμη περισσότερο χρόνο στο γκριλ (σκεφτείτε έναν χαμηλό-αργό καπνό που διαρκεί 12 ~ ώρες). Παρ 'όλα αυτά, πιστεύω ότι η αξία αν αυτό το εργαλείο είναι εύκολα εμφανές: το να μπορείτε να καταγράφετε τα αποτελέσματα των τροφίμων σας και στη συνέχεια να το συγκρίνετε με προηγούμενους μάγειρες σημαίνει ότι το μπάρμπεκιου σας θα βελτιωθεί σιγά σιγά με την πάροδο του χρόνου καθώς μπορείτε να χρησιμοποιήσετε δεδομένα για να δείτε τι λειτουργεί και τι όχι 't
Βήμα 3: Το φαγητό
Αυτή ήταν η πρώτη φορά που έφτιαχνα μοσχάρι κοντά παϊδάκια. για καρύκευμα, χρησιμοποίησα απλά αλάτι, μαύρο πιπέρι και σκόνη σκόρδου. Παρά τα προβλήματα με τον καυστήρα να είναι πολύ ψηλός για λίγο στην αρχή, τα παϊδάκια βγήκαν φανταστικά. Σε παρακαλώ ρίξε μια ματιά:
Βήμα 4: Συμπέρασμα
Τελικά, το φαγητό βγήκε υπέροχο, οι αισθητήρες, το GridDB και η Grafana συνεργάστηκαν όμορφα και πήραμε μερικά πολύτιμα δεδομένα για το πώς να μαγειρέψουμε ξανά αυτά τα πράγματα για την επόμενη φορά που θέλουμε να εντυπωσιάσουμε μερικούς φίλους.
Συνιστάται:
Οπτικοποίηση δεδομένων από το Magicbit στο AWS: 5 βήματα
Οπτικοποίηση δεδομένων από το Magicbit σε AWS: Τα δεδομένα που συλλέγονται από αισθητήρες που συνδέονται με το Magicbit θα δημοσιευτούν στον πυρήνα AWS IOT μέσω MQTT για οπτικοποίηση σε πραγματικό χρόνο. Χρησιμοποιούμε το magicbit ως πίνακα ανάπτυξης σε αυτό το έργο που βασίζεται στο ESP32. Επομένως, κάθε ESP32 d
IoT: Οπτικοποίηση δεδομένων αισθητήρα φωτός χρησιμοποιώντας Node-RED: 7 βήματα
IoT: Οπτικοποίηση δεδομένων αισθητήρα φωτός με χρήση του Node-RED: Σε αυτό το διδακτικό, θα μάθετε πώς να δημιουργείτε έναν αισθητήρα συνδεδεμένο στο Διαδίκτυο! Θα χρησιμοποιήσω έναν αισθητήρα φωτισμού περιβάλλοντος (TI OPT3001) για αυτό το demo, αλλά οποιοσδήποτε αισθητήρας της επιλογής σας (θερμοκρασία, υγρασία, ποτενσιόμετρο κ.λπ.) θα λειτουργούσε. Οι τιμές του αισθητήρα
Ανάγνωση δεδομένων υπερηχητικού αισθητήρα (HC-SR04) Δεδομένων σε οθόνη LCD 128 × 128 και οπτικοποίηση χρησιμοποιώντας Matplotlib: 8 βήματα
Ανάγνωση δεδομένων υπερηχητικού αισθητήρα (HC-SR04) Δεδομένων σε LCD 128 × 128 και οπτικοποίηση χρησιμοποιώντας Matplotlib: Σε αυτό το διδακτικό, θα χρησιμοποιήσουμε το MSP432 LaunchPad + BoosterPack για την εμφάνιση δεδομένων υπερήχων αισθητήρων (HC-SR04) σε 128 × 128 LCD και στείλτε τα δεδομένα στον Η / Υ σειριακά και οπτικοποιήστε τα χρησιμοποιώντας το Matplotlib
Οπτικοποίηση δεδομένων μεταφοράς με το Google Map: 6 βήματα
Οπτικοποίηση δεδομένων μεταφοράς Με το Google Map: Συνήθως θέλουμε να καταγράφουμε διάφορα δεδομένα κατά τη διάρκεια της ποδηλασίας, αυτή τη φορά χρησιμοποιήσαμε νέο Wio LTE για να τα παρακολουθήσουμε
Οπτικοποίηση δεδομένων ασύρματου αισθητήρα χρησιμοποιώντας γραφήματα Google: 6 βήματα
Οπτικοποίηση δεδομένων ασύρματου αισθητήρα χρησιμοποιώντας γραφήματα Google: Η προβλεπτική ανάλυση των μηχανημάτων είναι πολύ απαραίτητη προκειμένου να ελαχιστοποιηθεί ο χρόνος διακοπής λειτουργίας του μηχανήματος. Ο τακτικός έλεγχος βοηθά στην αύξηση του χρόνου λειτουργίας του μηχανήματος και με τη σειρά του αυξάνει την ανοχή σε σφάλματα. Ασύρματο σύστημα δόνησης και θερμοκρασίας