NEWS
History2DB converter
-
Keine Besserung, identisches Verhalten:
c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node history2db.js sql.0 debug 20170202 "c:\history" Send Data to sql.0 Start at 20170202 Use historyDir c:\history 2017-02-13 22:22:27.651 - debug: history.20170202 objectDB connected 2017-02-13 22:22:27.713 - debug: history.20170202 statesDB connected 2017-02-13 22:22:27.839 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 No stored earliesDBValues found No stored existingDBTypes found started processFiles with 0 known db values We start earliest at 20170202 Day 20170202 - history.hm-rega.0.10529.json datapoints reduced from 1 --> 1 Data stored but dbDB not available anymore, break. DONE
2.Durchlauf
c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node history2db.js sql.0 debug 20170202 "c:\history" Send Data to sql.0 Start at 20170202 Use historyDir c:\history 2017-02-13 22:26:47.355 - debug: history.20170202 objectDB connected 2017-02-13 22:26:47.386 - debug: history.20170202 statesDB connected 2017-02-13 22:26:47.433 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 No stored earliesDBValues found No stored existingDBTypes found started processFiles with 0 known db values We start earliest at 20170202 Day 20170202 - history.hm-rega.0.10529.json datapoints reduced from 1 --> 1 2017-02-13 22:28:18.915 - warn: history.0 Reconnection to DB. 2017-02-13 22:28:18.931 - warn: history.0 Reconnection to DB. Invalid call DONE
Evtl. war das der Grund weshalb bei meiner ersten Fehlermeldung auch der invalid call aufgetaucht ist
-
Versuch mal den laufenden history.0 auszuschalten und starte dann das Skript. Nicht das sich zwei laufende "history.0" (weil das Skript registriert sich quasi auch als "history.0" in die quere kommen …
Und zusätzlich hab ich non nen Fehler gefunden (Gründe für die "DB ist weg"-Meldung in deinem ersten Lauf von oben).
Bitte SQL vom Github aktualisieren. Dann sollte der Fehler weg sein. Nach github update neustart der sqlInstanz nicht vergessen.
Dann bitte nochmal logs
-
Leider ohne Erfolg (history.0 ausgeschaltet)
C:\Program Files\ioBroker>node node_modules/iobroker.js-controller/iobroker.js stop Stopping iobroker controller daemon... iobroker controller daemon stopped. C:\Program Files\ioBroker>npm i https://github.com/ioBroker/ioBroker.sql/tarball/master - > sqlite3@3.1.7 install C:\Program Files\ioBroker\node_modules\iobroker.sql\node_modules\sqlite3 > node-pre-gyp install --fallback-to-build [sqlite3] Success: "C:\Program Files\ioBroker\node_modules\iobroker.sql\node_modules\sqlite3\lib\binding\node-v46-win32-ia32\node_sqlite3.node" is installed via remote iobroker.sql@1.4.3 node_modules\iobroker.sql ├── mysql@2.13.0 (sqlstring@2.2.0, bignumber.js@3.1.2, readable-stream@1.1.14) ├── sql-client@0.7.0 (argf@0.0.1, inote-util@0.8.1) ├── pg@6.1.2 (packet-reader@0.2.0, pg-connection-string@0.1.3, buffer-writer@1.0.1, semver@4.3.2, pg-types@1.11.0, pg-pool@1.6.0, pgpass@1.0.1) ├── mssql@3.3.0 (generic-pool@2.5.4, promise@7.1.1, tedious@1.14.0) └── sqlite3@3.1.7 (nan@2.4.0) C:\Program Files\ioBroker>iobroker start C:\Program Files\ioBroker>node node_modules/iobroker.js-controller/iobroker.js start Starting iobroker controller daemon... c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node history2db.js sql.0 debug 20170202 "c:\history" Send Data to sql.0 Start at 20170202 Use historyDir c:\history 2017-02-14 20:49:09.831 - debug: history.20170202 objectDB connected 2017-02-14 20:49:09.847 - debug: history.20170202 statesDB connected 2017-02-14 20:49:09.878 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 No stored earliesDBValues found No stored existingDBTypes found started processFiles with 0 known db values We start earliest at 20170202 Day 20170202 - history.hm-rega.0.10529.json datapoints reduced from 1 --> 1 Data stored but dbDB not available anymore, break. DONE
-
Ok, bitte jetzt auch history vom Github aktualisieren, auch Debug drin. Jetzt bin ich gespannt was rauskommt
-
Ok, bitte jetzt auch history vom Github aktualisieren, auch Debug drin. Jetzt bin ich gespannt was rauskommt `
Ergebnis:
c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node history2db.js sql.0 debug 20170202 "c:\history" Send Data to sql.0 Start at 20170202 Use historyDir c:\history 2017-02-14 21:47:29.548 - debug: history.20170202 objectDB connected 2017-02-14 21:47:29.580 - debug: history.20170202 statesDB connected 2017-02-14 21:47:29.611 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 No stored earliesDBValues found No stored existingDBTypes found started processFiles with 0 known db values We start earliest at 20170202 Day 20170202 - history.hm-rega.0.10529.json datapoints reduced from 1 --> 1 Data stored but db not available anymore, break. {"success":true} DONE
Bis auf das {"success":true} gibt es anscheinend keine Änderung
-
Grrrrrrrrrr… der Push der Änderung von sql hatte nicht geklappt ... jetzt aber. Bitte neu sql installieren, dann sollte es laufen oder sinnvolle ausgaben geben
-
Grrrrrrrrrr… der Push der Änderung von sql hatte nicht geklappt ... jetzt aber. Bitte neu sql installieren, dann sollte es laufen oder sinnvolle ausgaben geben `
Das erklärt meine Aussage, dass sich nichts geändert hat zwischen meinem Rechner und der github-VersionJetzt passiert mehr bei der Ausgabe und er läuft aktuell immer noch, allerdings wird laut Ausgabe nahezu alles ignoriert. Ab und zu wird ein Datenpunkt am Tag übernommen:````
Day 20170122 - history.yr.0.forecast.day2.temperature_min.json
Ignore ID history.yr.0.forecast.day2.temperature_min.json: yr.0.forecast.day2.temperature_min
Day 20170122 - history.yr.0.forecast.day2.text.json
Ignore ID history.yr.0.forecast.day2.text.json: yr.0.forecast.day2.text
Day 20170122 - history.yr.0.forecast.day2.wind_direction.json
Ignore ID history.yr.0.forecast.day2.wind_direction.json: yr.0.forecast.day2.wind_direction
Day 20170122 - history.yr.0.forecast.day2.wind_speed.json
Ignore ID history.yr.0.forecast.day2.wind_speed.json: yr.0.forecast.day2.wind_speed
Day 20170122 - history.yr.0.forecast.diagram.json
Ignore ID history.yr.0.forecast.diagram.json: yr.0.forecast.diagram
Day 20170122 - history.yr.0.forecast.html.json
Ignore ID history.yr.0.forecast.html.json: yr.0.forecast.html
Day 20170122 - history.yr.0.forecast.object.json
Ignore ID history.yr.0.forecast.object.json: yr.0.forecast.object
Day end
Day 20170121 - history.admin.0.info.updatesList.json
Ignore ID history.admin.0.info.updatesList.json: admin.0.info.updatesList
Day 20170121 - history.admin.0.info.updatesNumber.json
Ignore ID history.admin.0.info.updatesNumber.json: admin.0.info.updatesNumber
Day 20170121 - history.dwd.0.warning.begin.json
Ignore ID history.dwd.0.warning.begin.json: dwd.0.warning.begin
Day 20170121 - history.dwd.0.warning.description.json
Ignore ID history.dwd.0.warning.description.json: dwd.0.warning.description
Day 20170121 - history.dwd.0.warning.end.json
Ignore ID history.dwd.0.warning.end.json: dwd.0.warning.end
Day 20170121 - history.dwd.0.warning.headline.json
Ignore ID history.dwd.0.warning.headline.json: dwd.0.warning.headline -
Jetzt kommen wir zu den zusätzlichen Parametern
Entweder du lässt vorher "analyzesql.js" laufen damit alle aktuell in sql existierenden Datenpunkt-IDs gesammelt werden und auch nur die konvertiert werden.
Alternativ –ignoreExistingDBValues setzen beim import-Skript dann sollte das egal sein und alles wird konvertiert - aber dann musst DU beim abbrechen aufpassen das du nicht doubletten erzeugst!
-
Jetzt kommen wir zu den zusätzlichen Parametern
Entweder du lässt vorher "analyzesql.js" laufen damit alle aktuell in sql existierenden Datenpunkt-IDs gesammelt werden und auch nur die konvertiert werden.
Alternativ –ignoreExistingDBValues setzen beim import-Skript dann sollte das egal sein und alles wird konvertiert - aber dann musst DU beim abbrechen aufpassen das du nicht doubletten erzeugst! `
Ich bin davon ausgegangen, dass ohne die zusätzlichen Parameter die Dubletten vermieden werden und er alle Datenpunkte übernimmt.
Das passt aber nicht mit dem ignore, dass aktuell protokolliert wird, überein, da er jetzt sehr viele Datenpunkte übernehmen müsste oder verstehe ich da etwas falsch. "analyzesql.js" hatte bei mir bisher eine nahezu leere Datei erzeugt und –simulate protokolliert ja, dass Daten übernommen werden können. Bin etwas ratlos.
-
Aaaaalso … die Idee war das man nur das nach sql konvertieren will was man auch mit sql loggt. Daher gibt es diese "analyze"-Skripte. Die suchen aus der sql-DB alle Datenpunkte raus die geloggt werden und speichert diese quasi in einer "white-list" für das Konverterskript weil dann auch nur die genommen werden.
Daher auch der Effekt, wenn Du ohne dieses analyze und daher mit leerem "welche Datenpunkte gibt es denn"-File den konverter startest, das alles ignoriert wird.
"--ignoreExistingDBValues" sagt dem Skript das er genau diese Whitelist ignorieren soll. Damit nimmt er dann alles was im History gefunden wurde egal ob es schon in sql da ist oder nicht.
Daher wenn es immer noch komisch ist: Was ist denn der Output vom analyze-Skript?
-
Daher wenn es immer noch komisch ist: Was ist denn der Output vom analyze-Skript? `
Ergebnis mit gestopptem history.0, damals lief history.0 noch. Ergebnis ist aber identisch:c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node analyzesql.js Query Data from sql.0 2017-02-15 08:03:11.425 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 Send {"succes":true,"result":{"undefined":{"type":"undefined","ts":1970000}}} Datapoints found: undefined {"undefined":{"type":"undefined","ts":1970000}}
Ergebnis earliestDBValues.json````
{"undefined":1487142206553}Ergebnis existingDBTypes.json```` {}
-
Was sagt denn das iobroker.Log von sql.0 zu dein zeitunkt? Da sollt auch was geloggt werden. Und schau bitte das sql auf loglevel "info" steht das Du diese Logs siehst.
Query result <json>Nochmal zur Klarstellung: sql.0 läuft und es sind Datenpunkte definiert die da hin loggen?!</json>
-
Was sagt denn das iobroker.Log von sql.0 zu dein zeitunkt? Da sollt auch was geloggt werden. Und schau bitte das sql auf loglevel "info" steht das Du diese Logs siehst.
Query result <json>Nochmal zur Klarstellung: sql.0 läuft und es sind Datenpunkte definiert die da hin loggen?!</json> `
sql.0 läuft und es sind Datenpunkte definiert. Über die Adminoberfläche wurde das logging für sql.0 und history.0 identisch eingestellt, alle Datenpunkte loggen. Ich habe auch ein flot Diagramm auf sql.0 umgestellt und dort werden die Kurven korrekt angezeigt, daher sollten die Werte im sql.0 vorhanden sein.log zum Zeitpunkt der Analyse (history.0 gestoppt)
<code>2017-02-17 23:37:54.844 - [31merror[39m: WARNING: cannot find logs with id = 96467210 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467638 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467639 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467640 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467641 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467642 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467643 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467644 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467645 2017-02-17 23:37:55.782 - [31merror[39m: WARNING: cannot find logs with id = 96467646 2017-02-17 23:37:55.797 - [31merror[39m: WARNING: cannot find logs with id = 96467647 2017-02-17 23:37:55.797 - [31merror[39m: WARNING: cannot find logs with id = 96467648 2017-02-17 23:37:55.797 - [31merror[39m: WARNING: cannot find logs with id = 96467649[/code]</code>
-
Während der Analyse oder auch beim History-Übertragen kann es zu solchen Logs kommen. Da kommt ein Log-Teilprozess nicht hinterher. Gefühlt nicht so schlimm.
Hat deine sql-Instanz Loglevel info?
-
Als ich mit iobroker angefangen hab, hat bei mir die Übernahme von history nach sql auch nicht geklappt.
Hab dann mit diesem flow improvisiert. Man muss vorher schon den sql adapter einschalten, damit er
die DP's anlegt.
! [
! {
! "id": "361523f4.0693fc",
! "type": "tab",
! "label": "Sql import historic data"
! },
! {
! "id": "54117af8.894304",
! "type": "file in",
! "z": "361523f4.0693fc",
! "name": "",
! "filename": "/opt/iobroker/iobroker-data/history/20170106/history.admin.0.ws333.Temp3.json",
! "format": "utf8",
! "x": 459,
! "y": 95,
! "wires": [
! [
! "ade70e93.59ded"
! ]
! ]
! },
! {
! "id": "42a18a7e.9e2744",
! "type": "debug",
! "z": "361523f4.0693fc",
! "name": "",
! "active": true,
! "console": "false",
! "complete": "true",
! "x": 1240,
! "y": 331,
! "wires": []
! },
! {
! "id": "ade70e93.59ded",
! "type": "json",
! "z": "361523f4.0693fc",
! "name": "",
! "x": 818,
! "y": 171,
! "wires": [
! [
! "2005b14d.5c492e"
! ]
! ]
! },
! {
! "id": "2005b14d.5c492e",
! "type": "function",
! "z": "361523f4.0693fc",
! "name": "Add timestamp",
! "func": "//var dp = msg.filename.match(/[-\w]+[.][\w]+$/i)[0]\nvar dp = msg.filename.match(/^.\/(.)\.(.*)$/i)[1]\n\nvar ma = []\n\nfor (i=0; i<msg.payload.length; ++i)/{\n/ma.push({topic:"insert/into/ts_number/set/id
="(select" id/from/iobroker.datapoints/where/type="0" and/name=""+ dp +"" )/,/ts
=""" +/msg.payload<i="">[i].ts + ",val
=" + msg.payload__.val + ",ack
=0,_from
=2,q
=" + msg.payload__.q, payload: ""})\n ma.push({topic:"insert into ts_string setid
=(select id from iobroker.datapoints where type = 1 and name = '"+ dp +"') ,ts
=" + msg.payload__.ts + ",val
=" + msg.payload__.val + ",ack
=0,_from
=2,q
=" + msg.payload__.q, payload: ""})\n ma.push({topic:"insert into ts_bool setid
=(select id from iobroker.datapoints where type = 2 and name = '"+ dp +"') ,ts
=" + msg.payload__.ts + ",val
=" + msg.payload__.val + ",ack
=0,_from
=2,q
=" + msg.payload__.q, payload: ""})\n}\nreturn [ma];",
! "outputs": "1",
! "noerr": 0,
! "x": 962,
! "y": 223,
! "wires": [
! [
! "6d4c858b.8562cc"
! ]
! ]
! },
! {
! "id": "6d4c858b.8562cc",
! "type": "mysql",
! "z": "361523f4.0693fc",
! "mydb": "c5d28ccd.2882a",
! "name": "",
! "x": 1102,
! "y": 286,
! "wires": [
! [
! "42a18a7e.9e2744"
! ]
! ]
! },
! {
! "id": "8b3dd54e.fdff98",
! "type": "inject",
! "z": "361523f4.0693fc",
! "name": "",
! "topic": "",
! "payload": "",
! "payloadType": "date",
! "repeat": "",
! "crontab": "",
! "once": false,
! "x": 93,
! "y": 36,
! "wires": [
! [
! "54117af8.894304"
! ]
! ]
! },
! {
! "id": "c5d28ccd.2882a",
! "type": "MySQLdatabase",
! "z": "",
! "host": "big",
! "port": "3306",
! "db": "iobroker",
! "tz": ""
! }
! ]_______________</msg.payload.length;> 1803_clipboard05.jpg -
Während der Analyse oder auch beim History-Übertragen kann es zu solchen Logs kommen. Da kommt ein Log-Teilprozess nicht hinterher. Gefühlt nicht so schlimm.
Hat deine sql-Instanz Loglevel info? `
Ja, hatte Loglevel Info. Ich habe Dir gerade per PN das Logging mit Level Debug zugesendet, vielleicht kannst Du damit mehr anfangen.
Ich habe mal in der sql-DB nachgesehen und die kennt ca. 500 Datenpunkte die auch vom Namen her gut aussehen, d.h. sehen so aus wie in admin bzw. die history-Dateinamen
-
Als ich mit iobroker angefangen hab, hat bei mir die Übernahme von history nach sql auch nicht geklappt.
Hab dann mit diesem flow improvisiert. Man muss vorher schon den sql adapter einschalten, damit er
die DP's anlegt. `
Was macht man mit den Infos im spoiler text? Wo muss ich das importieren? -
Wo muss ich das importieren? ` im adapter node-red. Wenn du 500 DP's importieren willst, muss man noch 2 nodes dranmachen um über das Verzeichnis zu wandern.
-
Während der Analyse oder auch beim History-Übertragen kann es zu solchen Logs kommen. Da kommt ein Log-Teilprozess nicht hinterher. Gefühlt nicht so schlimm.
Hat deine sql-Instanz Loglevel info? `
Ja, hatte Loglevel Info. Ich habe Dir gerade per PN das Logging mit Level Debug zugesendet, vielleicht kannst Du damit mehr anfangen.
Ich habe mal in der sql-DB nachgesehen und die kennt ca. 500 Datenpunkte die auch vom Namen her gut aussehen, d.h. sehen so aus wie in admin bzw. die history-Dateinamen `
Hallo apollon77, danke für die Rückmeldung per PN. Deine neue Version 1.4.5 erzeugt jetzt vernünftige Ergebnisse bei analyze.js. Allerdings scheint die Übertragung mit history2db.js weiterhin nicht zu laufen:
c:\Program Files\ioBroker\node_modules\iobroker.history\converter>node history2db.js sql.0 debug Send Data to sql.0 Use historyDir c:\Program Files\ioBroker\iobroker-data\history-data 2017-02-18 20:46:28.224 - debug: history.0 objectDB connected 2017-02-18 20:46:28.255 - debug: history.0 statesDB connected 2017-02-18 20:46:28.333 - info: history.0 starting. Version 1.5.2 in c:/Program Files/ioBroker/node_modules/iobroker.history, node: v4.6.2 EarliesDBValues initialized from cache 667 ExistingDBTypes initialized from cache 720 started processFiles with 667 known db values We start earliest at 20170218 DONE
-
Da fehlen Parameter! Da muss noch Das Datum und vor allem der Pfad dran!
node history2db.js sql.0 debug 20170218<pfad></pfad>