AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken [FB 2.1] Wieso 'pumpt' die Datenbank?
Thema durchsuchen
Ansicht
Themen-Optionen

[FB 2.1] Wieso 'pumpt' die Datenbank?

Ein Thema von Iwo Asnet · begonnen am 22. Aug 2011 · letzter Beitrag vom 22. Aug 2011
Antwort Antwort
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#1

[FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 09:29
Datenbank: Firebird • Version: 2.1 • Zugriff über: egal
Hallo,

Ich habe hier eine DB-Anwendung die kontinuierlich Daten in eine FB-Datenbank einfügt (3x pro Sekunde). Die Daten sind mit einem Zeitstempel versehen und Daten, die älter als 20 Tage sind, fliegen raus. Der Lösch-Job wird 1x pro Stunde angestoßen.

Das Einfügen passiert mit einem einfachen INSERT-Befehl


Offene Transaktionen habe ich keine (also Transaktionen, die ich vergessen habe, zu schließen)

Wenn ich den PC starte, dann liegt die CPU-Belastung konstant bei 0-3%
Nach 2 Wochen sehe ich periodisch, also so ca. alle 5-15 Sekunden, einen 'peak', der bis 80% hochgeht. Das ist an sich nicht beunruhigend (hab ja 4 Kerne), aber zwei Fragen hab ich trotzdem:

1. Woran könnte das liegen? Fehlt vielleicht sowas wie ein CHECKPOINT, FLUSH o.ä.?
2. Wird das schlimmer? (Ok, die Frage ist rethorisch da die Glasskugeln alle sind)

Danke im Voraus für Denkanstöße und Ideen...
Miniaturansicht angehängter Grafiken
taskmanager.jpg  
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: [FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 09:41
Da FB ohne Transaktionslog auskommt, gibt es keine Checkpoints.
Es könnte isch aber um eine Bereinigung im Hintergrund handeln (SWEEP)
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von chaosben
chaosben

Registriert seit: 27. Apr 2005
Ort: Görlitz
1.358 Beiträge
 
Delphi XE2 Professional
 
#3

AW: [FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 09:53
... wobei es ein absoluter Sonderfall sein müsste, bei dem man das Sweep-Intervall auf ~30 (10 Sekunden * 3 Transaktionen pro Sekunde) setzt.
Benjamin Schwarze
If I have seen further it is by standing on the shoulders of Giants. (Isaac Newton)

Geändert von chaosben (22. Aug 2011 um 09:56 Uhr)
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#4

AW: [FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 10:04
Hallo,

und "Danke" für die Antworten.
Wo stellt man das SWEEP-Interval ein?
  Mit Zitat antworten Zitat
Benutzerbild von chaosben
chaosben

Registriert seit: 27. Apr 2005
Ort: Görlitz
1.358 Beiträge
 
Delphi XE2 Professional
 
#5

AW: [FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 10:30
Das wird direkt in der DB konfiguriert. Entweder mittels gfix oder per gutem Tool ... z.B. IBExpert
Benjamin Schwarze
If I have seen further it is by standing on the shoulders of Giants. (Isaac Newton)
  Mit Zitat antworten Zitat
tsteinmaurer

Registriert seit: 8. Sep 2008
Ort: Linz, Österreich
530 Beiträge
 
#6

AW: [FB 2.1] Wieso 'pumpt' die Datenbank?

  Alt 22. Aug 2011, 12:25
Vermutlich nicht Sweep, sondern Garbage Collection. Abhänging von der Firebird Architekturen und Konfigurationsparameter entweder durch einen Hintergrund-Thread oder im Kontext von SQL Anweisungen.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:58 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz