- Beiträge: 1
Schreiben mit SQLServerAdapter sehr langsam
- Olaf Waltjen
- Autor
- Offline
- Benutzer
Weniger
Mehr
3 Jahre 2 Wochen her #4417
von Olaf Waltjen
Schreiben mit SQLServerAdapter sehr langsam - Beitrag(4417) wurde erstellt von Olaf Waltjen
Hallo,
wir haben einen FH-Job, der Daten aus einer Postgres-Datenbank in eine MSSQL-Datenbank übertragen soll (ca. 2 Mio Zeilen).
Die Versionen sind aktuell.
Dabei haben wir das Problem, dass der FH lediglich mit ca. 4 MBit/s in die Datenbank schreibt. Egal, ob im Batch-, Memory- oder MassData-Modus.
Das Lesen der Daten braucht ca 2-3 Minuten, das Schreiben dann mehr als 30 Minuten.
Mit welchen Einstellungen kann man die Übertragungsraten steigern?
Zum Vergleich: Der FlatFile-Import der gleichen Daten in die gleiche Tabelle mit dem SQL-Management-Studio läuft mit ca. 60 - 100 MBit/s und ist in ein paar Minuten fertig.
wir haben einen FH-Job, der Daten aus einer Postgres-Datenbank in eine MSSQL-Datenbank übertragen soll (ca. 2 Mio Zeilen).
Die Versionen sind aktuell.
Dabei haben wir das Problem, dass der FH lediglich mit ca. 4 MBit/s in die Datenbank schreibt. Egal, ob im Batch-, Memory- oder MassData-Modus.
Das Lesen der Daten braucht ca 2-3 Minuten, das Schreiben dann mehr als 30 Minuten.
Mit welchen Einstellungen kann man die Übertragungsraten steigern?
Zum Vergleich: Der FlatFile-Import der gleichen Daten in die gleiche Tabelle mit dem SQL-Management-Studio läuft mit ca. 60 - 100 MBit/s und ist in ein paar Minuten fertig.
Bitte Anmelden oder Registrieren um der Konversation beizutreten.
- FlowHeater-Team
- Offline
- Administrator
3 Jahre 2 Wochen her - 3 Jahre 2 Wochen her #4419
von FlowHeater-Team
gruß
Robert Stark
FlowHeater-Team antwortete auf Schreiben mit SQLServerAdapter sehr langsam - Beitrag(4419)
Hallo Herr Waltjen,
zuerst hätte ich da mal eine Frage. Wie importieren Sie denn die 2 Millionen Datensätze über das SQL Server Management Studio, verwenden Sie dafür einen „BULK INSERT“ oder den Wizard?
Wenn Sie „BULK INSERT“ würde mir das erklären warum es so schnell geht. Aus meiner Sicht sind 30 Minuten für 2 Millionen Datensätze gar nicht so schlecht. Aber optimieren kann man natürlich immer
Einmal sollten Sie bei nur INSERT Definitionen darauf achten, dass im SQL Server Adapter auf der WRITE Seite das auch so eingestellt ist bzw. hier UPDATEs nicht aktiviert sind. Wenn Sie hier nichts geändert haben sollte das passen, so sind jedenfalls die Standardeinstellungen bei einer Neuanlage einer Definition. Hintergrund: Sind in der Definition UPDATEs aktiviert, wird pro Datensatz geprüft ob der Datensatz bereist existiert und verlangsamt den Vorgang nochmal.
Dann kann über das Transaktionsverhalten auch nochmal optimiert werden. Hier wird in den Standardeinstellungen eine „Große“ Transaktion pro Verarbeitungsschritt verwendet. Manche Datenbanken performen mit solch „großen“ Transaktionen nicht ganz so optimal. Der SQL Server ist hier eigentlich klar im Vorteil und sollte keine Probleme haben. Sie können hier allerdings einmal probieren, nach ca. 10.000 – 50.000 geschriebenen Datensätzen einen „AutoCommit“ durchzuführen.
Oft ist allerdings auch die Netzwerk Anbindung ein Flaschenhals. Es ist ein Unterschied ob Sie z.B. mit dem SQL Server Management Studio direkt auf dem Server einen Import Job anstoßen und mit dem FlowHeater übers Netzwerk darauf zugreifen. Hier kommen bei solch großen Datenmengen über die Latenz schnell mal ein paar Minuten mehr zustande.
Daten nur anfügen
Transaktionsverhalten ändern
zuerst hätte ich da mal eine Frage. Wie importieren Sie denn die 2 Millionen Datensätze über das SQL Server Management Studio, verwenden Sie dafür einen „BULK INSERT“ oder den Wizard?
Wenn Sie „BULK INSERT“ würde mir das erklären warum es so schnell geht. Aus meiner Sicht sind 30 Minuten für 2 Millionen Datensätze gar nicht so schlecht. Aber optimieren kann man natürlich immer
Einmal sollten Sie bei nur INSERT Definitionen darauf achten, dass im SQL Server Adapter auf der WRITE Seite das auch so eingestellt ist bzw. hier UPDATEs nicht aktiviert sind. Wenn Sie hier nichts geändert haben sollte das passen, so sind jedenfalls die Standardeinstellungen bei einer Neuanlage einer Definition. Hintergrund: Sind in der Definition UPDATEs aktiviert, wird pro Datensatz geprüft ob der Datensatz bereist existiert und verlangsamt den Vorgang nochmal.
Dann kann über das Transaktionsverhalten auch nochmal optimiert werden. Hier wird in den Standardeinstellungen eine „Große“ Transaktion pro Verarbeitungsschritt verwendet. Manche Datenbanken performen mit solch „großen“ Transaktionen nicht ganz so optimal. Der SQL Server ist hier eigentlich klar im Vorteil und sollte keine Probleme haben. Sie können hier allerdings einmal probieren, nach ca. 10.000 – 50.000 geschriebenen Datensätzen einen „AutoCommit“ durchzuführen.
Oft ist allerdings auch die Netzwerk Anbindung ein Flaschenhals. Es ist ein Unterschied ob Sie z.B. mit dem SQL Server Management Studio direkt auf dem Server einen Import Job anstoßen und mit dem FlowHeater übers Netzwerk darauf zugreifen. Hier kommen bei solch großen Datenmengen über die Latenz schnell mal ein paar Minuten mehr zustande.
Daten nur anfügen
Transaktionsverhalten ändern
gruß
Robert Stark
Letzte Änderung: 3 Jahre 2 Wochen her von FlowHeater-Team.
Bitte Anmelden oder Registrieren um der Konversation beizutreten.
Ladezeit der Seite: 0.260 Sekunden