ESP8266 NodeMCU Flashing

Um eine neue Firmware oder ein neue Software zu installieren ist es notwendig den ESP8266 zu flashen.

Download der neuen Firmware

Als erstes ja nach Bezugsquelle die neue Firmware downloaden. Es handelt sich hierbei um eine bin Datei.

Im nächsten Schritt benötigen wir ein Tool um die Firmware per USB auf den ESP8266 hochzuladen. Dafür verwenden wir esptool unter Linux.

    git clone https://github.com/themadinventor/esptool.git

Nach dem Download wechseln wir in den Ordner esptool und fuehren folgenden Befehl aus:

    sudo python esptool.py --port /dev/ttyUSB0  write_flash 0x00000 neue_Firmware.bin

Fertig. Wenn alles funktioniert hat, gibt es noch eine kleine Übersicht.

E-Mails versenden mit sSMTP

Es gib immer mal wieder die Situation mit einem Linux System E-Mails zu versenden. Das können zu hohe Temperaturen der Festplatte, störungen von Cronjob oder eine IP, die aufgrund von falschen Login versuchen auffällt. Natürlich ist dieser Service auch bei anderen Diensten wie FHEM interessant. 

Man könnte sich eine E-Mail senden lassen wenn ein bestimmter Bewegungsmelder aktiv wird.  Oder die Temperatur der Gefriertruhe steigt wegen einem defekt. Hier kann auch sSMTP einspringen und eine E-Mail versenden. Die Einsatzmöglichkeiten sind unglaublich vielfältig.

Und diese Möglichkeiten gibt es mit sSMTP mit relativ wenig Aufwand.

Installation von sSMTP

Wie immer, wer sein Linux liebt der updatet als erstes 🙂

apt-get update && apt-get upgrade -V

Nun kann man die beiden Pakete von sSMTP installieren

apt-get install ssmtp mailutils

Nun wird als erster Schritt die generelle Einrichtung von sSMTP vorgenommen

nano /etc/ssmtp/ssmtp.conf

Gebt in diesem File euer E-Mail Konto sowie die entsprechenden Ports eures E-Mail Anbieters an.

root=DEINE@EMAIL.DE
mailhub=DEIN-EMAIL.SERVER.DE:PORT(ist bei jedem Anbieter anders!)
hostname=localhost
UseTLS=Yes
UseSTARTTLS=Yes
AuthUser=DEIN-EMAIL-LOGIN-BENUTZER
AuthPass=DEIN-EMAIL-PASSWORT
FromLineOverride=yes

Wer mehr zu den einzelnen Eintragen wissen möchte kann sich gerne mal die man von sSMTP ansehen.  Linux versteht man nur durch lesen :).

man ssmtp

Nun müssen wir Linux nur noch mitteilen welche Benutzer eigentlich sSMTP nutzen dürfen.

Dazu öffnen wir das Benutzer File des sSMTP

nano /etc/ssmtp/revaliases

In diesem File müssen alle Benutzer des jeweiligen Linux System eingetragen werden die gerne eine Email versenden möchten. Bitte achtet drauf auch hier die richtigen PORTs mit anzugeben.

root:DEINE@EMAIL-ADRESSE.DE:smtp.EMAIL-ADRESSE.de:587 (Je nach Anbeiter)
www-data:WWW-USER@SEINE-EMAIL.DE:smtp.IRGENDWAS.DE:PORT

Zum Schluss schicken wir nun mal eine Test E-Mail 😀

echo "Mail-Inhalt" | mail -s "Betreff" EMAIL@AN-DIE-GESENDET-WERDEN-SOLL.DE

So das waren die Grundlagen. Nun ist dein Linux System in der Lage E-Mails zu versenden. War ja eigentlich gar nicht so viel Aufwand!

SDS011 – Feinstaubsensor

Mit dem Modul SDS011 kann der Feinstaub in der Luft per Particulate Matter (PM) „gezählt“ werden. Es werden Partikelgrößen in den Bereichen PM 2.5 und PM 10 registriert.

Die Kommunikation mit dem Arduino geht per Serieller Verbindung. Der Sensor kann per HEX Befehl gesteuert oder Schlafen gelegt werden. Dies ist auch bei Einsatz als „Messsonde“ auch sinnvoll da die Lebensdauer der Laserdiode auf 8000 h geschätzt wird. Mehr Infos gibt es Datenblatt am Ende des Beitrages.

