İçindekiler:
2025 Yazar: John Day | [email protected]. Son düzenleme: 2025-01-13 06:58
İnternet+ artık popüler bir kavram. Bu sefer internet artı tarım yaparak çay bahçesini internetten çay yetiştirmeye çalıştık.
Adım 1: Bu Projede Kullanılanlar
Donanım bileşenleri
- Grove - Karbon Dioksit Sensörü(MH-Z16)
- Grove - Dijital Işık Sensörü
- Grove - Toz Sensörü(PPD42NS)
- Grove - Oksijen Sensörü(ME2-O2-Ф20)
- Toprak Nemi ve Sıcaklık Sensörü
- LoRa LoRaWAN Ağ Geçidi - Raspberry Pi 3 ile 868MHz Kiti
- Grove - Sıcaklık&Humi&Barometre Sensörü (BME280)
Yazılım uygulamaları ve çevrimiçi hizmetler
Microsoft Visual Studio 2015
2. Adım: Öykü
Sichuan, Ya'an'ın kuzeydoğusundaki Mengding Dağı'nda, dağ sırtı yeşil bir denizde batıdan doğuya uzanır. Bu, deniz seviyesinden 1100 m yükseklikte bulunan 50mu (=3.3 hektar) plantasyonuyla neslinin çok az Mengding çay üreticisinden biri olan 36 yaşındaki Deng için en tanıdık manzara. Deng, çay üreticisi bir aileden geliyor, ancak aile mirasını sürdürmek kolay bir iş değil. “Çaylarımız, mükemmel kalitesini sağlamak için organik bir ortamda yüksek rakımda yetiştirilmektedir. Ancak aynı zamanda, büyüme yoğunluğu düşük, maliyet yüksek ve tomurcuklanma düzensiz, bu da çayı hasat etmeyi zorlaştırıyor. Bu nedenle yüksek dağ çayları normalde küçük hasatlardır ve değerleri piyasaya yansıtılmaz.” Deng, son iki yıldır, değerlerini tanıtmak için yüksek dağ çayı konusunda tüketici bilincini artırmaya çalışıyor. Ve Seeed'in IoTea teknolojisini uygulamak için bir plantasyon arayan Fan ile tanıştığında, bir çözüm için mükemmel bir eşleşme yapıldı.
3. Adım: Donanım Bağlantısı
Bu projenin donanımı 4 bölüme ayrılabilir: Güç, Sensörler, Düğüm ve Ağ Geçidi. Aşağıdaki makale, adım adım nasıl tamamlayacağınızı gösterecektir.
Güç Parçası
Güç Bölümü esas olarak bir Güneş Paneli ve bir Lityum Pil içerir, bu projeyi sadece gösteri için inşa ederseniz, onları görmezden gelebilirsiniz. Veya düğüm gücünü yüklemek için Önceki öğreticiyi takip edebilirsiniz.
Sensörler Parçası
Sensörler Bölümünde, sensörlerin çokluğu nedeniyle bir meteoroloji istasyonu kullandık ve ayrıca bunları takmak için bir Akrilik braket yaptık.
Yukarıdaki resimde gördüğünüz gibi, Dijital Işık Sensörü her zaman üsttedir, böylece aydınlatma bilgilerini toplayabilir. Akrilik braketin ortasına O2 Sensörü, Toz Sensörü ve CO2 Sensörü gibi ısı üretecek sensörler takılır. Son olarak, Akrilik braketin altındaki Sıcaklık ve Nem Sensörü.
Ayrıca Toprak Sıcaklık ve Nem Sensörü toprakta tek başına kurulur. Düğüm Parçası
Düğüm Parçası, Su Geçirmez Kutuya monte edilmiş bir Seeeduino LoRaWan'dır, Su Eklemleri aracılığıyla güce ve sensörlere bağlanır. Bunlar arasında Toz Sensörü LoRaWan'ın D3 dijital pimine bağlanır, CO2 Sensörü D4 ve D5 pimine bağlanır, Toprak Sensörü D6 ve D7 pimine bağlanır, O2 Sensörü analog pim A1'e bağlanır ve Işık Sensörü ve Barometre Sensörü I2C portuna bağlanır.
NOT: Toprak Sensörünün Mavi(Veri) kablosu ile Kırmızı(Vcc) kablosu arasına 10k Direnç eklenmelidir.
Seeeduino LoRaWan arada bir sensör değerlerini toplar ve bunları LoRa aracılığıyla Gateway'e gönderir. Aşağıdaki gibi veri formatı:
{
[0], /* Hava sıcaklığı(℃) */ [1], /* Hava nemi(%) */ [2], /* Rakım(m) yüksek bayt */ [3], /* Rakım(m) düşük bayt */ [4], /* CO2 konsantrasyonu(PPM) yüksek bayt */ [5], /* CO2 konsantrasyonu(PPM) düşük bayt */ [6], /* Toz konsantrasyonu(adet/0.01cf) yüksek bayt */ [7], /* Toz konsantrasyonu(adet/0.01cf) düşük bayt */ [8], /* Işık yoğunluğu(lüks) yüksek bayt */ [9], /* Işık yoğunluğu(lüks) düşük bayt */ [10], /* O2 konsantrasyonu(%) */ [11], /* Toprak sıcaklığı(℃) */ [12], /* Toprak nemi(%) */ [13], /* Akü voltajı(V) */ [14] /* Sensör hata kodu */ }
Sensör Hata Kodu baytındaki her bit, aşağıdaki gibi bir fark anlamı taşır:
{
bit0: 1; /* Barometre Sensör Hatası */ bit1: 1; /* CO2 Sensör Hatası */ bit2: 1; /* Toz Sensörü Hatası */ bit3: 1; /* Işık Sensörü Hatası */ bit4: 1; /* O2 Sensör Hatası */ bit5: 1; /* Toprak Sensörü Hatası */ saklıdır: 2; /* Rezerve */ }
Ağ Geçidi Parçası
Ağ Geçidi Parçası, Ağ Geçidi modülü RHF0M301–868 ve PRI 2 Köprü RHF4T002'yi takan bir Ahududu Pi'dir, bir Su Geçirmez Kutuya monte edilir ve Su Eklemleri aracılığıyla güç ve USB Kameraya bağlanır. Özel ürün yazılımı kullandığından, yapılandırmak için lütfen Seeed Wiki'yi takip edin.
Adım 4: Yazılım Programlama
Donanım Bağlantısı olarak Yazılım Programlama da bölünebilir, 3 bölüme ayrılabilir: Düğüm, Ağ Geçidi ve Web Sitesi.
Düğüm Parçası
Düğüm Bölümünün gerektirdiği sürücülerin çoğu zaten Origin_driver klasöründe bulunur. Aşağıdaki kitaplıkların manuel olarak yüklenmesi gerekir:
Adafruit_ASFcore
Proje karmaşık olduğu için Arduino IDE yerine Microsoft Visual Studio kullanmanızı öneririz. Visual Micro adlı bir eklenti, Visual Studio kullanarak bir Arduino projesi oluşturmanıza yardımcı olabilir, daha fazla bilgi için buraya tıklayın.
Daha iyi okunabilirlik ve sürdürülebilirlik için bu sefer Nesne Yönelimli Programlama kullanıyoruz. Bu projenin sınıf diyagramı aşağıdaki gibidir:
Halihazırda OOP sürücüsüne sahip sensörler için, bu projeyi uyarlamak için yeniden paketledik, diğerleri için sürücülerini OOP kullanarak yeniden yazdık. Ara katman katmanındaki Sensör sınıfı, gerçek sensörlerin arayüzlerini birleştirmek için kullanılır, örneğin bir barometre sensörü aynı anda sıcaklık, nem ve irtifa toplayabilir, bu nedenle sıcaklık, nem ve yükseklik elde etmek için 3 arayüze sahiptir. Ancak, sensör değeri elde etme programını aşağıdaki gibi daha karmaşık hale getirecek olan farklı yöntem adlarına sahiptirler:
barometre->getTemperature();
barometre->getHumidity(); barometre->getAltitude(); // … other_sensor->getSomeValue(); // …
Ancak OOP kullanarak şöyle görünür:
for (otomatik i = 0; i getValue();
}
Ayrıca bir Application sınıfını paketledik, IApplication arabirimini uygular, IoTea.ino'daki setup() ve loop() yöntemi Application nesnesinde setup() ve loop() yöntemini çağırabilir.
NOT: USB Seri SADECE hata ayıklamak için kullanılır. Hata ayıklamadan sonra, lütfen setup() yönteminde kodu başlattığını yorumlayın.
Ağ Geçidi Parçası
Gateway Part'ın ana klasördeki Python programı, fotoğraf çekmek ve her saat başı Amazon S3 Server'a yüklemek için kullanılır. Kullanmadan önce fswebcam'in Raspberry Pi'nizde kurulu olduğundan emin olun:
sudo apt-get güncelleme && sudo apt-get install fswebcam
Fotoğraf yüklemek istiyorsanız aşağıdaki adımları izleyerek AWS'nizi yapılandırın. Öncelikle aşağıdaki komutları kullanarak AWS SDK ve AWS CLI'yi Raspberry Pi'nize yükleyin:
sudo pip yükleme boto3
sudo pip kurulum awscli
ve ardından AWS CLI'yi çalıştırın:
sudo aws yapılandır
AWS Erişim Anahtarı Kimliğinizi, AWS Gizli Erişim Kimliğinizi ve Varsayılan bölge adınızı yapılandırın.
Fotoğraflarınızı yüklemek istemiyorsanız, AWS yapılandırma adımlarını atlayabilir ve photo.py'ye yüklemeyle ilgili kodlara yorum yapabilirsiniz. Bu programı her seferinde Raspberry Pi'yi açtıktan sonra çalıştırmak için /etc/init.d içinde bir dosya adı fotoğrafı oluşturabilir ve buna aşağıdaki kodu yazabilirsiniz.
#!/bin/bash
# /etc/init.d/photo ### BEGIN INIT INFO # Sağlar: seeed_photo # Gerekli-Başlangıç: $remote_fs $syslog # Gerekli-Durdur: $remote_fs $syslog # Varsayılan-Başlangıç: 2 3 4 5 # Varsayılan-Durdur: 0 1 6 # Kısa Açıklama: fotoğraf çekme initscript # Açıklama: Bu hizmet fotoğraf çekmeyi yönetmek için kullanılır ### END INIT INFO case "$1" başlangıçta) echo "Fotoğraf çekmeye başla" /home/rxhf/photo.py &;; stop) echo "Fotoğraf çekmeyi durdur" kill $(ps aux | grep -m 1 'python3 /home/rxhf/photo.py' | awk '{ print $2 }');; *) echo "Kullanım: hizmet fotoğrafı başlat|durdur" çıkış 1;; esac çıkış 0
yürütme iznini ayarla
sudo chmod 777 /etc/init.d/photo
sudo chmod 777 /home/rxhf/photo.py
ve test et
sudo /etc/init.d/fotoğraf başlangıcı
Herhangi bir sorun yoksa durdurup başlangıç uygulamasına ekleyin.
sudo /etc/init.d/fotoğraf durdurma
sudo update-rc.d fotoğraf varsayılanları
NOT: Raspberry Pi önyüklemesinden sonra ağ geçidini başlatmak istiyorsanız, Seeed Wiki'deki ağ geçidi başlatma kodlarını /etc/rc.local'a ekleyin, şöyle görünsün:
#!/bin/sh -e
# # rc.local # # Bu komut dosyası, her çok kullanıcılı çalışma seviyesinin sonunda yürütülür. # Başarı durumunda betiğin "0"dan veya hata durumunda başka bir # değerden çıkacağından emin olun. # # Bu betiği etkinleştirmek veya devre dışı bırakmak için sadece yürütmeyi # bit değiştirin. # # Varsayılan olarak bu komut dosyası hiçbir şey yapmaz. # IP adresini yazdırın _IP=$(hostname -I) || true if ["$_IP"]; sonra printf "IP adresim %s\n" "$_IP" fi cd /home/rxhf/loriot/1.0.2 sudo systemctl pktfwd sudo gwrst wget https://cn1.loriot.io/home/gwsw/loriot -risinghf-r… -O loriot-gw.bin chmod +x loriot-gw.bin./loriot-gw.bin -f -s cn1.loriot.io çıkış 0
İnternet sitesi
Web sitesini CentOS 7'ye kurduk. Aşağıdaki adımlar size nasıl dağıtacağınızı gösterecektir.
Adım 1. Python3'ü yükleyin
sudo yum -y epel sürümünü yükle
sudo yum -y python36'yı kurun
Adım 2. Python pip ve sanal ortamı kurun
wget
sudo python36 get-pip.py sudo pip sanalenv yükleyin
Setp 3. Web sitemizi GitHub'dan klonlayın
sudo yum -y git'i kurun
git klon
Adım 4. Sanal ortam oluşturun ve etkinleştirin
virtualenv -p python36 iotea-hb
cd iotea-hb kaynak kutusu/etkinleştirme
Adım 5. Bağımlı kitaplıkları kurun
pip kurulum pymysql
pip kurulumu dbutils pip flask kurulumu pip websocket-client kurulumu pip cofigparser kurulumu
Adım 6. Veritabanı oluşturun
sudo yum -y mariadb mariabd sunucusunu kurun
sudo systemctl mariadb'yi etkinleştir sudo systemctl mariadb'yi başlat mysql -uroot -p
ve sonra bir tablo oluşturmak için iotea_hb.sql kullanın.
Adım 7. db.ini oluşturun ve bu kodları ona yazın
[db]
db_port = 3306 db_user = kök db_host = localhost db_pass = db_name = iotea
db.py'de db.ini'nin yolunu değiştir
# db.py'de
#cf.read("/data/www/python3_iotea_hb/iotea/conf/db.ini") cf.read("/home//iotea-hb/db.ini")
Adım 8. App.py'deki bağlantı noktasını değiştirin ve web sitesini başlatın:
# app.py'de
#app.run(debug=Doğru, bağlantı noktası=6000) app.run(debug=Doğru, bağlantı noktası=8080)
# terminalde
pip kurulumu gunicorn gunicorn -w 5 -b 0.0.0.0:8080 app:app
şimdi web tarayıcınızda 127.0.0.1:8080 adresini ziyaret edin, web sitesini görebilirsiniz, ancak gerçek zamanlı veriler görüntülenmez.
Adım 9. Loriot verilerini alın
Başka bir terminal açın, sanal ortama yeniden girin ve loriot uygulamasını başlatın:
cd iotea-hb
kaynak kutusu/gunicorn loriot'u etkinleştir: uygulama
Bir süre bekleyin, web sitesinde görüntülenen verileri göreceksiniz veya loriot.py'de wss'yi değiştirebilirsiniz:
# loriot.py'de
#ws = create_connection("wss://cn1.loriot.io/app?token=vnwEuwAAAA1jbjEubG9yaW90LmlvRpscoh9Uq1L7K1zbrcBz6w==")
ws = create_connection()
Adım 5: Çalıştırma
Gerçek zamanlı verileri görüntülemek için web sitelerimizi ziyaret edebilirsiniz:
- Ya'an'da
- Gösteri için