NEWS
Proxmox / Influxdb V1 zu V2... wie?
-
@rene55 https://docs.influxdata.com/influxdb/v2.4/upgrade/v1-to-v2/manual-upgrade/
Wer mit Google translate Probleme hat vielleicht mal deepl.com probieren.
-
@wendy2702 Danke. Deepl ist eh mein Freund - ohne ist manchmal schwierig.
-
Irgendwo muß du bei Proxmox ja einen Speicher/Storage eingestellt haben.
Bei mir ist das ein ein NFS Link auf mein NAS:
Unter dem erstellten Storage, wo du im Conent auch ISO bzw Container Template angeben kannst, kannst du dann dann ein LXC template runterladen. z.B., Debian 11
Damit kannst du dann Container bemäß einem Template einrichten.
Was du da nimmst ist mal dir überlassen.
Für meine Grafana und InfluxDB LXCs sieh meine Config so aus:
Beides sind Debian 11 basierte LXC.
Eventuell sollte der Beitrag raus hier und in einen eigenen fred, da nicht direkt was mit dem Wetterstation-Script zu tun hat. Vielleicht kann das einer der moderatoren behben?
-
-
@ilovegym thnx! allerdings hat heute @haus-automatisierung genau dazu auch ein video rausgebracht.
hat mir schon mal geholfen. werd mir aber deinen link sicher beguxxen! -
@tritor passend zum thema hat heute @haus-automatisierung ein video rausgebracht.
https://www.youtube.com/watch?v=p6XmgzhH0Ow
nebenbei gibts da einen netten link...
https://tteck.github.io/Proxmox/ -
@meister-mopper sagte in Proxmox / Influxdb V1 zu V2... wie?:
Ich habe es mit dieser Anleitung nach dessen YT-Video mehrfach getan, und es ging immer gut aus.
Gibt's das auch für docker Container, vorzugsweise unter Qnap?
Mir ist alles recht, upgrade auf 2.x, bzw. eine Neuinstallation von 2.x mit Datenmigration von 1.8 -
@Rene55 ...ich mach mal hier weiter.
Ich bin ja der absolute Docker-Guru
Aber Spaß beiseite, ev. muss der Influx-Aufruf auch mittels "docker exec..." erfolgen. Ich kann bei mir problemlos die Ausgabe mittels ">" in eine Datei umleiten. -
@sborg Hi, danke dass du für mich weiter getestet hast. Ich bin heute vormittag auf den grünen Zweig gestoßen. Machdem mich ja gestern fasst alle Versionen mit Fehlern beglückt haben und alle "Anleitungen" an sich aus seriösen Quellen stammte, musste der Fehler bei mir liegen. So war es denn auch. Ich hatte gestern alle Versuche
IN
der Influxdb gemacht, heute ausserhalb.
Und schon funktioniert der Befehlinflux -username dbuser -password xxyyzz123 -database iobroker -host localhost -execute 'SELECT * FROM "0_userdata.0.Wetterstation.Aussentemperatur"' -format csv -precision='rfc3339'> ./temperatur.csv
und exportiert mir die Daten, so wie ich es wollte. Danke an alle für die Unterstützung, Links, etc. und wollte meinen Erfolg auch hier kurz mitteilen. -
@tritor sagte in Proxmox / Influxdb V1 zu V2... wie?:
Eventuell sollte der Beitrag raus hier und in einen eigenen fred, da nicht direkt was mit dem Wetterstation-Script zu tun hat.
gute idea! das könnte ja @Negalein schnitzen.
thnx für deine tips. hab bis jetzt nur mit VMs gewerkelt... -
@da_woody sagte in Proxmox / Influxdb V1 zu V2... wie?:
gute idea! das könnte ja @Negalein schnitzen.
schau auf die Überschrift.
hat @wendy2702 schon erledigt. -
@negalein hrnz, bissl chaotisch in den letzten tagen...
mea culpa. -
Funktioniert bestens: Teil-Export von 1.8 --> 2.6.1
Vor dem Import (ich logge schon 2 Tage per Influx-Adapter):
Nach dem Import:
Bevor ich dann wieder die Syntax selbst vergesse, man kann auch den Zeitraum bei der Abfrage eingrenzen. ZB. auf die letzten 7 Tage
'SELECT * FROM "javascript.0.Wetterstation.Aussentemperatur" WHERE time>=now()-7d'
Man kann also ohne Datenverlust umziehen oder migrieren (was ich wg. ev. Altlasten bei mir nicht tun werde = tabula rasa)
-
@sborg sagte in Proxmox / Influxdb V1 zu V2... wie?:
Man kann also ohne Datenverlust umziehen oder migrieren (was ich wg. ev. Altlasten bei mir nicht tun werde = tabula rasa)
Ich stoppe vor dem Umzug zuerst den Influx Adapter, stell im Adapter auf V2, ziehe mit den Daten um und starte dann wieder den Adapter?
Laufen dann die Dashboard normal weiter, oder müssen die noch speziell auf V2 angepasst werden?
-
@negalein Jupp, wenn du mit einer InfluxDB arbeitest. Ich fahre zu Beginn lieber mal Zweigleisig, man weiß ja nie. Außerdem will ich die Influx auch von meinem NUC weg haben, deswegen läuft sie zuerst parallel auf meiner Synology im Docker, später nur noch dort.
Laufen dann die Dashboard normal weiter, oder müssen die noch speziell auf V2 angepasst werden?
Jein. Wenn du in der alten SQL-Sprache weitermachst läuft alles 1:1. Nutzt du die moderne, neuere Flux, musst du auch alle Dashboards/Widgets umstellen...
-
@sborg sagte in Proxmox / Influxdb V1 zu V2... wie?:
wenn du mit einer InfluxDB arbeitest.
hab gerade InfluxDB V2 installiert.
also auch Zweigleisig.Dann mach in ioB eine 2. Influx-Instanz, die ich für V2 verwende. Und dann zieh ich um?
Beide Instanzen trotzdem derweil stoppen? -
@negalein sagte in Proxmox / Influxdb V1 zu V2... wie?:
Und dann zieh ich um?
Damit würde ich aktuell noch warten, außer du willst Skript und Statistik von Hand ändern. Die können ja mit Influx V2 so noch nichts anfangen. Du kannst aber bedenkenlos beide parallel laufen lassen. Es macht auch überhaupt nichts aus wenn du Werte von der V1 in die V2 umziehst die dort schon existieren. Da sie den selben Zeitstempel haben werden sie einfach mit dem selben Inhalt überschrieben.
Oder du ziehst halt um, belässt Wetter so in der V1 und loggst das aber jetzt schon in die V2. Dann stellst du noch die restlichen Werte was du sonst noch loggst auf die V2 um. Kommt dann meine V3 brauchst du nur in der *.conf den Influx-Zugang ändern und kannst die V1 abschalten.
Anhalten brauchst du nichts. Das kann alles im laufenden Betrieb geschehen. Wenn du direkt beides loggst verlierst du nicht mal paar Datensätze (siehe paar Zeilen weiter oben). -
@sborg sagte in Proxmox / Influxdb V1 zu V2... wie?:
Oder du ziehst halt um, belässt Wetter so in der V1 und loggst das aber jetzt schon in die V2. Dann stellst du noch die restlichen Werte was du sonst noch loggst auf die V2 um. Kommt dann meine V3 brauchst du nur in der *.conf den Influx-Zugang ändern und kannst die V1 abschalten.
so werde ich es machen.
Steh aber gerade komplett an.
Influx 1 ist auf Host A
Influx 2 ist auf Host BDiese Anleitung ist für ein Upgrade auf 1 Host.
Ich finde nichts, wie ich die Daten von A nach B bringe und sie dann in Influx 2 übernommen werden.
-
@sborg said in Proxmox / Influxdb V1 zu V2... wie?:
Bevor ich dann wieder die Syntax selbst vergesse, man kann auch den Zeitraum bei der Abfrage eingrenzen. ZB. auf die letzten 7 Tage 'SELECT * FROM "javascript.0.Wetterstation.Aussentemperatur" WHERE time>=now()-7d'
Man kann also ohne Datenverlust umziehen oder migrieren (was ich wg. ev. Altlasten bei mir nicht tun werde = tabula rasa)@sborg Mit welchen Flags hast du exportiert?
ich habe mal testweise den schon genannten
influx -username dbuser -password xxyyzz123 -database iobroker -host localhost -execute 'SELECT * FROM "0_userdata.0.Wetterstation.Aussentemperatur"' -format csv -precision='rfc3339'> ./temperatur.csv
benutzt
und musste dann wegen Fehlermeldung bei importieren über das WebIF, den Umweg über die Console machen, wo ich die Spalten definieren musste, weil er mit dem Export-Headername,time,ack,from,q,value
nix anfangen konnte
influx write -b iobroker -f ./temperatur.csv --skipHeader=1 --header="name|measurement,time|dateTime:RFC3339,ack|boolean,from|string,q|double,value|double"
Ist auch für dich @Negalein
Auf Console Host 1 exportieren:influx -username dbuser -password xxyyzz123 -database iobroker -host localhost -execute 'SELECT * FROM "0_userdata.0.Wetterstation.Aussentemperatur"' -format csv -precision='rfc3339'> ./temperatur.csv
File von Host 1auf Host 2
Dann importieren:
influx write -b iobroker -f ./temperatur.csv --skipHeader=1 --header="name|measurement,time|dateTime:RFC3339,ack|boolean,from|string,q|double,value|double"
(Hier für die Aussentemperatur)
Aber er meckerte bei mir rum, weil er die Spalten
name,time,ack,from,q,value 0_userdata.0.Wetterstation.Aussentemperatur,2022-01-31T00:00:29.043Z,false,system.adapter.simple-api.0,0,-1.88
nicht richtig erkennt (er kann mit name nix anfangen), deswegen den Zusatz
--header="name|measurement,time|dateTime:RFC3339,ack|boolean,from|string,q|double,value|double"
um zu definieren, was was in welchem Format (z.B. ack|bool) ist.
-
Ich bin ja bekennender "Faullist"
Auf Quellhost im Verzeichnis stehend was auch der Zielhost lesen kann:
- Datei export.csv mit folgendem Inhalt angelegt
#datatype measurement,dateTime:RFC3339,boolean,string,double,double
- danach jeweils ausgeführt [xxx] jeweils passend ersetzt; ohne die []:
influx -database [DB-Name] -username [name] -password [passwort] -execute 'SELECT * FROM "javascript.0.Wetterstation.Aussentemperatur"' -format csv -precision='rfc3339' >> export.csv influx -database [DB-Name] -username [name] -password [passwort] -execute 'SELECT * FROM "javascript.0.Wetterstation.Wind_max"' -format csv -precision='rfc3339' >> export.csv influx -database [DB-Name] -username [name] -password [passwort] -execute 'SELECT * FROM "javascript.0.Wetterstation.Regen_Tag"' -format csv -precision='rfc3339' >> export.csv
Ergebnis für 4 Jahre Daten: ca. 200MB - Datei
Dauer bis hierhin < 1 Minute
Zielhost, im Verzeichnis stehend wo der Export statt fand
influx write -b [bucketname] -f export.csv
Das hat nun etwa 3-4 Minuten gedauert und 3 Fehlerhafte Datensätze zu Tage gebracht --> Fertig
- Datei export.csv mit folgendem Inhalt angelegt