Ein einfacher Arduino Sketch zum auslesen der Daten sollte als Basis für weitere Entwicklungen ausreichend sein. Hierfür bietet sich die Library von Paweł Kołodziejczyk an die hier zu finden ist.



Nachfolgend eine Ausgabe im Arduino Seriellen Monitor.

 
#include "SdsDustSensor.h"
 
int rxPin = 6;
int txPin = 7;
SdsDustSensor sds(rxPin, txPin);
 
void setup() {
  Serial.begin(9600);
  sds.begin();
 
  Serial.println(sds.queryFirmwareVersion().toString()); // prints firmware version
  Serial.println(sds.setActiveReportingMode().toString()); // ensures sensor is in 'active' reporting mode
  Serial.println(sds.setCustomWorkingPeriod(10).toString()); // sensor sends data every 3 minutes
}
 
void loop() {
  PmResult pm = sds.readPm();
  if (pm.isOk()) {
    Serial.print("PM2.5 = ");
    Serial.print(pm.pm25);
    Serial.print(", PM10 = ");
    Serial.println(pm.pm10);
 
    // if you want to just print the measured values, you can use toString() method as well
    Serial.println(pm.toString());
  } else {
    // notice that loop delay is set to 5s (sensor sends data every 3 minutes) and some reads are not available
    Serial.print("Could not read values from sensor, reason: ");
    Serial.println(pm.statusToString());
  }
 
  delay(5000);
}

Nachfolgend noch das Datenblatt von Nova Fitness Co., Ltd..

DHT22 / AM2302-Luftfeuchte und Temperatursensor

Dieser Sensor dient zum Messen der Luftfeuchtigkeit und der Temperatur. Durch seinen günstigen Preis bietet sich der AM2302 fuer diese Aufgabe an. Da er sowohl mit 3,3V oder 5V betrieben werden kann eignet er sich zum Betrieb an einem Raspberry oder Arduino.

Durch seine OneWire Technologie reicht ein PIN am Board um Luftfeuchtigkeit und Temperatur zu ermitteln. Die Abfrage der Messwerte erfolgt somit seriell als Bitreihenfolge.

Technische Daten:

  • Betriebsspannung: DC 3.3-5.5V
  • Luftfeuchtigkeitsmessbereich : 0 bis 100% relative Luftfeuchte
  • Feuchtemessgenauigkeit: ±2% RH
  • Temperaturbereich: -40 bis +80 C
  • Temperaturmessgenauigkeit ±0.5
  • OneWire Ausgang an Pin 2

  • Maße: 28mm x 12mm x 10mm

Beispielprogramm fuer einen Arduino Uno

    // Example testing sketch for various DHT humidity/temperature sensors
// Written by ladyada, public domain
 
#include "DHT.h"
 
#define DHTPIN 7     // what digital pin we're connected to
 
// Uncomment whatever type you're using!
//#define DHTTYPE DHT11   // DHT 11
#define DHTTYPE DHT22   // DHT 22  (AM2302), AM2321
//#define DHTTYPE DHT21   // DHT 21 (AM2301)
 
// Connect pin 1 (on the left) of the sensor to +5V
// NOTE: If using a board with 3.3V logic like an Arduino Due connect pin 1
// to 3.3V instead of 5V!
// Connect pin 2 of the sensor to whatever your DHTPIN is
// Connect pin 4 (on the right) of the sensor to GROUND
// Connect a 10K resistor from pin 2 (data) to pin 1 (power) of the sensor
 
// Initialize DHT sensor.
// Note that older versions of this library took an optional third parameter to
// tweak the timings for faster processors.  This parameter is no longer needed
// as the current DHT reading algorithm adjusts itself to work on faster procs.
DHT dht(DHTPIN, DHTTYPE);
 
void setup() {
  Serial.begin(57600);
  Serial.println("DHTxx test!");
 
  dht.begin();
}
 
