Ahoj, liebe Gemeinde
Derzeit muß ich einen Cache entwickeln, der per
TCP mit clients kommuniziert. Er soll aus einer
DB nur die Daten laden, die sich verändert haben usw....
Die erste Testanwendung habe ich mit Datasnap und einer TSocketConnection gemacht: Für ca. 5.5MB Daten verbrät das Teil 1600ms (ca. 3.4MB/sec). Ups, dachte ich mir geht das nicht schneller? (ich hab ein 100mb Netz, und Dateien kopieren kann ich mit 8MB/sec). Also Mal die Indies angeschaut, is ja simpel, einen TCPServer in den Cache-Manager, einen
TCP-Client in den Test-Client und ab gehts..
... Denkste. Genauso 'schnell'.
So sieht der Code aus.
Delphi-Quellcode:
Procedure TfmMain.TCPSvrExecute(AThread: TIdPeerThread);
Var
sQuery, sResponse : String;
Begin
With AThread.Connection Do Begin
sQuery := ReadLn;
LoadData (sQuery, sResponse);
c := GetTickCount;
WriteLn(sResponse);
lbInfo.caption := IntToStr(GetTickCount - c)+' Tics'; // <--- Zeigt 40ms
Disconnect;
End;
End;
Und im Client (Button-Ereignis)
Delphi-Quellcode:
Procedure TForm6.btTCPClick(Sender: TObject);
Var
sResponse, sQuery : WideString;
c: Cardinal;
Begin
c := GetTickCount;
sQuery := 'Auftragsdaten';
With TCPClnt Do Begin
Try
Connect;
WriteLn(sQuery);
c := GetTickCount;
sResponse := ReadLn;
lbInfo.Caption := IntToStr(GetTickCount - c) + ' tics';// <-- 1670 Tics
Finally
Disconnect;
End;
End;
End
Sind da die Indies an ihren Grenzen oder kann man irgendwo etwas tunen?
Danke im Voraus.