AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Firebird hängt beim disconnect
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird hängt beim disconnect

Offene Frage von "danielA"
Ein Thema von danielA · begonnen am 6. Mai 2004 · letzter Beitrag vom 29. Okt 2004
Antwort Antwort
Seite 1 von 2  1 2      
danielA

Registriert seit: 10. Jun 2002
Ort: Hamburg
72 Beiträge
 
Delphi XE7 Enterprise
 
#1

Firebird hängt beim disconnect

  Alt 6. Mai 2004, 11:23
Hallo erstmal.

Ich habe das Problem das Firebird (1.0.3) sich gelegentlich beim schließen meiner Anwendung aufhängt. Diese Anwendung nimmt die Datenbank notwendigerweise etwas härter ran. Das heißt es werden in einer Stored Proc momentan bis zu 5000 Datensätze in eine andere Tabelle kopiert (ist eine Meßreihe) um berechnungen in akzeptabler Zeit darauf ausführen zu können.
UDFs habe ich alle schon wieder rausgeschmissen, so daß es daran nicht liegen kann. In der Log des Firebird Servers taucht dann folgender Fehler auf

"INET/inet_error: read errno = 10054"

Das weißt laut IBPhoenix auf einen Netzwerkfehler hin aber auf Localhost ?
Habe das nun schon auf mehreren Rechnern ausprobiert auf jedem dieses Phänomen (übrigens auch mit IB 6.0.1). Sobald ich das Programm schließe bleibt das Programm beim Connected:=false in der OnClose, gelegentlich hängen. Transactionen wurden an diese Stelle alle schon beendet. CPU-Last 0%. Es kann dann bis zu 10 min dauern bis er sich gefangen hat, je nachdem wieviel ich berechnen lassen habe. Breche ich den Task meines Programmes hart ab hilft nur noch ein Neustart des Rechners. Kann es an den Standard Delphikomponenten liegen die für Interbase bei Delphi 6 dabei sind ? Ich arbeite auch fast ausschließlich mit CommitRetaining um die Transaktionen offen zu halten. Kann es vielleicht auch daran liegen ? Währe echt toll wenn mir hier jemand helfen könnte, habe echt keine Idee mehr.

Gruß Daniel
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.032 Beiträge
 
Delphi 12 Athens
 
#2

Re: Firebird hängt beim disconnect

  Alt 6. Mai 2004, 13:01
Moin, moin Daniel,

probier mals die Transaktion zu schließen. Kommt dann ein Fehler? Könne es sein, das Deine
Stored Procedure noch läuft oder das Ergebnis nicht gespeichert hat?
Dann dürfte die Transaktion nicht beendet werden können.

Die Delphi-Komponenten sind da eher unkritisch. Ebenso ZEOS, denn normnalerweise kann man
PDB-Programme damit spontan bbenden, wenn dabei die Database-Conntection gelöst wird.


Grüße // Martin
Martin Schaefer
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#3

Re: Firebird hängt beim disconnect

  Alt 6. Mai 2004, 13:04
Ich glaube kaum, daß der Rechner hängt, der wird nur unendlich langsam. Und zwar weil er 5000 Transaktionen rückwärts abarbeiten muß. Mache mal nach dedem 100. oder 500. ein Commit. Wetten, daß es dann geht ? Aber ohne Gewähr. 8)
Gruß
Hansa
  Mit Zitat antworten Zitat
danielA

Registriert seit: 10. Jun 2002
Ort: Hamburg
72 Beiträge
 
Delphi XE7 Enterprise
 
#4

Re: Firebird hängt beim disconnect

  Alt 6. Mai 2004, 14:00
Hallo,

erstmal danke für die schnellen antworten.
Also die Transaktionen sind wirklich alle beendet hier mal ein Teil aus der OnClose:

Delphi-Quellcode:

        ...
Dm1.IbTransaction1.Commit;
Dm1.IbTransaction1.Active:=false;
Dm1.IBDatabase1.Connected := False; // << und hier bleibt er dann hängen
        ...
Das mit dem Commit ist denke ich eine Gute Idee nur werden die Datensätze in einer Stored Proc auf einmal kopiert also in der Art:

Delphi-Quellcode:
For select ... do
Begin
  insert into ...
END
und Transaktionen kann man ja in Stored Procedures nicht beenden.
Da werde ich mich mal mit Limit, was ja für Firebird neu sein soll, auseinandersetzen müssen.

Gruß und Danke

Daniel
  Mit Zitat antworten Zitat
Udontknow

Registriert seit: 17. Jun 2002
223 Beiträge
 
#5

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 12:46
Was für eine Transaktions-Isolation nutzt du? Das kann sich u.U. auf die Performance auswirken.
Wechsel doch mal auf den FB 1.5! Hat sich schliesslich schon einiges getan...