void loop() {
  // Wait a few seconds between measurements.
  delay(2000);
 
  // Reading temperature or humidity takes about 250 milliseconds!
  // Sensor readings may also be up to 2 seconds 'old' (its a very slow sensor)
  float h = dht.readHumidity();
  // Read temperature as Celsius (the default)
  float t = dht.readTemperature();
  // Read temperature as Fahrenheit (isFahrenheit = true)
  float f = dht.readTemperature(true);
 
  // Check if any reads failed and exit early (to try again).
  if (isnan(h) || isnan(t) || isnan(f)) {
    Serial.println("Failed to read from DHT sensor!");
    return;
  }
 
  // Compute heat index in Fahrenheit (the default)
  float hif = dht.computeHeatIndex(f, h);
  // Compute heat index in Celsius (isFahreheit = false)
  float hic = dht.computeHeatIndex(t, h, false);
 
  Serial.print("Humidity: ");
  Serial.print(h);
  Serial.print(" %\t");
  Serial.print("Temperature: ");
  Serial.print(t);
  Serial.print(" *C ");
  Serial.print(f);
  Serial.print(" *F\t");
  Serial.print("Heat index: ");
  Serial.print(hic);
  Serial.print(" *C ");
  Serial.print(hif);
  Serial.println(" *F");
}

Quelle ladyada, public domain

Mehr infos unter Github.

Arduino Relaiskarte per MQTT Befehl steuern

Die Hausautomatisierung benötigt sehr viele Aktoren. In diesem Bereich gibt es sehr viele Produkte der großen Hersteller. Leider auch entsprechend teuer. Hier möchte ich ein Projekt vorstellen das über einen Arduino (WeMos D1) eine Relaiskarte ansteuert. zur Steuerung verwende ich das MQTT Protokoll. Natürlich alles per WiFi. Es wird nur noch die Versorgungsspannung und der Laststromkreis benötig.

5 Minuten Probeaufbau

Gesteuert wird nun das Relais A mit folgendem Befehl:

Ebenso einfach geht das Aus schalten des Relais

Relais B reagiert folglich auf

Das Relais ist nun im kompletten Heimnetzwerk erreichbar.

Code Snipes

WooCommerce-Shortcodes.

Alle Befehle in [ ] setzen.

Recent products

recent_products per_page="12" columns="4"

Zeigt neue Produkte an.

Featured Products

featured_products per_page="12" columns="4"

Zeigt empfohlene Produkte an.

Product

product id="99"  oder
product sku="FOO"

Zeigt ein bestimmtes Produkt an.

Products

products ids="1, 2, 3, 4, 5" columns="4"  oder
products skus="foo, bar, baz" columns="4"

Zeigt mehrere bestimmte Produkte an.

Product page

product_page id="99" oder
product_page sku="FOO"

Zeigt den Inhalt einer Produkt-Detailseite an.

Product category

product_category category="appliances" per_page="12" columns="4"

Zeigt die Produkte einer Kategorie an.

Product Categories

product_categories columns="4"

Zeigt eine Produkt-Kategorieübersicht an.

Sale Products

sale_products per_page="12" columns="4"

Zeigt reduzierte Produkte an.

Best Selling Products

best_selling_products per_page="12" columns="4"

Zeigt Verkaufsschlager an.

Top Rated Products

top_rated_products per_page="12" columns="4"

Viel mehr Shortcodes gibt es hier.

BASH Scripting

Inhaltsverzeichnis

Bevor man die ersten BASH Scripte erstellt sollte man sich die Position von BASH ausgeben lassen. Das geht mit folgendem Befehl.

which bash

Die erste Zeile eines BASH Scripts

Damit das Betriebssystem bei Programmstart alle Interpreten zuweisen kann, wird in der ersten Zeile der Pfad zum BASH Interpreter angegeben. Diese Angabe ist kein Teil des Scriptes. Muss aber angegeben werden.

#!/bin/bash

Kommentare – kann es nie zu wenig geben

Um die Funktion und Arbeitsweise eines Scripts zu erläutern ist es immer Sinnvoll Kommentare anzugeben.  Bei BASH werden alle Zeichen die in einer Zeile auf ein # folgen ignoriert.

# Das waere die erste Kommentarzeile
# 2. Zeile die vom Interpreter uebersprungen wird.


Variablen

Wie in jeder Programmiersprache bietet auch BASH die Möglichkeit Variablen anzulegen. Diese dienen auch bei BASH dazu werte später immer wieder zu verwenden.
Um im Script eine Variable verwenden zu können muss diese nicht extra deklariert werden. Im Allgemeinen reicht es direkt einen Wert zuzuweisen.

NeueVAR = Test

Die Verwendung derVariablen erfolgt im Script mit einem $.