AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Delphi Probleme mit Indy (IdHTTP)
Thema durchsuchen
Ansicht
Themen-Optionen

Probleme mit Indy (IdHTTP)

Ein Thema von endeffects · begonnen am 23. Jun 2005 · letzter Beitrag vom 24. Jun 2005
Antwort Antwort
Seite 1 von 2  1 2      
endeffects

Registriert seit: 27. Jun 2004
450 Beiträge
 
#1

Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 21:27
Hallo,

ich habe die Indy Komponenten in meinen Threads global deklariert und
rufe in der Exceute Methode eine Funktion auf die die Indys
initialisiert und nach dem Durchlauf wieder frei gibt.
Wärend die Methode Lunch() durchläuft werden verschiedene Get und Post Request
getätigt, leider kommt es hier immer wieder dazu das die Threads einfrieren
bzw eine lange Zeit überhaupt nichts machen.
Genau das kann ich mir allerdings nicht erklären, der Timeout für einen
Verbindungsaufbau liegt bei 10s und sollte der String aus den Methoden
Get() und Post() nicht die gesuchten Wörter enthalten müßte der nächste
Request aus der Methode Lunch() abgearbeitet werden.

Ich bin ein wenig ratlos, weiß vielleicht Jemand woran das liegt?

PS: SmartPos ist lediglich eine schnellere Variante der Pos() Methode


Delphi-Quellcode:
function TMyThreads.Lunch: Boolean;
...
begin
  Result:= False;
//init components
  IdHTTP:= TIdHTTP.Create(nil);
  IdCookieManager:= TIdCookieManager.Create(nil);
  PostDataStream := TStringStream.Create('');
  ParamData := TStringStream.Create('');
//settings
  IdHTTP.AllowCookies:= True;
  IdHTTP.CookieManager:= IdCookieManager;
  IdHTTP.HandleRedirects:= True;
  IdHTTP.Request.ContentType:= 'application/x-www-form-urlencoded';
  IdHTTP.Request.Connection:= 'Keep-Alive';
  IdHTTP.ConnectTimeout:= 10000;
  IdHTTP.Request.UserAgent:= '..';

  Source:= '';
  Source:= Get('...');
  if SmartPos('...', Source, False, 1, True) > 0 then
  begin
    Source:= '';
    Source:= Get('...');
    if SmartPos('...', Source, False, 1, True) > 0 then
    begin
      ...
    end;
  end;
  
  Source:= '';
  Source:= Get('...');
  if SmartPos('...', Source, False, 1, True) > 0 then
  begin
    Source:= '';
    Source:= Get('...');
    if SmartPos('...', Source, False, 1, True) > 0 then
    begin
      ...
    end;
  end;

  Source:= '';
  Source:= Get('...');
  if SmartPos('...', Source, False, 1, True) > 0 then
  begin
    Source:= '';
    Source:= Get('...');
    if SmartPos('...', Source, False, 1, True) > 0 then
    begin
      ...
    end;
  end;

 ...// usw


  FreeAndNil(ParamData);
  FreeAndNil(PostDataStream);
  FreeAndNil(IdCookieManager);
  FreeAndNil(IdHTTP);
  Result:= True;
end;

function TMyThreads.Get(Url: String): String;
begin
  try
    Result:= IdHTTP.Get(Url);
  except
    FStatus:= 'error';
    Synchronize(UpdateLVCaption);
    Result:= '';
  end;
end;

function TMyThreads.Post(Url, Params: String): String;
begin
  ParamData.WriteString(Params);
  try
    IdHTTP.Post(Url, ParamData, PostDataStream);
    Result:= PostDataStream.DataString;
  except
    FStatus:= 'error';
    Synchronize(UpdateLVCaption);
    Result:= '';
  end;
  ParamData.Size:= 0;
  PostDataStream.Size:= 0;
end;
  Mit Zitat antworten Zitat
Benutzerbild von Sanchez
Sanchez

Registriert seit: 24. Apr 2003
Ort: Neumarkt Stmk
892 Beiträge
 
Delphi XE6 Enterprise
 
#2

Re: Indy und Threads

  Alt 23. Jun 2005, 21:37
Hallo,
Heißt das du lässt mehrere Threads auf die selbe idHttp-Instanz zugreifen?
Wenn ja, das wird so nicht gehen.

Ist TMyThreads ein Nachfahre von TThread?
Was steht denn in der Execute-Routine? Zeig die am Besten her.