Cu,
Udontknow
  Mit Zitat antworten Zitat
danielA

Registriert seit: 10. Jun 2002
Ort: Hamburg
72 Beiträge
 
Delphi XE7 Enterprise
 
#6

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 13:34
Hallo,

also meine Transaktionseigenschaft ist auf Schnappschuß (also concurrency nowait) eingestellt.
Habe meine Stored Proc mal so umgeschrieben, daß er nur 200 Datensätze kopiert und die letzte kopierte ID zurückgibt. Durch anschließendes Commit und erneutem Aufruf der Stored Proc erhoffe ich mir, daß es funzt. Hat beim ersten Test ebend leider noch nicht funktioniert. GFIX hat mir aber auch Indexfehler gemeldet in genau den Tabellen, welche von der Stored Proc angefaßt werden.
Firebird 1.5 habe ich vor der 1.0.3 schon ausprobiert aber da kamen immer Fehler wenn ich mehrere Select Statements kurz hintereinder aufgerufen habe in der ORDER BY Clausel. Wenn ich die Statements einzeln ausgeführt habe (aus meinem Programm) haben sie jedoch immer Funktioniert.

Gruß Daniel
  Mit Zitat antworten Zitat
Udontknow

Registriert seit: 17. Jun 2002
223 Beiträge
 
#7

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 13:49
Zitat von danielA:
Firebird 1.5 habe ich vor der 1.0.3 schon ausprobiert aber da kamen immer Fehler wenn ich mehrere Select Statements kurz hintereinder aufgerufen habe in der ORDER BY Clausel. Wenn ich die Statements einzeln ausgeführt habe (aus meinem Programm) haben sie jedoch immer Funktioniert.
Merkwürdig. An FB liegt das meiner Meinung nach nicht, bei uns in der Firma nutzen wir FB 1.5 mit relativ großen Datenbanken (>4 GB); so ein Fehler trat aber noch nie auf. Allerdings nutzen wir auch DBExpress.

Cu,
Udontknow
  Mit Zitat antworten Zitat
danielA

Registriert seit: 10. Jun 2002
Ort: Hamburg
72 Beiträge
 
Delphi XE7 Enterprise
 
#8

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 15:01
Habe die TIBQuery abgeleitet. Folgender Code funktioniert unter IB6 und Firebird 1.0.3. Bei Firebird 1.5 fliegt er an der markierten Stelle raus wenn
UseCountStatement True ist (und FDBType auf F_Interbase6 steht).
PS.: Ich weiß das das Countstatement bei Firebird nicht mehr notwendig ist da RecordCount richtig gesetzt wird. Leider ist das nur eine Stelle an der er mit dieser Fehlermeldung rausfliegt.

Delphi-Quellcode:
   
   ...
        Self.Active:=False;
        if (MyUseCountStatement) and (FDBType = F_Interbase6) then
        begin
          SQLKompo:=TIBQuery.Create(self);
          SQLTransaction:=TIBTransaction.Create(self);
          try
            SQLTransaction.DefaultDatabase:=Self.Database;
            SQLKompo.Database:=Self.Database;
            SQLKompo.Transaction:=SQLTransaction;
            if not SQLKompo.Transaction.InTransaction then
               SQLKompo.Transaction.StartTransaction;
            SQLKompo.SQL.Text:=CountStatement;
            SQLKompo.Prepare;
            SQLKompo.Active:=True;
            FRecordCount:=SQLKompo.fieldbyname('ANZAHL').AsInteger;
            SQLKompo.Transaction.Rollback;
            SQLKompo.Active:=False;
          finally
            SQLKompo.Free;
            SQLTransaction.Free;
          end;
        end;
        Self.SQL.Clear;
        Self.SQL.Add(Statement);
        Self.Prepare;
        Self.Active:=True; // <== und hier fliegt er dann raus
   ...
Gruß Daniel
  Mit Zitat antworten Zitat
Udontknow

Registriert seit: 17. Jun 2002
223 Beiträge
 
#9

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 16:08
Was für eine Fehlermeldung erhälst du denn genau?

Cu,
Udontknow
  Mit Zitat antworten Zitat
danielA

Registriert seit: 10. Jun 2002
Ort: Hamburg
72 Beiträge
 
Delphi XE7 Enterprise
 
#10

Re: Firebird hängt beim disconnect

  Alt 7. Mai 2004, 18:40
Hallo nochmal,

komme leider erst MMontag wieder an meine Quellen ran aber er meckert dann über das ORDER BY.
Nehme ich das ORDER BY raus funktioniert es wieder.

Gruß Daniel
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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:08 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