Einzelnen Beitrag anzeigen

Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#1

MyDAC im Thread = "Net packets out of order"

  Alt 14. Jun 2019, 18:12
Datenbank: MariaDB • Version: n/a • Zugriff über: MyDAC
Hallo!

Ich verzweifle grad an einem Fehler. Wir haben in der Vergangenheit jahrelang ohne Probleme unter D2007 mit UniDAC Threads programmiert, die im Hintergrund regelmäßig ein paar SELECTs ausführen. Jetzt bin ich auf D10.2.3 umgestiegen, wofür wir uns eine entsprechende Version von MyDAC gekauft haben (wir haben nie mehr als diesen Teil der Suite gebraucht, also dieses Mal die kleine Version).

Folgendes Szenario:
Delphi-Quellcode:
type
  TUpdateDataThread = class(TThread)
  private
  protected
    procedure Execute; override;
  public
    FDBInfo: TDBInfo;
  end;

  TSomeClass = class
  // bla
  end;

implementation

procedure TSomeClass.InitThread;
begin
  UpdateThread := TUpdateDataThread.Create(True);
  UpdateThread.FDBInfo := self.DBInfo:
  UpdateThread.Start;
end;

procedure TUpdateDataThread.Execute;
var
  con: TMyConnection;
  qry: TMyQuery;
begin
  inherited;
  con := TMyConnection.Create(nil);
  con.Server := FDBInfo.DBServerName;
  con.Username := FDBInfo.DBUserName;
  con.Password := FDBInfo.DBPassword;
  con.Port := FDBInfo.DBPort;
  con.Database := FDBInfo.DBCatalog;
  con.LoginPrompt := False;
  qry := TMyQuery.Create(nil);
  qry.Connection := con;
  repeat
    try
      CSMasterData.Enter;
      if not con.Connected then con.Connect;
      qry.SQL.Text := 'SELECT foo FROM bar WHERE flump';
      qry.Open;
      while not qry.Eof do
      begin
        // Daten in ein Dictionary packen
        qry.Next;
      end;
      qry.Close;
      end;
    finally
      CSMasterData.Leave;
      Sleep(1000);
    end;
  until Terminated;
  qry.Free;
  con.Free;
end;
Die Connection wird im Thread.Execute erstellt und auch ausschließlich dort genutzt. Das ist definitiv sicher - ist immerhin eine lokale Variable. Dieses Vorgehen setzen wir seit Jahren ohne Probleme unter D2007 ein, and zig Stellen in zig Programmen die seit Jahren 24/7 am Stück laufen. Jetzt unter D10.2.3 mit dem neuen MyDAC bekomme ich sporadisch, und auf unterschiedlichen Rechnern unterschiedlich oft (auf manchen auch fast gar nicht) folgende Fehlermeldungen:

Zitat:
---------------------------
Fehler
---------------------------
ReceiveHeader: Net packets out of order: received[XXX], expected[1].
---------------------------
OK
---------------------------
Wobei das "XXX" irgend eine Zahl ist. Zwischen 0 und 200 habe ich praktisch schon alles gesehen. Sämtliche alte Einträge im Devart Forum beziehen sich auf Nutzung in Threads bei denen die Connection im falschen Kontext erstellt wird. Aber genau das mache ich ja nicht - würde ich mal denken.

Ich komme nicht mehr weiter. Ich habe schon anonyme Threads versucht, abgeleitete wie hier als Beispiel gezeigt, die Connection innerhalb des repeat-until erstellen und wieder freigeben (mit pooling in dem Fall) - nichts. Immer derselbe Effekt. Fällt euch noch was blödes auf?
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat