NEWS
Adapter "smartmeter"
-
@RappiRN
wichtig ist wohl dieser part:"protocol": "d0", "device": "/dev/ttyUSB0", "pullseq": "2F3F210D0A", "ackseq": "063030300D0A", "baudrate": 300, "parity": "7e1", "baudrate_change_delay": 0
Also D0
Baudrate und parityirgendwo stand noch was von delay
-
Also früher musste man noch das Paket Serialport manuell installieren.
Schau mal in /opt/iobroker/node_modules/iobroker.modbus/node_modules/serialport was in der package.json steht ... Die Version zählt am Ende und ob es das bei dir überhaupt gibt.
Sonst: iobroker stoppen und das Paket nach installieren.
cd /opt/iobroker npm i serialport
Dann nochmal den Adapter testen.
-
@wendy2702
find ich nix:This adapter for ioBroker allows the reading and parsing of smartmeter protocols that follow the OBIS number logic to make their data available. The Adapter needs nodejs 4.x to work! This Adapter needs to have git installed currently for installing!
Kann ich mich auch nicht dran erinnern
-
@Homoran hmmm.... verwechsel ich das mit Modbus ?
Wobei das Package eigentlich für Anwendungen benötigt wird die auf den Serialport zugreifen wenn ich mich richtig erinnere.
Ist aber auch schon laaaaaannnnnggggeeee her und ich weiß das ich es mal nach dieser Seite installiert habe:
http://www.iobroker.net/docu/?page_id=5510&lang=de
Allerdings stand damals so 2016 hier auch noch der Serialport Befehl drin.
-
Also ich hab tagsüber noch dem Hersteller von dem Adapter geschrieben und gerade folgenden Link zur Konfiguration von dem Adapter bekommen:
Daraufhin habe ich jetzt den stty Befehl ausgeführt und in einem parallel Fenster das echo getriggert. Daraufhin kommt im ersten Fenster wo ich cat /dev/ttyUSB0 laufen lasse folgendes:
digitalnaive@asrock:~$ sudo cat /dev/ttyUSB0 cat: /dev/ttyUSB0: Resource temporarily unavailable
In der PDF steht ja noch, dass auch der Handshake ausgeschaltet sein muss. Wo genau finde ich den denn bei Minicom?
-
Wenn du die stty Befehle aus dem PDF nimmst ist doch alles richtig gesetzt.
WICHTIG: Flow Control und Hardware Handshake müssen ausgeschaltet werden, was mit der oben genannen stty Konfiguration durchgeführt wird.
Kannst du den Kopf mal an einen anderen PORT stecken zum testen?
Hast du auch mal das von Seite 2 versucht?
-
@wendy2702 said in Adapter "smartmeter":
Wenn du die stty Befehle aus dem PDF nimmst ist doch alles richtig gesetzt.
WICHTIG: Flow Control und Hardware Handshake müssen ausgeschaltet werden, was mit der oben genannen stty Konfiguration durchgeführt wird.
Kannst du den Kopf mal an einen anderen PORT stecken zum testen?
Hast du auch mal das von Seite 2 versucht?
Also ich habe von Seite 2 erst
Beispiel für fast alle Stromzähler mit der Baudrate 300:
echo -n -e '\x2F\x3F\x21\x0D\x0A' > /dev/ttyUSB0und dann
nach max. 2 Sekunden den folgenden Befehl senden:
echo -n -e '\x06\x30\x30\x30\x0D\x0A' > /dev/ttyUSB0ausgeführt. Daraufhin bekam ich diese Resource temporarily unavailable Meldung.
Kann gerne mal an einen anderen Port stecken. Muss ich dann nochmal was wegen ttyUSB0 ändern? (ich habe nur 3 USB Ports und nur diesen einen Adapter angeschlossen am Gerät, sonst gar nichts)
-
@digitalnaive
es kann immer nur einer auf den serialport zugreifen.
der Adapter ODER die Konsole -
@Homoran said in Adapter "smartmeter":
@digitalnaive
es kann immer nur einer auf den serialport zugreifen.
der Adapter ODER die KonsoleVielleicht verstehe ich auch deine Aussage nicht richtig, aber warum sollte dann in der PDF stehen, dass man quasi den Adapter via cat anstoßen und im zweiten Terminal Fenster dann den Echo Befehl starten soll?
-
@digitalnaive
weil bei ioBroker mit Adapter der Smartmeter-Adapter gemeint ist, nicht der Lesekopf -
Das Device solltest du sicherheitshalber wieder Prüfen.
Also hast du jetzt das gemacht:
stty -F /dev/ttyUSB0 300 -parodd cs7 -cstopb parenb -ixoff -crtscts -hupcl -ixon -opost -onlcr -isig -icanon -iexten -echo -echoe -echoctl -echoke
Dann ein Fenster geöffnet und
cat /dev/ttyUSB0
Und in einem zweiten Fenster das:
echo -n -e 'Befehl' > /dev/ttyUSB0
oder das:
echo -n -e '\x2F\x3F\x21\x0D\x0A' > /dev/ttyUSB0 nach zwei sekunden--> echo -n -e '\x06\x30\x30\x30\x0D\x0A' > /dev/ttyUSB0
Und wie @Homoran schreibt, entweder Adapter aktiv oder CAT nutzen.
-
@wendy2702 said in Adapter "smartmeter":
echo -n -e 'Befehl' > /dev/ttyUSB0
Also, der Adapter ist in iobroker deaktiviert. Mit dmesg | grep tty bekomme ich folgende Anzeige:
digitalnaive@asrock:~$ sudo dmesg | grep tty [ 0.000000] console [tty0] enabled [ 7.820332] usb 1-2: FTDI USB Serial Device converter now attached to ttyUSB0 [19339.786752] ftdi_sio ttyUSB0: FTDI USB Serial Device converter now disconnected from ttyUSB0 [19343.305426] usb 1-3: FTDI USB Serial Device converter now attached to ttyUSB0
Dann hab ich wieder deine Kette befolgt @wendy2702 und bekomme direkt nach dem ersten Echo im zweiten Fenster wieder die Meldung:
digitalnaive@asrock:~$ sudo cat /dev/ttyUSB0 cat: /dev/ttyUSB0: Resource temporarily unavailable
Noch eine Ergänzung. Der Adapter scheint zu gehen. Als ich ihm mit der Taschenlampe des Handys draufgeleuchtet habe, hat die LED grün geblinkt.
Das habe ich gerade noch im Datenblatt des Stromzählers gefunden:
Optische Schnittstelle, Serielle Schnittstelle RS-485 bzw. RS-232 oder
M-Bus. Konfigurierbare Übertragungsgeschwindigkeit von 300 Bd
bis 9600 Bd. Protokoll-Unterstützung EN 62056-21 (IEC1107), DLMS
(optional). -
@digitalnaive sagte in Adapter "smartmeter":
Optische Schnittstelle, Serielle Schnittstelle RS-485 bzw. RS-232 oder
M-Bus. Konfigurierbare Übertragungsgeschwindigkeit von 300 Bd
bis 9600 Bd. Protokoll-Unterstützung EN 62056-21 (IEC1107), DLMS
(optional).Hatte ich bereits ganz zu Anfang gepostet
-
@Homoran said in Adapter "smartmeter":
@digitalnaive sagte in Adapter "smartmeter":
Optische Schnittstelle, Serielle Schnittstelle RS-485 bzw. RS-232 oder
M-Bus. Konfigurierbare Übertragungsgeschwindigkeit von 300 Bd
bis 9600 Bd. Protokoll-Unterstützung EN 62056-21 (IEC1107), DLMS
(optional).Hatte ich bereits ganz zu Anfang gepostet
Sorry, habe ich in der Flut der Nachrichten übersehen. War keine Absicht.
-
Meine Kette? Das war eigentlich eine Frage an dich damit wir wissen was du gemacht hast.
Vielleicht postest du einfach das logfile von deinen Befehlen.
Hast du eigentlich den NUC mal neu gestartet und was ist mit meiner Frage nach Serialport ?
-
@wendy2702 said in Adapter "smartmeter":
Meine Kette? Das war eigentlich eine Frage an dich damit wir wissen was du gemacht hast.
Vielleicht postest du einfach das logfile von deinen Befehlen.
Hast du eigentlich den NUC mal neu gestartet und was ist mit meiner Frage nach Serialport ?
Mit deiner Kette meinte ich deinen Post darüber, in der du auf die Einhaltung des Ablaufes bzlg der Echo Befehle hingewiesen hast. Ich meinte damit nur, dass ich es exakt so der Abfolge umgesetzt hatte mit dem Ergebnis wie im Post von mir dann beschrieben.
Den Nuc habe ich schon mehrmals sicherheitshalber neugestartet. Meinst du mit deiner Frage nach dem Serial ob ich mal an einen anderen USB-Port gesteckt habe? Ja das hab ich gestern gemacht und anschließend den NUC neugestartet.
Mit dmesg | grep tty kommt folgende Info:
[ 0.000000] console [tty0] enabled [ 7.460689] usb 1-3: FTDI USB Serial Device converter now attached to ttyUSB0
-
was ergibt denn die Eingabe von
ls /dev/serial/by-id/
-
@Röstkartoffel said in Adapter "smartmeter":
ls /dev/serial/by-id/
usb-FTDI_FT230X_Basic_UART_DN068A03-if00-port0
-
so und nun wie @wendy2702 es gesagt hat (wie ich es verstanden habe):
Putty (SSH) zweimal öffnen.
im ersten Fenster das Kommandocat /dev/ttyUSB0
Und in dem zweiten Fenster das:
echo -n -e '\x2F\x3F\x21\x0D\x0A' > /dev/ttyUSB0
Beobachten was jetzt im ersten Fenster passiert
(sollte sowas wie "/PAF5EC3g00006" rauskommen)Nach 1 bis 2 sec. dann im zweiten Fenster
echo -n -e '\x06\x30\x30\x30\x0D\x0A' > /dev/ttyUSB0
Und wieder beobachten was jetzt im ersten Fenster passiert
(sollten jetzt ein paar Daten rauskommen) -
@Röstkartoffel said in Adapter "smartmeter":
echo -n -e '\x2F\x3F\x21\x0D\x0A' > /dev/ttyUSB0
Das habe ich ja leider bereits schonmal gemacht und bekomme folgende Meldung:
root@asrock:/home/digitalnaive# cat /dev/ttyUSB0 cat: /dev/ttyUSB0: Resource temporarily unavailable