Wissensdatenbank Wirtschaftsrecht

aktuelles Dokument: BSys03ProzesseThreads
image4
image3
image2
image1
 Alle Kategorien:
  Forschungsdatenbank
  Lehrveranstaltungen
  Lexikon
  Literatur
  Rechtsgebiete
  Rechtsprechung
  Service
  Studium F H S
  Wissensmanagement
ich war hier: BSys03ProzesseThreads

Revision history for BSys03ProzesseThreads


Revision [83408]

Last edited on 2017-08-29 15:17:15 by ClaudiaMichel
Additions:
CategoryBSys
Deletions:
CategoryBetriebssysteme


Revision [83222]

Edited on 2017-08-16 14:30:56 by ClaudiaMichel
Additions:
CategoryBetriebssysteme
Deletions:
CategoryDelete


Revision [72172]

Edited on 2016-09-27 12:54:25 by NicoleHennemann
Additions:
CategoryDelete
Deletions:
CategoryBSys


Revision [22405]

Edited on 2013-03-26 15:55:13 by RonnyGertler
Additions:
Kapitel 3 - Prozesse und Threads======
Deletions:
Kapitel 3 - 3. Prozesse und Threads======


Revision [22403]

Edited on 2013-03-26 15:52:33 by RonnyGertler
Additions:
{{image url="BSys13.gif"}}
{{image url="BSys14.gif"}}
Deletions:
{{image class="left" url="BSys13.gif"}}
{{image class="left" url="BSys14.gif"}}


Revision [22402]

Edited on 2013-03-26 15:51:51 by RonnyGertler
Additions:
3) Threads sind nicht voneinander geschützt und müssen durch Programmierer synchronisiert werden.
===Multi-Threading===
Multi-Threading ist eine Betriebsart mit mehreren Thread pro Prozess.
Beispiele:

<b>Single-Thread-
Systeme </b>
<b>Multi-Thread-
Systeme </b>
<b>Ein -Prozess-
System </b>
MS-DOS
Java-Runtime-System,
z.B. JDK-Version 1.6
<b>Multitasking</b>
Ältere UNIX-
Varianten
Windows XP, Solaris,
Modernes UNIX
===Thread-Formen===
1) Kernel-Level-Threads (KL-Threads) werden vom Betriebssystem verwaltet.
2) User-Level-Threads (UL-Threads, Benutzer-Threads) werden vom Prozess verwaltet. Die Existenz von UL-Threads ist dem Betriebssystem nicht bekannt.
a) Vorteil: Die UL-Threads können schneller umgeschaltet werden. Bei der Zeitmessung für ein VAX-UNIX-System haben sich z.B. folgende Verhältnisse ergeben: ULTh / KLTh / Prozesse = 1 / 10 / 40.
b) Nachteil: Wenn ein UL-Thread blockeit wird (z.B. wegen I/O), dann sind alle UL-Threads des Prozesses auch blockiert.
c) Beispiel: Fibers von Windows.
===Java-Threads ===
1) Java ist eine Multithreading -Sprache.
2) Java-Threads erhalten der CPU durch die JVM zugeteilt.
JVM (Java Virtual Maschine) ist das Laufzeitsystem für
Java-Programme.
3)Formen der Java-Threads:
a)UL-Threads, (Green Threads), z.B. JDK-Version 1.2 für Linux,
b)KL-Threads, (native Threads), z.B. Windows NT/2000/XP.
⇒Demo 6
⇒Demo 7


Revision [22400]

Edited on 2013-03-26 15:46:57 by RonnyGertler
Additions:
{{image class="left" url="BSys13.gif"}}
{{image class="left" url="BSys14.gif"}}
===Beispiel===
Ein Textsystem (z.B. Microsoft Word) lässt sich effizient mittels vier Threads parallelisieren:
1) Text eingeben,
2) Rechtschreibung prüfen ,
3) Zeilen-/Seitenumbruch gestalten,
4) periodisch Sicherheitskopie auf der Platte anlegen.

Alle vier Vorgänge arbeiten mit einem Textdokument gemeinsam.
===Thread-Modell===
1) Ein Thread ist eine Ausführung eines Programmteils.
2) Jeder Thread gehört zu einem bestimmten Prozess.
3) Jeder Prozess enthält implizit mindestens einen Thread.
4) Jeder Prozess kann beliebig viele Threads generieren.
5) Alle Threads eines Prozesses können parallel (pseudoparallel) ausgeführt werden.

6) Thread besitzt Zustände (aktiv, rechenbereit, blockiert).
7) Thread besitzt einen eigenen Registersatz und eigenen Stack.
8) Alle Threads eines Prozesses haben eine gemeinsame Prozessumgebung, z.B. gleicher Adressraum, gleiche geöffnete Dateien usw.
9) Jeder Thread ist gegenüber anderen Threads dieses Prozesses nicht geschützt.
===Trennung von Ressourcenverwaltung und Prozessorverwaltung===
Die Ressourcen werden zwischen dem Prozess und den Threads aufgeteilt:
1) Ein Prozess besitzt alle Ressourcen außer Register und Stack.
2) Jeder Thread besitzt einen eigenen Registersatz und eigenen Stack. Die CPU wird nicht dem Prozess sondern den Threads zugeteilt.
3) Prozess besitzt die Ressourcen, Thread führt den Code aus.
===TCB===
Ein Thread-Kontext wird im so genannten Thread-Controll-Block (TCB) zusammengestellt:
1) Thread-Identification,
2) Thread-Zustand (aktiv, rechenbereit, blockiert),
3) Priorität für das Scheduling,
4) Register-Inhalte,
5) Zeiger auf PCB, usw.
Ein PCB enthält dann keine Register-Inhalte und wird entsprechend reduziert.
===Erzeugung und Terminierung des Threads===
1) Wird ein Prozess erzeugt, so stellt dieser eine Ausführungsumgebung für Threads zur Verfügung. Der Code des Prozesses wird durch einen Thread (primary thread) ausgeführt, der automatisch zusammen mit dem Prozess erzeugt wird.
Jeder Thread kann weitere Threads erzeugen, die zum gleichen Prozess gehören.
2) Jeder Thread kann sich selbst beenden oder von anderem Thread terminiert werden. Wird primary thread terminiert, wird gesamter Prozess beendet.
Bei der Prozessterminierung werden alle seine Threads auch terminiert.
""⇒"" Demo 4.
""⇒"" Demo 5.
===Vorteile und Nachteile von Threads===
1) Erzeugen, Terminieren, Kommunikation, Kontextwechsel von Threads sind wesentlich schneller als bei Prozessen. Daher kommt der Begriff Leichtgewichtige-Prozesse.
2) Besoders oft findet der Kontextwechsel statt. Ein Thread-Kontextwechsel ist ungefähr 100-mal schneller als ein Prozess-Kontextwechsel.
""<table class="data" width="80%">
<tr>
<td>
<b>Schritte beim Kontextwechsel </b>
</td>
<td>
<b>Prozesswechsel</b>
</td>
<td>
<b>Threadwechsel</b>
</td>
</tr>
<tr>
<td>
<b>TCB austauschen </b>
</td>
<td>
+
</td>
<td>
+
</td>
</tr>
<tr>
<td>
<b>Speicherverwaltungstabelle ändern </b>
</td>
<td>
+
</td>
<td>
-
</td>
</tr>
<tr>
<td>
<b>Speicherbereiche ersetzen</b>
</td>
<td>
+
</td>
<td>
-
</td>
</tr>
<tr>
<td>
<b>Entleeren und Neuladen des Cache</b>
</td>
<td>
+
</td>
<td>
-
</td>
</tr>
</table>""
Deletions:
{{image class="center" url="BSys13.gif"}}
{{image class="center" url="BSys14.gif"}}


Revision [22399]

Edited on 2013-03-26 15:39:24 by RonnyGertler
Additions:
Es gibt folgende Übergänge zwischen den Zuständen im Grundmodell:
(1) Blockierung. Der aktive Prozess gibt die CPU frei, da er auf ein Ereignis wartet, z.B. auf eine Eingabe. Der Prozess wird blockiert.
(2) Verdrängung (Deaktivieren, Preemption, Vorrangunterbrechung). Dem aktiven Prozess wird die CPU entzogen, z.B. nach dem Interrupt vom Timer.
(3) Zuteilung (Aktivieren). Dem Prozess wird die CPU zugeteilt.
(4) Aufwecken (wakeup, Deblockierung). Der Blockierungsgrund wird aufgehoben, weil das Betriebsmittel verfügbar ist.
=====3.2. Threads=====
===Definition===
Threads sind parallel ablaufende Aktivitäten in einem Prozess.
Synonyme: Fäden, Stränge, Leichtgewichtprozesse, Light Weight Processes (LWP).
Grungidee: Die gesamte Rechenarbeit eines Prozesses wird auf mehrere Aktivitäten geteilt, welche parallel ablaufen können.
**Prozess mit einem Thread**
{{image class="center" url="BSys13.gif"}}
**Prozess mit mehreren Threads**
{{image class="center" url="BSys14.gif"}}


Revision [22398]

Edited on 2013-03-26 15:36:35 by RonnyGertler
Additions:
{{image class="center" url="BSys12.gif" width="550"}}
Deletions:
{{files}}


Revision [22397]

Edited on 2013-03-26 15:35:14 by RonnyGertler
Additions:
{{files}}
c) durch Systemaufruf im laufenden Prozess, z.B. fork in UNIX oder ""CreateProcess"" in Windows,
a) freiwillige Beendigung durch Systemaufruf , z.B. exit in UNIX oder ""ExitProzess"" in Windows;
===Prozesszustände===
Ein Prozess durchläuft während seiner Lebenszeit verschiedene Zustände. Ein Grundmodell enthält drei Zustände:
1) Aktiv (laufend, running). Der Prozess besitzt die CPU. In einem Einprozessorsystem kann nur ein Prozess zu jedem Zeitpunkt in diesem Zustand sein.
2) Rechenbereit (ready). Der Prozess wartet auf die CPU- Zuteilung.
3) Blockiert (wartend, blocked). Der Prozess wartet auf ein Ereignis, z.B.:
a) Ablauf einer Zeitspanne, welche der Prozess selbst beauftragt hat, z.B. sleep,
b) Zuteilung eines Betriebsmittels außer CPU,
c) Meldung von einem anderen Prozess.
In konkreten Betriebssystemen sind auch weitere Prozesszustände möglich.
Deletions:
c) durch Systemaufruf im laufenden Prozess, z.B. fork in UNIX oder CreateProcess in Windows,
a) freiwillige Beendigung durch Systemaufruf , z.B. exit in UNIX oder ExitProzess in Windows;


Revision [22396]

Edited on 2013-03-26 15:33:31 by RonnyGertler
Additions:
===Typische Informationen in einem PCB===
1. Register-Inhalte:
a) PC - Program Counter,
b) PSW - Program Status Word,
c) SP - Stack Pointer,
d) allgemeine Register.
2. Informationen für die Speichermanagement:
a) Seitentabelle-Adresse,
b) Basisregister-Inhalte,
c) Grenzregister-Inhalte,
d) Adressen auf Code-, Daten- und Stack-Segmente des Prozesses, usw.
3. Beschreibung der zugeordneten Betriebsmittel:
a) Informationen für die Dateiverwaltung: Dateideskriptoren, Home-Verzeichnis, Arbeitsverzeichnis usw.
b) Netzwerkverbindungen,
c) allozierte Geräte usw.
4. Betriebssysteminterne Prozessverwaltungsdaten:
a) Prozess-Nummer (PID-Process IDentification)
b) Prozesszustand, z.B. aktiv, bereit, blockiert,
c) Priorität für das Scheduling,
d) verbrauchte Prozessorzeit seit dem Start,
e) Prozeßnummer des Elternprozesses (PPID, Parent PID), usw.
""⇒"" Demo 1.
===Prozesswechsel===
Synonyme: Prozess-Umschaltung, Kontextwechsel, context-switch, process switch, task switch.
Am Prozesswechsel sind zwei Prozesse beteiligt:
1) der suspendierte Prozess, der vor der Unterbrechung aktiv war, und
2) der aktivierte Prozess, der vor der Unterbrechung unaktiv war. Der aktivierte Prozess wurde vom Scheduler ausgewählt.
Am Prozesswechsel sind zwei Ressourcen beteiligt:
1) CPU-Register und
2) Arbeitsspeicher.
===Wechsel von Register-Inhalten===
Dieser Wechsel besteht aus Kontextsicherung und Kontextwiederherstellung.
(1) Bei der **Kontextsicherung** (Kontext-Retten) müssen Registerinhalte des suspendierten Prozesses gesichert werden, um später wiederhergestellt werden zu können.
a) Der Unterbrechungskontext wird aus dem Stack im PCB gesichert.
b) Andere Registerinhalte werden aus der CPU im PCB gesichert.
Analogie: Schnappschuss.
(2) Bei der **Kontextwiederherstellung** werden Registerinhalte des aktivierten Prozesses wiederherstellt, d.h. aus dem PCB in die CPU kopiert.
===Wechsel von Speicher-Inhalten===
Dieser Wechsel findet z.B. im Rechner mit virtuellem Speicher statt.
Beim Prozesswechsel können:
(3) einige Speicherbereiche des suspendierten Prozesses ausgelagert werden und
(4) einige Adressraumbereiche des aktivierten Prozesses nach Bedarf von der Festplatte auf den Speicher geladen werden.
===Erzeugung und Terminierung des Prozesses===
Es gibt einige Möglichkeiten einen neuen Prozess zu erzeugen:
a) beim Systemstart, z.B. Leerlaufprozess,
b) durch Benutzeranforderung, z.B. cmd- Konsole,
c) durch Systemaufruf im laufenden Prozess, z.B. fork in UNIX oder CreateProcess in Windows,
d) durch Systemaufruf für Stapelauftrag, z.B. batch job.
Es gibt einige Möglichkeiten einen Prozess zu terminieren:
a) freiwillige Beendigung durch Systemaufruf , z.B. exit in UNIX oder ExitProzess in Windows;
b) unfreiwillige Beendigung durch das System wegen den Fehler, z.B. trap;
c) unfreiwillige Terminierung durch einen anderen Prozess, z.B. kill.
""⇒"" Demo 2.
""⇒"" Demo 3.


Revision [22394]

Edited on 2013-03-26 15:25:56 by RonnyGertler
Additions:
===Grundbegriffe===

1) Ein **Prozess** (Task, Aufgabe) ist eine Ausführung des Programms in seiner eigenen Prozessumgebung. Der Prozess ist ein zentrales Konzept einer Parallelverarbeitung in der Betriebssystemtheorie.
2) Eine **Prozessumgebung** (Ablaufumgebung, Ausführungsumgebung) besteht aus dem Prozess-Kontext und zugeordneten Ressourcen.
3) Ein **Ressource** (Betriebsmittel) kann eine Hardware oder eine Informationseinheit sein. Jedem Prozess können folgende Ressourcen zugeordnet werden:
a) CPU,
b) Arbeitsspeicher,
c) andere Ressourcen: offene Dateien, Konsolen, Netzwerkverbindungen usw.
4) Ein **Prozess-Kontext** ist eine ausführliche Beschreibung des Prozesses:
a) Registerinhalte,
b) Adressraumbeschreibung,
c) Beschreibung der zugeordneten Ressourcen,
d) Betriebssysteminterne Verwaltungsdaten.
5) Ein **Programm** ist eine Verfahrensvorschrift für die Datenverarbeitung.
a) Ein Programm ist ein Teil der Prozessumgebung.
b) Ein bestimmtes Programm kann von mehreren Prozessen ausgeführt werden.
6) Ein **Job** (Session, Anwendung) ist ein Benutzerauftrag an das Betriebssystem.
a) Ein Job kann aus einem oder mehreren Prozessen bestehen.
b) Jobs sind unabhängig und geschützt von anderen.
===Prozessmodell===

1) Die gesamte Software ist als Menge von Prozessen organisiert.

2) Das Betriebssystem schafft für jeden Prozess eine Illusion, dass er den ganzen Rechner für sich selbst alleine zur Verfügung hat. Dieser illusorische Rechner wurde durch die Multitasking realisiert.

3) Jeder Prozess merkt keine Unterbrechung, nur die zeitliche Verzögerung.

4) Jeder Prozess ist gegenüber anderen Prozessen geschützt.
===PCB ===

1) Ein **PCB***-Process Control Block (Process Context Block) wird vom Betriebssystem zur Verwaltung eines Prozesses geführt.
Ein PCB ist eine Repräsentation eines Prozesses und enthält seinen Prozess-Kontext.

2) Die **Prozesstabelle** wird vom BS zur Verwaltung von Prozessen geführt und enthält PCB von allen Prozessen.
Sie kann auch als Liste implementiert werden.


Revision [22393]

The oldest known version of this page was created on 2013-03-26 15:19:41 by RonnyGertler
Valid XHTML   |   Valid CSS:   |   Powered by WikkaWiki