grüße, daniel
Daniel
Testen ist feige!
  Mit Zitat antworten Zitat
endeffects

Registriert seit: 27. Jun 2004
450 Beiträge
 
#3

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 21:44
also jeder thread erzeugt seine eigene instanz von idhttp
die execute methode sieht wie folgt aus:


type
TMyThreads = class(TThread)
....
Delphi-Quellcode:
procedure TMyThreads.Execute;
begin
  while not Terminated do
  begin
    if WaitForSingleObject(WorkPool.Semaphore, INFINITE) = WAIT_OBJECT_0 then
    begin
      Job:= WorkPool.GetNextJob;
      if Job<>szNoJobAvail then
      begin
        while Lunch = false do
          Application.ProcessMessages;
      end;
    end;
  end;
end;
ich denke aber das es irgendwo an den methoden get() und post() hängen muss,
denn sobald die methode lunch() gestartet wurde muss diese auch durchlaufen
werden, nur wird der durchlauf irgendwo ausgebremst
  Mit Zitat antworten Zitat
Benutzerbild von Sanchez
Sanchez

Registriert seit: 24. Apr 2003
Ort: Neumarkt Stmk
892 Beiträge
 
Delphi XE6 Enterprise
 
#4

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:10
Auf alle Fälle ist das Application.ProcessMessages mal sinnlos. Das bremst den Thread nur unnötig ein.
Wenn er etwas warten soll, dann solltest du Sleep verwenden.
Das ist aber nicht der Grund fürs Einfrieren.

Wartet der Thread eventuell beim WaitForSingleObject?
Daniel
Testen ist feige!
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:16
Das jeder Thread seine eigene Instanz erzeugt ist klar, die frage ist ob du die ganzen instanzen auf die gleiche Variable (globale?) zuweist oder ob es eine variable aus dem private/public/protected des Threads ist
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
endeffects

Registriert seit: 27. Jun 2004
450 Beiträge
 
#6

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:17
wenn ich an dieser stelle sleep() verwende
dann steht der thread komplett still
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#7

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:19
Zitat von endeffects:
wenn ich an dieser stelle sleep() verwende
dann steht der thread komplett still
Ja - und ? Es ist doch nicht der mainthread, also macht das doch nichts ...

Müsstest du eigendlich ganz weglassen können ....
  Mit Zitat antworten Zitat
endeffects

Registriert seit: 27. Jun 2004
450 Beiträge
 
#8

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:31
ich denke das spielt in dem zusammenhang nun keine große rolle,
das eigentliche problem besteht weiterhin, sofern die methode
lunch() die arbeit aufnimmt dann kommt es immer mal wieder vor
das die geschichte irgendwo hängen bleibt

der einzigste grund der mir dazu einfallen würde ist das einer
der server immer mal wieder lagged, aber sollte das so sein
würden die indys dann nicht irgendwann den request abbrechen
und wenn nein, wie geht man damit am besten um
(und bricht selbst ab)
  Mit Zitat antworten Zitat
Benutzerbild von Dani
Dani

Registriert seit: 19. Jan 2003
732 Beiträge
 
Turbo Delphi für Win32
 
#9

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 22:51
Hi, kann es sein, dass unter bestimmten Umständen Lunch() niemals true zurückliefert? Ist da irgendwo ein exit drin? Warum erstellst du mit jedem Aufruf von Lunch (Launch?) neue Instanzen, dafür gibt es doch Kontruktor und Desktruktor!?
Dani H.
At Least I Can Say I Tried
  Mit Zitat antworten Zitat
endeffects

Registriert seit: 27. Jun 2004
450 Beiträge
 
#10

Re: Probleme mit Indy (IdHTTP)

  Alt 23. Jun 2005, 23:06
welche umstände sollten das sein?
IdHttp.Post und IdHttp.Get hab ich in die
Methoden Get() und Post() ausgelagert, die
Rückgabewerte beider Methoden werden in
jedem Fall übergeben und den
Durchlauf der Methode lunch() habe ich
weiter oben beschrieben, die dann zum ende
auch Result:= True; gesetzt wird

das der gesamte aufbau an sich sicher nicht
der beste ist ist mir durchaus klar, da gibt
es sicher eine smartere lösung

trotzdem ist mir nicht klar warum der durchlauf
anfängt zu hängen
  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 20:30 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