AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Delphi Indy TCP: Was ist ein Scheduler?
Thema durchsuchen
Ansicht
Themen-Optionen

Indy TCP: Was ist ein Scheduler?

Ein Thema von Stefan Hueg · begonnen am 26. Nov 2006 · letzter Beitrag vom 26. Nov 2006
Antwort Antwort
Benutzerbild von Stefan Hueg
Stefan Hueg

Registriert seit: 13. Jun 2004
Ort: Gießen
187 Beiträge
 
Delphi 2006 Professional
 
#1

Indy TCP: Was ist ein Scheduler?

  Alt 26. Nov 2006, 00:50
Eine weitere Frage die sich mir stellte und die in der Hilfe auch recht verwirrend beantwortet wird.

Es gibt eine Property namens "Scheduler" bei der Indy TCP Server Komponente. Nur was genau ist das?

Viele Grüße,

Stefan
Stefan Hueg
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#2

Re: Indy TCP: Was ist ein Scheduler?

  Alt 26. Nov 2006, 10:31
Zitat von Stefan Hueg:
Es gibt eine Property namens "Scheduler" bei der Indy TCP Server Komponente. Nur was genau ist das?
HI,
soetwas wie einen Scheduler findest du häufiger dort, wo parallel mehrere Prozesse laufen. Das einfachste Beispiel wäre hier so ziemlich jedes (große) Betriebssystem, insbesondere natürlich solche mit grafischer Oberfläche. Hier besitzt das Betriebssystem als einzigstes den Zugriff auf die CPU. Der Scheduler weißt nun allen aktiven Prozessen Rechenzeit zu und da man i.d.R. weniger Prozessorkerne als laufende Prozesse hat, verteilt der Scheduler somit die tatsächliche Rechenzeit auf transparent auf die laufenden Prozesse. Diese merken das natürlich nicht.
Wichtig ist dabei, dass der Scheduler hier auch Prioritäten setzen kann. Es gibt gewisse Prozesse, die sollten nie warten und immer sofort ausgeführt werden, andere können ohne Probleme zurückgestellt werden. Im besten Fall wird die CPU optimal genutzt und der Benutzer merkt gar nichts vom Scheduler (ausser das alles läuft).

Bei einem Server hat man wiederum ein ähnliches Problem, es können quasi-parallel Anfragen eintreffen. Natürlich wird hier kein Server eine Anfrage komplett abarbeiten und erst dann die nächste Anfrage annehmen. Vielmehr wird auch hier versucht die Anfragen parallel abzuarbeiten. Würde man hier für jede Anfrage einen eigenen Systemprozess verwenden, dürfte klar sein dass hier schnell eine Unmenge solcher Prozesse existiert. Die Synchronisation und die Prioritäten nun vom OS verwalten zu lassen kann dabei dann ganz schön viel Zeit kosten. Vorallem ist man auch auf die vom OS zur Verfügung gestellten Möglichkeiten beschränkt. Hier kann es durchaus sein, dass man mehr Prioritätsstufen unterscheiden möchte, dass man Ack-Pakete immer so schnell wie möglich verschicken möchte usw.
Deswegen bietet Indy einfach die Möglichkeit die Jobs durch einen eigenen Scheduler zu verwalten. Der Scheduler bekommt dabei vom OS Rechenzeit und verteilt diese auf die aktiven Indy Jobs. Intern wird dann z.B. beim Threadbasierten Scheduler ein Threadpool verwendet. Das ist dann einfach eine Menge von Threads, die frühzeitig erzeugt und gespeichert werden. Nur diese Threads arbeiten Jobs ab. Das heißt, dass man nicht für jede Anfrage einen eigenen Thread bereitstellen muss, was zwei Vorteile mit sich bringt:
  1. Der Thread muss nicht erzeugt werden, spart eine Menge an Zeit!
  2. Dadurch dass die Anzahl der Threads begrenzt ist, kommt es hier nicht zu einer totalen Auslastung des OS für die Verwaltung der Threads (jeder Thread würde nur minimale Rechenzeit bekommen und ewig brauchen bis er fertig ist)

Ich hoffe die Idee ist grob (und weniger wirr als in der Hilfe) klar geworden.

Gruß Der Unwissende
  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 02:32 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