Die Ausführung geschieht über die sequentielle Abarbeitung der Instruktionen.
|
|
- Nadine Huber
- vor 7 Jahren
- Abrufe
Transkript
1 Kapitel 4 Prozesse Seite 1 4 Prozesse 4.1 Prozeßkonzept Prozess- ein Programm in Ausführung Die Ausführung geschieht über die sequentielle Abarbeitung der Instruktionen. Üblicher Start: über eine Kommandozeileneingabe (Dialog) oder über eine Jobeingabe (Batch) oder Mausklick. Das Bedienprogramm zb Shell ruft eine Systemfunktion "Starte Prozeß" auf. Ein Prozess besteht aus folgenden Komponenten: Prozesssteuerblock (ProcessControlBlock, PCB) oder Prozessdeskriptor <- Bürokratie Datenstruktur zur Verwaltung eines Prozesses Programmadresse: Zeiger auf einen im Speicher geladenen Programmtext Programmtext im Speicher Stack Datenteil Daten im Speicher Ein Prozeß muß verwaltet werden!
2 Kapitel 4 Prozesse Seite 2 Der Prozess innerhalb der wichtigen Komponenten eines Betriebssystems. Programm Prozess Prozessumgebung Hardware, Systemfunktionen, Systemdienste Dateisystem Deadlock Schutztmechanismen Prozessdeskriptor Geräte- Speicher- Synchronisation Manager Manager Scheduler Resourcemanager Geräte Speicher CPU Resourcen andere Resourcen
3 Kapitel 4 Prozesse Seite 3 Im Zeitablauf der Ausführung kann ein Prozeß folgende Zustände einnehmen: neu: Der Prozeß wird erstellt. aktiv (running): Instruktionen werden ausgeführt. wartend (waiting, blockiert): Der Prozeß wartet auf ein Ereignis. bereit (ready): Der Prozeß wartet auf die Zuweisung an einen Prozessor (CPU). beendet (terminated): Der Prozeß hat die Ausführung beendet. Zustandübergangsdiagramm neu beendet Aufnahme Ende Interrupt bereit aktiv CPU-Zuteilung I/O-Ende oder (Scheduler) Warten auf Ende I/O Ereignis oder Ereignis wartend Wie wird verwaltet? Wie üblich: Verwaltungsfelder Tabellen Listen Prozessdeskriptor - Information, die zur Verwaltung eines Prozesses benötigt wird. Prozeßzustand Programmadresse CPU-Register Information für den CPU-Scheduler Information der Speicherverwaltung Informationen zur Betriebsmittelvergabe und Abrechnung Information zum I/O-Status
4 Kapitel 4 Prozesse Seite Adressraum eines Prozesses Menge der Adressen der dem Prozess zur Verfügung stehenden Speicherfelder. Die Speicherfelder werden benötigt, um den Programmtext, die Datenfelder, den Stack des Prozesses im Hauptspeicher unterzubringen. Adressraum des Prozesses - ein Überblick Prozess Adressraum (Adressen des Prozesses) Hauptspeicher andere Objekte Wie entsteht der Adressraum? Dieser Vorgang läuft mit der Programmverarbeitung ab: Programmtext editieren. Übersetzen. Binden (Link). Programmaufruf zur Ausführung. Ausführung.
5 Kapitel 4 Prozesse Seite 5 Quellmodule Compiler Objektmodule - Adressraum verschiebbar Linker Absolutes Image in exe-datei Programm Lader Image im Speicher
6 Kapitel 4 Prozesse Seite 6 Speicherhierarchie EAX IP Adressregister EBX Flags EDI Register der CPU Hauptspeicher Primärer Speicher Massenspeicher Sekundärer Speicher Die Speicherhierarchie Dateien im Sekundärspeicher Prozesskomponenten im Hauptspeicher Temporäre Daten und Instruktionen in Registern der CPU Diese drei Speicher sind beim Programmieren sichtbar (die Registerebene mit Hilfe des Compilers). Es gibt noch weitere Speicherebenen, die aber nicht sichtbar für die Programme sind (L1-Cache, L2-Cache).
7 Kapitel 4 Prozesse Seite 7 Die dauerhaften Daten liegen im Sekundärspeicher. Das Programm hat dafür zu sorgen, dass die dauerhaft zu haltenden Daten aus den anderen Speicherebenen dauerhaft in den Sekundärspeicher geschrieben werden. Der Übergang Register zum Hauptspeicher geschieht mit Hilfe des Compilers, der Programmierer hat damit i.a. nichts zu tun. Das Schreiben in den Sekundärspeicher hat aber der Programmierer zu veranlassen. Stürzt der Prozess ab oder ist das Programm fehlerhaft, so kann ein inkonsistenter Datenzustand (unstimmiger Datenzustand) entstehen. 4.3 CPU-Ablaufplanung (Scheduling) Die verschiedenen Prozesse: Konkurrenz um die Resourcen! Prozeßlisten Jobliste - Liste aller im System anstehenden Jobs Bereitliste - Liste aller bereiten Prozesse Wartelisten I/O-Warteliste - einem Gerät zugeordnet, Liste der Prozesse, die auf ein I/O- Ende des Gerätes warten. Ereignisliste - Liste der Prozesse, die auf das Ereignis warten. Bewegung der Prozesse zwischen den Listen CPU-Entzug (Preemption) Prozesserstellung Bereitliste CPU Ende I/O läuft I/O Warteliste
8 Kapitel 4 Prozesse Seite 8 Zweistufige CPU-Planung CPU-Entzug (Preemption) Langzeitplanung Kurzzeitplanung Ende Bereitliste CPU I/O läuft I/O Warteliste Kurzzeitplanung: Prozesse im Hauptspeicher Verwaltung der CPU-Zeit! Die Kurzzeitplanung wird sehr oft aufgerufen: Liegt im Millisekundenbereich, muß schnell sein. Langzeitplanung: Starten neuer Prozesse, Aus- und Einlagern von Prozessen Manipulation der Bereit-Listen Verplanung der Betriebsmittel Die Langzeitplanung wird weniger oft aufgerufen: Sekunden-, Minutenbereich. Die Langzeitplanung legt den Grad des Mehrprogrammbetriebs fest (Zahl der Prozesse). Klasseneinteilung von Prozessen: I/O-intensiv: Die meiste Zeit wird I/O durchgeführt, dazwischen viele kurze CPU-Bursts. CPU-intensitiv: Die meiste Zeit werden Berechnungen durchgeführt, wenige, lange CPU-Bursts.
9 Kapitel 4 Prozesse Seite Operationen auf Prozessen Kontext-Umschaltung Wenn die CPU auf einen anderen Prozeß umschaltet, muß der Zustand des geräumten Prozesses abgespeichert werden. Der andeswo abgespeicherte Zustand des neuen Prozesses muß geladen werden. Da diese Umschaltung ein Systemoverhead ist, muß dafür gesorgt werden daß a) sie nicht zu oft auftritt und nicht zu lange dauert. Prozeß-Erstellung Ein "Parent"-Prozeß erstellt einen "Child"-Prozeß, der wiederum einen neuen Prozeß erstellen kann. Damit wird auf den Prozessen eine Baumstruktur definiert. Der Wurzelprozeß wird beim Systemstart automatisch ohne Parent erstellt. Betriebsmittel Die Childprozesse können Betriebsmittel des Parent erben und diese zusammen mit dem Parent benutzen (z.b. Dateien). Ausführungszeit Im Allgemeinen laufen Parent und Child zeitlich parallel ab. Jedoch kann sich der Parent auf das Ende des Child synchronisieren (Warteaufruf). Beispiel UNIX - Der Child-Adreßraum besteht aus deinem Duplikat des Parent. - In den Child-Adreßraum wurde bei der Erstellung ein Programm geladen. - Ein fork System-Call erstellt durch Duplizieren einen Child-Prozeß. - Ein execve System-Call lädt nach dem fork ein neues Programm in den Adreßraum. Beispiel Windows NT - Die Windows API stellt die Funktion BOOL CreateProcess ( ) zur Verfügung. Wichtigstes Argument ist der (Pfad)name der auszuführenden Programmdatei.
10 Kapitel 4 Prozesse Seite 10 Prozeßende Über den System-Call exit( ) beendet sich ein Prozeß normal. Über den Wait-Synchronisationsaufruf kann der Child-Prozeß dem Parent einen Status mitteilen. - Die vom Prozeß belegten Betriebsmittel werden freigegeben. - Der Prozeß wird aus der Prozeßverwaltung entfernt. Der Parent kann einen Child-Prozeß abbrechen (abort), - falls das Child nicht das gewollte Verhalten zeigt, - falls das Child nicht länger benötigt wird, - falls der Parent sich beendet. Schema der normalen Programmausführung Es gibt mindestens einen Prozeß, der mit dem Systemstart eingerichtet wird und mit dem Systemende beendet wird. Seine Struktur besteht aus einer Endloschleife. Bei jedem Durchlauf wird eine Programmausführung als Child-Prozeß erstellt und nach dem Ablauf gelöscht. Für die Prozeßoperationen ruft dieser Prozeß die zur Verfügung stehenden Systemfunktionen auf.
11 Kapitel 4 Prozesse Seite 11 Beispiele für die Parent -Prozesse der Anwendungen MS-DOS: "Command.com"-Prozeß UNIX: "Root"-Prozeß, Shell-Prozesse Windows: Programm-Manager SYSTEMFUNKTIONEN Systemaufrufe Systemprozeß (Parent) Childprozeß 1 eine Programmausführung 2 1 Prozeßerstellung 2 Synchronisation Prozeßende 4.5 Zusammenarbeit von Prozessen Ein unabhängiger Prozeß wird von anderen Prozessen in seinem Ablauf nicht beeinflußt - außer evtl. in der Ausführungszeit, wenn ein Warten auf Resourcen diese verlängert. Zusammenarbeitende Prozesse können sich gegenseitig beeinflussen - ähnlich wie der Ablauf von Funktionen durch Argumente gesteuert wird.
12 Kapitel 4 Prozesse Seite 12 Beispiele für zusammenarbeitende (kooperierende) Prozesse: Kooperation über Betriebsmittel Standardproblem Produzent - Konsument Ein Hauptkonstrukt für kooperierende Prozesse. Der Produzent produziert Information, der Konsument konsumiert die Information. Klassische Lösung mit einem Prozeß, strukturiert mit Funktionen. main() produziere() produziere() konsumiere() konsumiere() Lösung mit mehreren Prozessen Produzent Konsument produziere konsumiere Puffer Für die Kooperation wird ein Puffer benötigt. Ein unbegrenzter Puffer setzt kein Limit bzgl. der Puffergröße. Ein begrenzter Puffer geht von einer bestimmten Puffergröße aus.
13 Kapitel 4 Prozesse Seite 13 Kommunikation zwischen Prozessen Client/Server-Beziehung Der Serverprozeß erstellt die Kommunikationseinrichtung.und wartet auf Anfragen. Der Clientprozeß hängt sich in die Kommunikationseinrichtung ein, stellt eine Anfrage. Der Server führt die vom Client gestellte Aufgabe aus und sendet dem Client i.a. eine Antwort. Client Server 1 Internet (HTML)- Internet- Anforderung eines server Browser Dokumentes Lieferung des Dokumentes 2 Der Client wendet sich an den Server, der Server reagiert auf die Anforderung des Client. Danach findet eine symmetrische Kommunikation statt. 4.6 Threads Ein Thread ( oder ein leichtgewichtiger Prozeß, deutsch: Faden bessere Bezeichnung: Ablaufbahn) ist eine Basiseinheit der Programmausführung durch die CPU. Er besteht aus: Instruktionenadresse Registersatz Stack Ein Prozess ist die organisatorische Hülle für die Threads der Programmausführung. Ein Prozess besitzt mindestens einen Thread.
14 Kapitel 4 Prozesse Seite 14 Ein Thread teilt mit seinen zugeordneten Threads den Programmtext die Daten die vom System zugewiesenen Betriebsmittel (außer CPU-Zeit) zusammen als Prozess oder Task bezeichnet Prozess: hier mit nur einem Thread Funktion main() call f Funktion f ( ) Ausführungsbahn return Prozess: hier mit 2 Threads Funktion main() CreateThread f Funktion f ( ) zeitlich parallel ThreadEnde WarteThreadEnde Meldung (Signal)
15 Kapitel 4 Prozesse Seite 15 Ein klassischer oder schwergewichtiger Prozeß ist gleich einem Prozeß mit einem Thread. Warum Threads? Hilfmittel zur Programmstrukturierung. Man kann Parallelität bei der Programmausführung einfacher formulieren, da das Betriebssystem zusätzliche Dienste zur Verfügung stellt. Laufzeitverbesserung. Wenn ein Prozeß auf ein Ereignis oder auf eine I/O wartet, so kann keine weitere Aktion in dieser Zeit von ihm durchgeführt werden. Ist er in Thread unterteilt, so kann ein Thread warten, während andere Threads weitere Aktionen ausführen. SERVER Serverprozeß CLIENTS Thread 1 für Anforderung von \\1\a \\1\a Thread 2 für Anforderung von \\2\x NETZ \\2\x Thread 3 für Anforderung von \\3\pp Thread 4 für zentrale Netzanbindung Datenpakete \\3\pp im Netz Thread 4 holt aus dem Netz die Datenpakete und übergibt die Antwortpakete an das Netz. Bearbeitet werden die Anforderungen der einzelnen Clients von zugeordneten Threads weitgehend unabhängig voneinander. Datenpaket zum Server: \\Server\3 \\2\x Verwaltung D A T E N Verwaltung Adresse Absender
Die Ausführung geschieht über die sequentielle Abarbeitung der Instruktionen.
Kapitel 4 Prozesse Seite 1 4 Prozesse 4.1 Prozeßkonzept Prozess- ein Programm in Ausführung Die Ausführung geschieht über die sequentielle Abarbeitung der Instruktionen. Üblicher Start: über eine Kommandozeileneingabe
MehrProzesse. Prozesskonzept. Prozess- ein Programm in Ausführung
Prozesse Prozesskonzept Prozess- ein Programm in Ausführung Üblicher Start: über eine Kommandozeileneingabe (Dialog) oder über eine Jobeingabe (Batch) oder Mausklick. Das Bedienprogramm zb Shell ruft eine
MehrÜberlegungen beim Entwurf eines Betriebssystems
Überlegungen beim Entwurf eines Betriebssystems Schnelligkeit Schutz und Sicherheit Korrektheit Wartbarkeit Kommerzielle Faktoren Standards und offene Systeme Schnelligkeit Es ist schwierig, Kenngrößen
MehrSequentielle Programm- / Funktionsausführung innerhalb eines Prozesses ( thread = Ausführungsfaden )
Threads Sequentielle Programm- / Funktionsausführung innerhalb eines Prozesses ( thread = Ausführungsfaden ) Ein thread bearbeitet eine sequentielle Teilaufgabe innerhalb eines Prozesses Mehrere nebenläufige
MehrSysteme I: Betriebssysteme Kapitel 4 Prozesse. Wolfram Burgard
Systeme I: Betriebssysteme Kapitel 4 Prozesse Wolfram Burgard Version 18.11.2015 1 Inhalt Vorlesung Aufbau einfacher Rechner Überblick: Aufgabe, Historische Entwicklung, unterschiedliche Arten von Betriebssystemen
MehrSingle- und Multitasking
Single- und Multitasking Peter B. Ladkin ladkin@rvs.uni-bielefeld.de Peter B. Ladkin Command Interpreter (ComInt) läuft wartet auf Tastatur-Eingabe "liest" (parst) die Eingabe (für Prog-Name) Macht "Lookup"
MehrPROGRAMMIEREN MIT UNIX/LINUX-SYSTEMAUFRUFEN
PROGRAMMIEREN MIT UNIX/LINUX-SYSTEMAUFRUFEN 2. UNIX/Linux-Prozessverwaltung und zugehörige Systemaufrufe Wintersemester 2016/17 2. Die UNIX/LINUX-Prozessverwaltung Aufgaben: 1. Erzeugen neuer Prozesse
MehrTechnische Informatik 1
Technische Informatik 1 7 Prozesse und Threads Lothar Thiele Computer Engineering and Networks Laboratory Betriebssystem 7 2 7 3 Betriebssystem Anwendung Anwendung Anwendung Systemaufruf (syscall) Betriebssystem
MehrSysteme I: Betriebssysteme Kapitel 4 Prozesse. Maren Bennewitz
Systeme I: Betriebssysteme Kapitel 4 Prozesse Maren Bennewitz Version 13.11.2013 1 Inhalt Vorlesung Aufbau einfacher Rechner Überblick: Aufgabe, Historische Entwicklung, unterschiedliche Arten von Betriebssystemen
MehrTeil 3: Konzepte von Betriebssystemen
Teil 3: Konzepte von Betriebssystemen Inhalt: Einführung Prozesse Speicherverwaltung Virtueller Speicher 1 Definition eines Betriebssystems Was ist ein Betriebssystem? einfache Definition: Als Betriebssystem
MehrWas machen wir heute? Betriebssysteme Tutorium 3. Organisatorisches. Prozesskontrollblock (PCB) Programmieraufgaben. Frage 3.1.a
Was machen wir heute? Betriebssysteme Tutorium 3 Philipp Kirchhofer philipp.kirchhofer@student.kit.edu http://www.stud.uni-karlsruhe.de/~uxbtt/ Lehrstuhl Systemarchitektur Universität Karlsruhe (TH) 1
MehrBetriebssysteme Kapitel E : Prozesse
Betriebssysteme Kapitel E : Prozesse 1 Inhalt Prozesse Zustand eines Prozesses» Kontext» Kontextswitch Prozessbeschreibungsblock PCB Zustandsübergänge» Zustandsdiagramm 2 Hinweis Ein Programm(code) kann
MehrSysteme I: Betriebssysteme Kapitel 4 Prozesse. Maren Bennewitz
Systeme I: Betriebssysteme Kapitel 4 Prozesse Maren Bennewitz Version 21.11.2012 1 Begrüßung Heute ist Tag der offenen Tür Willkommen allen Schülerinnen und Schülern! 2 Testat nach Weihnachten Mittwoch
MehrProzesse and Threads WS 09/10 IAIK 1
Prozesse and Threads WS 09/10 IAIK 1 Prozesse Programm in Ausführung Mit einem Prozess verbunden: Adressraum Folge von Speicherstellen auf die der Prozess zugreifen kann Enthält ausführbares Programm,
MehrFakultät für Informatik der Technischen Universität München. Kapitel 3. Nebenläufigkeit
Kapitel 3 Nebenläufigkeit 136 Inhalt Motivation Unterbrechungen (Interrupts) (Software-) Prozesse Threads Interprozesskommunikation (IPC) 137 Links: Literatur Maurice Herlihy, Nir Shavit, The Art of Multiprocessor
MehrKlausur Betriebssysteme
Prof. Dr. Michael Jäger FB MNI Klausur Betriebssysteme 5.2.2016 Die Dauer der Klausur beträgt 90 Minuten. Es sind keine Unterlagen und Hilfsmittel erlaubt. Bitte bearbeiten Sie die Aufgaben soweit wie
MehrInhaltsverzeichnis. 2.4 Thread-Systeme. 2.1 Was ist ein Prozess? 2.2 Scheduling. 2.3 Interprozesskommunikation
Inhaltsverzeichnis Systemprogrammierung - Kapitel 2 Prozessverwaltung 1/21 2.1 Was ist ein Prozess? Definition Prozesszustände Prozesskontrollblöcke 2.4 Thread-Systeme Sinn und Zweck Thread-Arten Thread-Management
MehrProzesse: Prozesskontrollblock, -steuerung, -umschaltung
Proseminar: Konzepte von Betriebssystemkomponenten 3.11.03 Prozesse: Prozesskontrollblock, steuerung, umschaltung Überblick Prozesskontrollblock Prozesszustände Prozessumschaltung Prozesskontrollblock
MehrEinführung. Anwendung. logischer Adreßraum. Kontrollfluß (Thread) = CPU führt Instruktionen aus. Was charakterisiert einen Kontrollfluß?
Kontrollflüsse Einführung 1 Motivation Kontrollfluß Anwendung logischer Adreßraum Kontrollfluß (Thread) = führt Instruktionen aus Was charakterisiert einen Kontrollfluß? Programmzähler Registerinhalte
MehrBetriebssysteme Betriebssysteme und. Netzwerke. Netzwerke Theorie und Praxis
Einführung Einführung in in Betriebssysteme Betriebssysteme und und Theorie und Praxis Theorie und Praxis Oktober 2006 Oktober 2006 Prof. Dr. G. Hellberg Prof. Dr. G. Hellberg Email: hellberg@drhellberg.de
MehrDämon-Prozesse ( deamon )
Prozesse unter UNIX - Prozessarten Interaktive Prozesse Shell-Prozesse arbeiten mit stdin ( Tastatur ) und stdout ( Bildschirm ) Dämon-Prozesse ( deamon ) arbeiten im Hintergrund ohne stdin und stdout
Mehr1 Prozesse und Scheduling (12 Punkte)
1 Prozesse und Scheduling (12 Punkte) a) UNIX Shell-Operatoren (insgesamt 4 Punkte) 1. Operator (1,5 Punkte) Beschreiben Sie die Funktionsweise des Operators. 2. Operator Beispiel (1 Punkt) Geben Sie für
MehrSysteme I: Betriebssysteme Kapitel 8 Speicherverwaltung
Systeme I: Betriebssysteme Kapitel 8 Speicherverwaltung Version 21.12.2016 1 Inhalt Vorlesung Aufbau einfacher Rechner Überblick: Aufgabe, Historische Entwicklung, unterschiedliche Arten von Betriebssystemen
MehrProgrammieren 2 12 Netzwerke
Programmieren 2 12 Netzwerke Bachelor Medieninformatik Sommersemester 2015 Dipl.-Inform. Ilse Schmiedecke schmiedecke@beuth-hochschule.de 1 Motivation Datenaustausch zwischen Programmen Spielstand Chat
MehrBetriebssysteme Vorstellung
Am Anfang war die Betriebssysteme Vorstellung CPU Ringvorlesung SE/W WS 08/09 1 2 Monitor CPU Komponenten eines einfachen PCs Bus Holt Instruktion aus Speicher und führt ihn aus Befehlssatz Einfache Operationen
MehrKlausur Betriebssysteme I
Prof. Dr. Michael Jäger FB MNI Klausur Betriebssysteme I 9.3.2000 Bitte bearbeiten Sie die Aufgaben soweit wie möglich auf den Aufgabenblättern. Nachname: Matrikelnummer: Vorname: Semester: Bitte beantworten
MehrBetriebssysteme. Thomas Fahringer. Institut für Informatik Universität Innsbruck. VO Betriebssysteme
Grundzüge der Informatik IV: Betriebssysteme Thomas Fahringer Institut für Informatik Universität Innsbruck V Thomas.Fahringer@uibk.ac.at 1 Kapitel I Betriebssysteme: Aufgaben und Überblick V 2 Was ist
MehrSystemprogrammierung
Systemprogrammierung 3Vom C-Programm zum laufenden Prozess 6. November 2008 Jürgen Kleinöder Universität Erlangen-Nürnberg Informatik 4, 2008 SS 2006 SOS 1 (03-Pro.fm 2008-11-06 08.52) 3 Vom C-Programm
MehrModul B-PRG Grundlagen der Programmierung 1
Modul B-PRG Grundlagen der Programmierung 1 Teil 3: Betriebssysteme, Dateisysteme,Sicherheit V20: Prozesse Prof. Dr. R. Brause Adaptive Systemarchitektur Institut für Informatik Fachbereich Informatik
MehrBetriebssysteme G: Parallele Prozesse (Teil A: Grundlagen)
Betriebssysteme G: Parallele Prozesse (Teil A: Grundlagen) 1 Prozesse Bei Betriebssystemen stoßen wir des öfteren auf den Begriff Prozess als wahrscheinlich am häufigsten verwendeter und am unklarsten
MehrMusterlösung Prüfung WS 01/02
Musterlösung Prüfung WS 01/02 Fach: I3 Software-Technik (SEE, GRS, BTS) Teilprüfung: Betriebssysteme Tag: 29.01.2002 10:45 14.45 Raum: 1006 Bearbeitungszeit: 4 Stunden Name:... Matr.Nr.:... Punkte:...
MehrProzesse und Threads. Prozess. Trace. Einfachstes Prozessmodell. Traces
Prozesse und s Begriffe und Konzepte Prozesszustände Kontrollstrukturen des BS Prozesse BS s Peter Puschner 1 Vorlesung Betriebssysteme, Prozesse; WS 05/06 2 Prozess Animated Spirit of a program ausführbares
MehrLegende: Running Ready Blocked P1 P2 P3. t[ms] 1 Prozesse und Scheduling (16 Punkte)
1 Prozesse und Scheduling (16 Punkte) a) UNIX Shell (insgesamt 5 Punkte) 1) $ ls > Dateien.txt (2 Punkte) Was bewirkt die Ausführung dieses Kommandos in einer UNIX-Shell? 2) $ cat Dateien.txt grep txt
Mehr2Binden 3. und Bibliotheken
3 Vom C-Programm zum laufenden Prozess 3.1 Übersetzen - Objektmodule 1Übersetzen 3. - Objektmodule (2) Teil III 3Vom C-Programm zum laufenden Prozess 2. Schritt: Compilieren übersetzt C-Code in Assembler
MehrLiteratur. VA SS Teil 5/Messages
Literatur [5-1] https://en.wikipedia.org/wiki/message-oriented_middleware [5-2] https://en.wikipedia.org/wiki/advanced_message_queuing_protocol http://www.amqp.org/specification/0-10/amqp-org-download
MehrProzesse. Prozesse sind Programme. Prozesse können aus Unterprozessen bestehen. Prozesshierarchie Unterprozesse Threads
Threads Prozesse, Parallelität, Nebenläufigkeit, Threads, Erzeugung, Ausführung, Kommunikation, Interferenz, Kritischer Bereich, Deadlock, Synchronisation. Prozesse Prozesse sind Programme mehrere Prozesse
MehrKapitel III. Prozessverwaltung. VO Betriebssysteme
Kapitel III Prozessverwaltung V 1 Was ist ein Prozess? Prozesse ein exekutierendes Programm (aktive Einheit) ein Prozess benötigt Ressourcen: CPU-Zeiten, Speicher, Files, I/O Systeme Betriebssystem ist
MehrEchtzeitbetriebssysteme
Speicherverwaltung (Memory Management) Aufgaben der Memory-Management-Unit ist l der Speicherschutz und l die Adressumsetzung Wird durch Hardware unterstützt l Memory Management Unit (MMU) l MMU wird vom
MehrBetriebssysteme. G: Parallele Prozesse. (Teil B: Klassische Problemstellungen, Mutual Exclusion, kritische Regionen)
Betriebssysteme G: Parallele Prozesse (Teil B: Klassische Problemstellungen, Mutual Exclusion, kritische Regionen) 1 Allgemeine Synchronisationsprobleme Wir verstehen ein BS als eine Menge von parallel
MehrBetriebssysteme Wintersemester 2005/06
Betriebssysteme Wintersemester 2005/06 Vorlesung 3 Prozesse und Threads Dr. Oliver Waldhorst Rechnernetze und verteilte Systeme Universität Leipzig http://www.informatik.uni-leipzig.de/rnvs Fahrplan Nr.
MehrPthreads. David Klaftenegger. Seminar: Multicore Programmierung Sommersemester
Seminar: Multicore Programmierung Sommersemester 2009 16.07.2009 Inhaltsverzeichnis 1 Speichermodell 2 3 Implementierungsvielfalt Prioritätsinversion 4 Threads Speichermodell Was sind Threads innerhalb
MehrArchitektur Verteilter Systeme Teil 2: Prozesse und Threads
Architektur Verteilter Systeme Teil 2: Prozesse und Threads 21.10.15 1 Übersicht Prozess Thread Scheduler Time Sharing 2 Begriff Prozess und Thread I Prozess = Sequentiell ablaufendes Programm Thread =
MehrI Einführung in Betriebssysteme
I Einführung in Betriebssysteme I.1 1 Einordnung Ebene 6 Ebene 5 Ebene 4 Problemorientierte Sprache Assemblersprache Betriebssystem Ebene 3 ISA (Instruction Set Architecture) Ebene 2 Ebene 1 Ebene 0 Mikroarchitektur
MehrSysteme I: Betriebssysteme Kapitel 4 Prozesse. Maren Bennewitz
Systeme I: Betriebssysteme Kapitel 4 Prozesse Maren Bennewitz Version 20.11.2013 1 Begrüßung Heute ist Tag der offenen Tür Willkommen allen Schülerinnen und Schülern! 2 Wdhlg.: Attributinformationen in
MehrBetriebssysteme. Tutorium 2. Philipp Kirchhofer
Betriebssysteme Tutorium 2 Philipp Kirchhofer philipp.kirchhofer@student.kit.edu http://www.stud.uni-karlsruhe.de/~uxbtt/ Lehrstuhl Systemarchitektur Universität Karlsruhe (TH) 4. November 2009 Philipp
MehrEinführung in die technische Informatik
inführung in die technische Informatik hristopher Kruegel chris@auto.tuwien.ac.at http://www.auto.tuwien.ac.at/~chris etriebssysteme ufgaben Management von Ressourcen Präsentation einer einheitlichen Schnittstelle
MehrBetriebssysteme. Vorlesung im Herbstsemester 2010 Universität Mannheim. Kapitel 6: Speicherbasierte Prozessinteraktion
Betriebssysteme Vorlesung im Herbstsemester 2010 Universität Mannheim Kapitel 6: Speicherbasierte Prozessinteraktion Felix C. Freiling Lehrstuhl für Praktische Informatik 1 Universität Mannheim Vorlesung
MehrBetriebssysteme. FU Berlin WS 2004/05 Klaus-Peter Löhr. bs-1.1 1
Betriebssysteme FU Berlin WS 2004/05 Klaus-Peter Löhr bs-1.1 1 1 Einführung Zur Erinnerung: Informatische Fachbegriffe in Deutsch und Englisch findet man unter http://www.babylonia.org.uk bs-1.1 2 Software
MehrThreads Einführung. Zustände von Threads
Threads Einführung Parallelität : Zerlegung von Problemstellungen in Teilaufgaben, die parallelel ausgeführt werden können (einfachere Strukturen, eventuell schneller, Voraussetzung für Mehrprozessorarchitekturen)
MehrBetriebssysteme KU - Einführungstutorium
Betriebssysteme KU - Einführungstutorium SWEB-Tutoren 5. Oktober 2008 1 Grundlagen 2 SWEB 3 Kernel Basics Memory Management Details 4 Userspace 5 Hacking 6 Beispiele 7 Assignment 0 Aufgaben eines Betriebssystems
MehrBetriebssysteme Übung 2. Tutorium System Calls & Multiprogramming
Betriebssysteme Übung 2. Tutorium System Calls & Multiprogramming Task Wiederholung 1 System SysCalls (1) Wozu? Sicherheit Stabilität Erfordert verschiedene modes of execution: user mode privileged mode
MehrJust-In-Time-Compiler (2)
Just-In-Time-Compiler (2) Dr.-Ing. Volkmar Sieh Department Informatik 4 Verteilte Systeme und Betriebssysteme Friedrich-Alexander-Universität Erlangen-Nürnberg WS 2015/2016 V. Sieh Just-In-Time-Compiler
MehrSysteme I: Betriebssysteme Kapitel 2 Überblick Betriebssysteme. Wolfram Burgard
Systeme I: Betriebssysteme Kapitel 2 Überblick Betriebssysteme Wolfram Burgard 1 Überblick Betriebssysteme Aufgabe von Betriebssystemen Historische Entwicklung von Betriebssystemen Unterschiedliche Arten
MehrProzesse und Prozessmanagement des BS. 1 Unterschied Prozess, Threads. 1.1 Prozess. 1.2 Threads
Prozesse und Prozessmanagement des BS 1 Unterschied Prozess, Threads 1.1 Prozess Bei jedem Programm muss gespeichert werden, welche Betriebsmittel (Speicherplatz, CPU- Zeit, CPU-Inhalt,...) es benötigt.
MehrBasisinformationstechnologie I Wintersemester 2011/ November 2011 Betriebssysteme
Basisinformationstechnologie I Wintersemester 2011/12 23. November 2011 Betriebssysteme Seminarverlauf 12. Oktober: Organisatorisches / Grundlagen I 19. Oktober: Grundlagen II 26. Oktober: Grundlagen III
Mehr(a) Wie unterscheiden sich synchrone und asynchrone Unterbrechungen? (b) In welchen drei Schritten wird auf Unterbrechungen reagiert?
SoSe 2014 Konzepte und Methoden der Systemsoftware Universität Paderborn Fachgebiet Rechnernetze Präsenzübung 2 2014-04-28 bis 2014-05-02 Aufgabe 1: Unterbrechungen (a) Wie unterscheiden sich synchrone
MehrInformatik 12 Kapitel 2 - Kommunikation und Synchronisation von Prozessen
Fachschaft Informatik Informatik 12 Kapitel 2 - Kommunikation und Synchronisation von Prozessen Michael Steinhuber König-Karlmann-Gymnasium Altötting 9. Februar 2017 Folie 1/40 Inhaltsverzeichnis I 1 Kommunikation
MehrProzesse und Threads. Peter Puschner Institut für Technische Informatik 1
Prozesse und Threads Peter Puschner Institut für Technische Informatik peter@vmars.tuwien.ac.at 1 Ziel: Gleichzeitiges, kontrolliertes Ausführen von Programmen auf einem Rechner Welche Mechanismen sind
MehrBegriff: Scheduling Planung, Schedule Plan. Verplanung der CPU-Zeit an die Threads (bzw. Prozesse)
5 CPU-Scheduling Im folgenden wird von Threads gesprochen. Bei Systemen, die keine Threads unterstützen, ist der einzige "Thread" eines Prozesses gemeint. Früher wurde dieser Thread synonym mit dem Begriff
Mehr3.5 Unterbrechungsbehandlung (interrupt handling)
3.5 Unterbrechungsbehandlung (interrupt handling) hat folgende Aufgaben: Zustandsdaten des unterbrochenen Prozesses retten und neuen Kontext für die Behandlung aufsetzen, unterbrechungsspezifische Behandlung
MehrBetriebssysteme. FU Berlin SS 2003 Klaus-Peter Löhr
Betriebssysteme FU Berlin SS 2003 Klaus-Peter Löhr 1 Einführung Zur Erinnerung: Informatische Fachbegriffe in Deutsch und Englisch findet man unter http://www.babylonia.org.uk Software zwischen Hardware
MehrÜberblick und Aufgaben
Aufgaben eines Betriebssystems Komponenten und Benutzer eines Rechnersystems Endbenutzer Applikationen Middleware Applikations- Programmierer System- Programmierer Betriebssystem Hardware 5 Aufgaben eines
MehrVorl. 6: Single- und Multitasking
Universität Bielefeld Technische Fakultät AG Rechnernetze und verteilte Systeme Vorl. 6: Single- und Multitasking Peter B. Ladkin Single Tasking Command Interpreter (ComInt) läuft wartet auf Tastatur-Eingabe
MehrKlausur zum Kurs Betriebssysteme (1802) am 18. September 2010
Fakultät für Mathematik und Informatik Lehrgebiet Kooperative Systeme Prof. Dr. Jörg M. Haake Klausur zum Kurs Betriebssysteme (1802) am 18. September 2010 Klausurort: Vorname Name: Adresse: Matrikelnummer:
MehrSystemprogramme bezeichnen alle Programme, die bestimmte Aufgaben unterstützen, die unabhängig von einer konkreten Anwendung sind
Betriebssysteme Systemprogramme bezeichnen alle Programme, die bestimmte Aufgaben unterstützen, die unabhängig von einer konkreten Anwendung sind Umfaßt z.b. auch Compiler, Interpreter und Dienstprogramme
MehrTest (Lösungen) Betriebssysteme, Rechnernetze und verteilte Systeme
Seite 1 Test (Lösungen) Betriebssysteme, Rechnernetze und verteilte Systeme 1 11.07.2007 Hinweise: Bevor Sie mit der Bearbeitung der Aufgaben beginnen, müssen Sie auf allen Blättern Ihren Namen und Ihre
MehrRechnernutzung in der Physik. Betriebssysteme
Rechnernutzung in der Physik Betriebssysteme 1 Betriebssysteme Anwendungsprogramme Betriebssystem Treiber BIOS Direkter Zugriff von Anwenderprogrammen auf Hardware nur in Ausnahmefällen sinnvoll / möglich:
MehrThreads. Foliensatz 8: Threads Folie 1. Hans-Georg Eßer, TH Nürnberg Systemprogrammierung, Sommersemester 2015
Sep 19 14:20:18 amd64 sshd[20494]: Accepted rsa for esser from ::ffff:87.234.201.207 port 61557 Sep 19 14:27:41 amd64 syslog-ng[7653]: STATS: dropped 0 Sep 20 01:00:01 amd64 /usr/sbin/cron[29278]: (root)
Mehr11. Die PC-Schnittstelle
PC-Schnittstelle Funktion -1. Die PC-Schnittstelle.1. Funktion Die folgenden Angaben gelten ohne Einschränkung für den PC, PC-XT, PC-AT, AT-386, AT-486 und kompatible Rechner. Sie sind nur für jene interessant,
MehrJust-In-Time-Compiler (2)
Just-In-Time-Compiler (2) Dr.-Ing. Volkmar Sieh Department Informatik 3: Rechnerarchitektur Friedrich-Alexander-Universität Erlangen-Nürnberg WS 2011/2012 Just-In-Time-Compiler (2) 1/13 2011-09-12 Just-In-Time-Compiler
Mehruntermstrich SYNC Handbuch
Handbuch 11/2017 Inhaltsverzeichnis 1. Einleitung... 2 2. Installation... 3 2.1 Systemanforderungen... 3 2.2 Vorbereitungen in Microsoft Outlook... 3 2.3 Setup... 4 3. SYNC-Einstellungen... 6 3.1 Verbindungsdaten...
MehrBetriebssystem. Arten von Betriebssystemen. Zweiteilung des Betriebssystems. 5. Kapitel Systemsoftware: Prozesse und Prozesswechsel
Wintersemester 2016/2017 5 Kapitel Systemsoftware: Prozesse und Prozesswechsel Prof Matthias Werner 5 Professur Betriebssysteme Betriebssystem Das Laden von Programmen ist ein Dienst, der zur Laufzeit
MehrGeräteverwaltung: Einführung
Geräteverwaltung: Einführung Die Ziele einer Geräteverwaltung sind: Einfache Softwareschnittstelle Gleiche Software Schnittstellen für alle Geräte eines Gerätetyps z.b.: unabhängig vom Soundkartenhersteller
MehrÜbung zu Grundlagen der Betriebssysteme. 10. Übung 18.12.2012
Übung zu Grundlagen der Betriebssysteme 10. Übung 18.12.2012 Aufgabe 1 a) Was versteht man unter einem kritischen Abschnitt oder kritischen Gebiet (critical area)? b) Welche Aufgabe hat ein Semaphor? c)
MehrLeichtgewichtsprozesse
Leichtgewichtsprozesse häufiger Prozeßwechsel stellt in einem Betriebssystem eine hohe Belastung dar; auch erfordert die Generierung eines neuen Prozesses viele System-Resourcen in vielen Anwendungen werden
MehrLeichtgewichtsprozesse
Leichtgewichtsprozesse häufiger Prozeßwechsel stellt in einem Betriebssystem eine hohe Belastung dar; auch erfordert die Generierung eines neuen Prozesses viele System-Resourcen in vielen Anwendungen werden
MehrPROGRAMMIEREN MIT UNIX/LINUX-SYSTEMAUFRUFEN
PROGRAMMIEREN MIT UNIX/LINUX-SYSTEMAUFRUFEN 2. UNIX/Linux-Prozessverwaltung und zugehörige Systemaufrufe Wintersemester 2015/16 2. Die UNIX/LINUX-Prozessverwaltung Aufgaben: 1. Erzeugen neuer Prozesse
MehrG Einführung in Betriebssysteme
Einführung in Betriebssysteme 1997-2003, Franz J. Hauck, Verteilte Systeme, Univ. Ulm [2003s-TI1--OS.fm, 2003-06-23 16.28] 1 1 Einordnung Ebene 6 Problemorientierte Sprache Ebene 5 Assemblersprache Ebene
MehrExtended Scope. Events und Mailboxen. Florian Franzmann Tobias Klaus Florian Korschin Florian Schmaus Peter Wägemann
Extended Scope Events und Mailboxen Florian Franzmann Tobias Klaus Florian Korschin Florian Schmaus Peter Wägemann Friedrich-Alexander-Universität Erlangen-Nürnberg Lehrstuhl Informatik 4 (Verteilte Systeme
Mehruntermstrich SYNC Handbuch
Handbuch 03/2017 Inhaltsverzeichnis 1. Einleitung... 2 2. Installation... 3 2.1 Systemanforderungen... 3 2.2 Vorbereitungen in Microsoft Outlook... 3 2.3 Setup... 4 3. SYNC-Einstellungen... 6 3.1 Verbindungsdaten...
MehrKapitel 2: Betriebssysteme
LUDWIG- MAXIMILIANS- UNIVERSITY MUNICH DEPARTMENT INSTITUTE FOR INFORMATICS Skript zur Vorlesung: Einführung in die Informatik: Systeme und Anwendungen Sommersemester 2013 Kapitel 2: Betriebssysteme Vorlesung:
MehrProzesszustände (1a)
Prozesszustände (1a) NOT EXISTING DELETED CREATED Meta-Zustand (Theoretische Bedeutung) Prozesszustände Multiuser Umfeld (1c) Hintergrund-Prozess - der Prozess startet im Hintergrund - my-commandbin &
MehrGrundlagen der Informatik für Ingenieure I. 5. Prozessverwaltung - Einführung
Background: 5. Prozessverwaltung - Einführung 5.1 Wichtige Komponenten eines Prozessors 5.2 Betriebsstrategien von Rechensystemen 5.2.1 Aktivitätsträger, Prozesse, Threads 5.2.1.1 Prozesszustände 5.2.1.2
MehrBetriebssysteme eine Einführung. Peter Puschner Institut für Technische Informatik
Betriebssysteme eine Einführung Peter Puschner Institut für Technische Informatik peter@vmars.tuwien.ac.at 1 Betriebssystem Was ist das? Peter Puschner, TU Wien Vorlesung Betriebssysteme, Einführung; WS
MehrU8 POSIX-Threads U8 POSIX-Threads
U8 POSIX-Threads U8 POSIX-Threads Motivation Thread-Konzepte pthread-api pthread-koordinierung U8.1 U8-1 Motivation von Threads U8-1 Motivation von Threads UNIX-Prozesskonzept: eine Ausführungsumgebung
Mehr4. Übung - Rechnerarchitektur/Betriebssysteme
4. Übung - Rechnerarchitektur/Betriebssysteme 1. Aufgabe: Caching Informatik I für Verkehrsingenieure Aufgaben inkl. Beispiellösungen a) Was ist ein Cache? Wann kommt Caching zum Einsatz? b) Welchen Vorteil
MehrProseminar: Konzepte von Betriebsystem-Komponenten (KVBK)
Proseminar: Konzepte von Betriebsystem-Komponenten (KVBK) Schwerpunkt Linux Interrupts, Softirqs, Tasklets, Bottom Halves Interrupts: Softirqs, Tasklets, Bottom Halves 1 Thomas Engelhardt Übersicht: Klassifizierung
MehrU8-1 Motivation von Threads. U8-2 Vergleich von Thread-Konzepten. U8-2 Vergleich von Thread-Konzepten (2) Motivation
U8 POSIX-Threads U8 POSIX-Threads U8-1 Motivation von Threads U8-1 Motivation von Threads Motivation Thread-Konzepte UNIX-Prozesskonzept: eine Ausführungsumgebung (virtueller Adressraum, Rechte, Priorität,...)
MehrNetzwerk-Programmierung. Prozesse. Alexander Sczyrba Michael Beckstette.
Netzwerk-Programmierung Prozesse Alexander Sczyrba Michael Beckstette {asczyrba,mbeckste@techfak.uni-bielefeld.de 1 Übersicht Prozesse fork() Parents und Childs system() und exec() 2 Prozesse moderne Betriebssysteme
MehrPaging. Einfaches Paging. Paging mit virtuellem Speicher
Paging Einfaches Paging Paging mit virtuellem Speicher Einfaches Paging Wie bisher (im Gegensatz zu virtuellem Speicherkonzept): Prozesse sind entweder ganz im Speicher oder komplett ausgelagert. Im Gegensatz
MehrProgramme werden durch den Ablauf eines oder mehrerer Prozesse (engl.: process, task) von einem Rechner abgearbeitet.
Prozessverwaltung Prozesse Programme werden durch den Ablauf eines oder mehrerer Prozesse (engl.: process, task) von einem Rechner abgearbeitet. Prozesse sind Abfolgen von Aktionen, die unter Kontrolle
MehrBetriebssysteme Kap A: Grundlagen
Betriebssysteme Kap A: Grundlagen 1 Betriebssystem Definition DIN 44300 Die Programme eines digitalen Rechensystems, die zusammen mit den Eigenschaften dieser Rechenanlage die Basis der möglichen Betriebsarten
MehrÜbung 1 - Betriebssysteme I
Prof. Dr. Th. Letschert FB MNI 13. März 2002 Aufgabe 0: Basiswissen Rechnerarchitektur: Übung 1 - Betriebssysteme I Aus welchen Komponenten besteht ein Rechner mit Von-Neumann Architektur? Was sind Bits
MehrDHBW Stuttgart, Studiengang Elektrotechnik, 5. HJ, Vorlesung: Realzeitsysteme Sep 2012. 4) Task-Verwaltung
Inhalte Eigenschaften von Rechenprozessen (Tasks) Taskübergänge (process control block) Multitasking (kooperativ und präemptiv) Scheduler Erzeugen, Starten und Beenden von Tasks Taskzustände (running,
MehrRTOS Einführung. Version: Datum: Autor: Werner Dichler
RTOS Einführung Version: 0.0.1 Datum: 20.07.2013 Autor: Werner Dichler Inhalt Inhalt... 2 RTOS... 3 Definition... 3 Anforderungen... 3 Aufgaben... 3 Eigenschaften... 4 Einteilung der Betriebssysteme...
MehrTafelübung zu BS 2. Threadsynchronisation
Tafelübung zu BS 2. Threadsynchronisation Olaf Spinczyk Arbeitsgruppe Eingebettete Systemsoftware Lehrstuhl für Informatik 12 TU Dortmund olaf.spinczyk@tu-dortmund.de http://ess.cs.uni-dortmund.de/~os/
Mehr