<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Three-Level-Scheduling</id>
	<title>Three-Level-Scheduling - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Three-Level-Scheduling"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Three-Level-Scheduling&amp;action=history"/>
	<updated>2026-05-22T13:56:04Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Three-Level-Scheduling&amp;diff=904648&amp;oldid=prev</id>
		<title>imported&gt;Invisigoth67: BKL aufgelöst; form</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Three-Level-Scheduling&amp;diff=904648&amp;oldid=prev"/>
		<updated>2023-04-11T12:58:45Z</updated>

		<summary type="html">&lt;p&gt;BKL aufgelöst; form&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;Three-Level-Scheduling&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;TLS&amp;#039;&amp;#039;&amp;#039;) unterteilt den [[Scheduling]]-Prozess in 3 Teilprozesse:&lt;br /&gt;
* Admission Scheduler&lt;br /&gt;
* Memory Scheduler&lt;br /&gt;
* CPU Scheduler&lt;br /&gt;
&lt;br /&gt;
[[Datei:TLS_Schema2.JPG|mini|Three Level Scheduling]]&lt;br /&gt;
&lt;br /&gt;
Am Beginn dieses Schedulingverfahrens steht ein [[Warteschlange (Datenstruktur)|Input Queue]]. Dabei handelt es sich lediglich um eine Datenstruktur ähnlich einer [[Datenstruktur#Grundlegende Datenstrukturen|Liste]], in der die neu ankommenden „Jobs“ zwischengespeichert werden. &lt;br /&gt;
&lt;br /&gt;
Nun kommt der &amp;#039;&amp;#039;Admission Scheduler&amp;#039;&amp;#039; (in der Folge AS genannt) ins Spiel. Der AS entscheidet, welcher Job ins weitere System (genauer gesagt in den Speicher) kommt. Die anderen Jobs verbleiben im Input Queue. Grundsätzlich wird versucht, einen guten Mix aus [[Compute-Bound]] Jobs (meist lange Abarbeitezeit) und [[Eingabe und Ausgabe|I/O]]-Bound Jobs (Input/Output – kurze Abarbeitezeit) zu finden und/oder kürzere Jobs längeren vorzuziehen. Der Admission Scheduler kann dabei auch Jobs, die später hinzutreten, denen im Input Queue vorziehen. Man kann den AS also als Vorfilter betrachten. &lt;br /&gt;
&lt;br /&gt;
Vom Admission Scheduler werden die Jobs dann weiter in den [[Arbeitsspeicher]] geladen. Hier beginnt nun die Arbeit des &amp;#039;&amp;#039;Memory Schedulers&amp;#039;&amp;#039;. Da jeder Job im Speicher Platz benötigt und es durchaus vorkommen kann, dass mehrere Jobs im Speicher vorhanden sind, entscheidet der Memory Scheduler, welcher Job im Hauptspeicher verbleibt und welcher auf die Festplatte ausgelagert wird ([[Swapping|Swap]]). Dabei wird das „Degree of Multiprogramming“ herangezogen, um zu entscheiden, wie viele Jobs im Hauptspeicher belassen werden. Das „Degree of Multiprogramming“ beschreibt die Anzahl von Prozessen, die ein Prozessor, abhängig von Hauptspeicherauslastung und Prozessorgeschwindigkeit, effizient verarbeiten kann. Wird auf eine Ressource von mehreren Prozessen gemeinsam zugegriffen, so kann dies das „Degree of Multiprogramming“ beeinflussen. Um eine optimale [[Performance (Informatik)|Performance]] zu gewährleisten, muss regelmäßig entschieden werden, wie viele Jobs im Speicher abgelegt werden. Es wird versucht, eine möglichst hohe CPU-Auslastung zu erreichen, wobei der Rest auf die Festplatte ausgelagert wird. Das Ein-/Auslagern ist teuer, da es vermehrt Systemressourcen beansprucht und Festplattenzugriffe verhältnismäßig langsam sind.&lt;br /&gt;
Kriterien des Ein-/Auslagerns:&lt;br /&gt;
* Wie lange ist es her, dass der Job auf die Festplatte ausgelagert wurde?&lt;br /&gt;
* Wie viel CPU-Zeit hat der Job kürzlich erhalten?&lt;br /&gt;
* Wie groß ist der Job? (kleinere Jobs werden überhaupt nicht ausgelagert, da Auslagern teuer ist)&lt;br /&gt;
* Wie wichtig ist der Job?&lt;br /&gt;
&lt;br /&gt;
Der &amp;#039;&amp;#039;CPU Scheduler&amp;#039;&amp;#039; entnimmt nun aus dem Speicher einen Job und arbeitet diesen ab (bzw. arbeitet weiter daran). Hierzu wird ein [[Prozess-Scheduler#Scheduling-Verfahren|Scheduling-Verfahren]] (meist [[Shortest-Job-Next]]) verwendet.&lt;br /&gt;
&lt;br /&gt;
== Quellen ==&lt;br /&gt;
* Andrew S. Tanenbaum: &amp;#039;&amp;#039;Modern Operating Systems - Second Edition&amp;#039;&amp;#039; ISBN 0-13-092641-8&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Betriebssystemtheorie]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Invisigoth67</name></author>
	</entry>
</feed>