AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FB wird immer langsamer und MON$ATTACHMENTS immer länger
Thema durchsuchen
Ansicht
Themen-Optionen

FB wird immer langsamer und MON$ATTACHMENTS immer länger

Ein Thema von Iwo Asnet · begonnen am 19. Okt 2011 · letzter Beitrag vom 20. Okt 2011
Antwort Antwort
Iwo Asnet

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

FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 19. Okt 2011, 16:21
Datenbank: Firebird • Version: 2.1 • Zugriff über: IBExpress
Hi,

Ich habe hier das Problem, das eine DB über die Tage hin immer langsamer wird und ich weiss einfach nicht, wieso. Die Tabelle MON$TRANSACTIONS enthält drei Einträge, das passt auch.

Ich bin echt ratlos. Das Einzige, was mir auffällt, ist, das die Tabelle MON$ATTACHMENTS von Firebird immer länger wird. Bei den Einträgen ist fast überall MON$STATE=0. Sie kommen fast alle von einer Applikation

Wenn ich fbServer.EXE abschieße, dann startet der sofort neu. Anschließend ist alles wieder in Butter. Bis in 1-3 Wochen der gleiche Scheiss wieder auftritt.

Hat Jemand eine Idee?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 19. Okt 2011, 16:25
Die Verbindungen scheinen nicht richtig geschlossen zu werden. Werden Verbindungsprobleme gelogt? Wann/wie werden Verbindungen im Programm aufgebaut?
Markus Kinzler
  Mit Zitat antworten Zitat
Iwo Asnet

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

AW: FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 19. Okt 2011, 16:29
hi,

Ok ok... Da kommen wir der Sache näher...
Wäre das denn etwas, was FB in die Knie zwingt?

Verbindungsprobleme werden nicht geloggt.

Ich habe eine Job-Queue implementiert. Die Jobs werden nacheinander, schön sequentiell, ausgeführt.
Wenn ein Job ausgeführt wird, fordere ich eine Connection (TIBDatabase-Objekt) aus einem Pool an.
Dann starte ich die Transaktion, führe das Zeugs aus, commite und gib dem Connectionpool die connection wieder zurück.

Hier das Create und das Dispose. Die Connection bleibt aber am Leben, d.h. i.d.R. wird eine Connection erzeugt und erst bei Programmenende per Dispose wieder weggeschmissen.
Delphi-Quellcode:
function TConnectionPool.CreateConnection: TIBDatabase;
begin
  Result := TIBDatabase.Create(nil);
  Result.DatabaseName := fDatabaseName;
  Result.Params.Clear;
  Result.Params.Add('user_name=sysdba');
  Result.Params.Add('password=xxxxx');
  Result.LoginPrompt := False;
  Result.DefaultTransaction := TIBTransaction.Create(nil);
  Result.Connected := True;
end;
...
procedure TConnectionPool.DisposeConnection(aConnection: TIBDatabase);
begin
  fPendingConnections.Remove(aConnection);
  aConnection.Connected := False;
  aConnection.DefaultTransaction.Free;
  aConnection.DefaultTransaction := nil;
  aConnection.Free;
end;
Mir scheint aber, das hier etwas anderes vorliegt. Ich habe 3 Jobs pro Sekunde und mittlerweile 237 Einträge in dieser MON$ATTACHMENTS-Tabelle. Alle 236 haben den gleichen Zeitstempel.

Geändert von Iwo Asnet (19. Okt 2011 um 16:45 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von chaosben
chaosben

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

AW: FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 19. Okt 2011, 17:29
Jetzt wäre noch die Stelle interessant, an der entschieden wird, ob einen neue Verbindung nötig ist.
Ich vermute mal, es werden immer wieder neue Verbindungen aufgemacht und die bestehenden nicht weiterverwendet.
Benjamin Schwarze
If I have seen further it is by standing on the shoulders of Giants. (Isaac Newton)
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 19. Okt 2011, 19:58
Hallo,

ich würde mal per FastMM4 prüfen,
ob wirklich alles freigegeben wird.
In deinem Pool-Create vermisse ich z.B.
einen Verweis auf das pendingXXX


Heiko
Heiko
  Mit Zitat antworten Zitat
tsteinmaurer

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

AW: FB wird immer langsamer und MON$ATTACHMENTS immer länger

  Alt 20. Okt 2011, 08:37
Wenn die Anzahl der Connections nicht abnimmt, dann stimmt was mit einer Connection-Pool Implementierung nicht.
  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 03:49 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