Grundlagen der Betriebssysteme
- Semester:
- Wintersemester
- Anrechenbar im:
- Bachelor
- Leistungspunkte
- 5
- Dozent:
- Daniel Lohmann
- Betreuer:
- Björn Fiedler
- E-Mail:
- gbs@sra.uni-hannover.de
- Zeit/Raum:
-
- Vorlesung: Freitag, 10:00-11:30, Online, Präsenz und Aufzeichnung
- Rechnerübung: wöchentlich, siehe Stud.IP
- Stud.IP-Veranstaltung:
Online-Veranstaltung oder Präsenzveranstaltung
Diese Veranstaltung wird in Teilen als Hybridveranstaltung durchgeführt.
Die Vorlesung wird dabei gleichzeitig in Präsenz und synchron in BBB abgehalten.
Gruppenübungen finden nur in Präsenz statt!
Lernziele
Die Veranstaltung vermittelt grundlegende Kenntnisse über den Aufbau, Funktionsweise und systemnahe Verwendung von Betriebssystemen. Behandelt werden, am Modell einer Mehrebenenmaschine, Betriebssystemabstraktionen wie Prozesse, Fäden, virtueller Speicher, Dateien, Gerätedateien und Interprozesskommunikation sowie Techniken für deren effiziente Realisierung. Dazu gehören Strategien für das Prozessscheduling, Latenzminimierung durch Pufferung und die Verwaltung von Haupt- und Hintergrundspeicher. Weiterhin werden die Themen Sicherheit im Betriebssystemkontext und Aspekte der systemnahen Softwareentwicklung in C erörtert. In den vorlesungsbegleitenden Übungen erfolgt eine praktische Vertiefung des Stoffs anhand von Programmieraufgaben in C aus dem Bereich der UNIX-Systemprogrammierung.
Im Vordergrund stehen Betriebssystemfunktionen für Einprozessorsysteme. Spezielle Fragestellungen zu Mehrprozessorsystemen (auf Basis gemeinsamen Speichers) werden nur am Rande und in Bezug auf Funktionen zur Koordinierung nebenläufiger Programme behandelt. In ähnlicher Weise werden Fragen zur Echtzeitverarbeitung ansatzweise nur in Bezug auf die Prozesseinplanung erörtert.
Stoffplan
- Einführung
- Systemnahe Informatik, Mehrebenenmaschine
- Einordnung der Veranstaltung
- Was ist denn nun ein Betriebssystem?
- Aufbau und Organisation der Veranstaltung
- Systemnahe Softwareentwicklung in C (Wiederholung)
- C vs. Java: Syntax, Idiomatik, Philosophie
- Speicherabbildung von Variablen
- Zeiger und Felder
- Zeichenketten in C
- Grundlegende Konzepte
- Mehrebenenmaschine: Vom C-Code zum Programm (in Ausführung)
- Grundlegendes Speichermodell: Code, Data, Stack, Heap
- Maschinenebene vs. Befehlssatzebene (von GRA zu GBS)
- Virtualisierung durch das Betriebssystem: Grundkonzepte im Schnellüberblick
- Dateien und Dateisysteme
- benannte Objekte und hierarchischer Namensraum
- Dateien und Pseudodateien
- Aufbau eines Dateisystems
- Pseudodateisysteme und Gerätesteuerung
- Prozesse und Fäden
- Der Prozessbegriff in der Informatik
- Prozessbegriff in der Mehrebenenmaschine (virtuelle Maschine)
- Faden (als virtueller Prozessor)
- Adressraum (als virtueller Zustandsspeicher)
- Programm (als Handlungsvorschrift)
- Unterbrechungen, Systemaufrufe und Signale
- Mehrebenenmaschine: Grundprinzip des Upcalls
- Ablauf einer Hardwareunterbrechung, cli/sti
- Implizite/explizite Betriebssystemaktivirungen
- Privilegebenen, das Betriebssystem als Herrscher
- Prozesseinplanung
- Ebenen und Kriterien der Einplanung (Scheduling)
- Klassische Scheduling-Verfahren (FCFS, RR/VRR, SJN, ...)
- Echtzeitbetrieb, Multiprozessor-Scheduling
- Linux Scheduler
- Speicherbasierte Interaktion
- Grundprobleme, Lost-Update, Read-Write
- Aktives Warten mit Sperrvariablen, Varianten, Probleme
- Prinzip des passiven Wartens
- Semaphore
- Betriebsmittelverwaltung, Synchronisation und Verklemmung
- Betriebsmittel, Taxonomie (wiederverwendbar/konsumierbar, un/teilbar)
- Livelocks und Deadlocks, 4 Bedingungen
- Klassische Probleme (5 Philosophen, Erzeuger-Verbraucher, Leser-Schreiber)
- Vermeidungs/Verhinderungsansätze
- Interprozesskommunikation
- Speichergekoppelt vs. nachrichtengekoppelt
- send/receive, Semantiken
- Signale
- Pipes und Sockets
- Speicherorganisation
- Adressraummodelle (real, logisch, virtuell)
- Statische Speicherzuteilung
- Dynamische Speicherzuteilung
- Schutz
- Speichervirtualisierung
- Gekachelter Speicher, Paging
- Seitenersetzung im Detail
- Gemeinsamer Speicher, Copy-on-Write
- Arbeitsmengenmodell
Semesterplan
Vorlesung | Übung | |||
Vorlesungstermine | Übungstermine | Hausaufgaben | ||
14.10.24 | Mo | |||
15.10.24 | Di | |||
16.10.24 | Mi | |||
17.10.24 | Do | |||
18.10.24 | Fr | 1. Einführung | Aufgabe 1 | |
19.10.24 | Sa | |||
20.10.24 | So | |||
21.10.24 | Mo | RÜ 1 | ||
22.10.24 | Di | |||
23.10.24 | Mi | |||
24.10.24 | Do | |||
25.10.24 | Fr | 2. Systemnahe Softwareentwicklung in C | Aufgabe 2 | |
26.10.24 | Sa | |||
27.10.24 | So | |||
28.10.24 | Mo | RÜ 2 | ||
29.10.24 | Di | |||
30.10.24 | Mi | |||
31.10.24 | Do | |||
01.11.24 | Fr | 3. Grundlegende Konzepte | Aufgabe 3 | |
02.11.24 | Sa | |||
03.11.24 | So | |||
04.11.24 | Mo | RÜ 3 | ||
05.11.24 | Di | |||
06.11.24 | Mi | |||
07.11.24 | Do | |||
08.11.24 | Fr | 4. Dateien und Dateisysteme | Aufgabe 4 | |
09.11.24 | Sa | |||
10.11.24 | So | |||
11.11.24 | Mo | RÜ 4 | ||
12.11.24 | Di | |||
13.11.24 | Mi | |||
14.11.24 | Do | |||
15.11.24 | Fr | 5. Prozesse und Fäden | Aufgabe 5 | |
16.11.24 | Sa | |||
17.11.24 | So | |||
18.11.24 | Mo | RÜ 5 | ||
19.11.24 | Di | |||
20.11.24 | Mi | |||
21.11.24 | Do | |||
22.11.24 | Fr | 6. Unterbrechungen, Systemaufrufe und Signale | Aufgabe 6 | |
23.11.24 | Sa | |||
24.11.24 | So | |||
25.11.24 | Mo | RÜ 6 | ||
26.11.24 | Di | |||
27.11.24 | Mi | |||
28.11.24 | Do | |||
29.11.24 | Fr | 7. Prozesseinplanung | Aufgabe 7 | |
30.11.24 | Sa | |||
01.12.24 | So | |||
02.12.24 | Mo | RÜ 7 | ||
03.12.24 | Di | |||
04.12.24 | Mi | |||
05.12.24 | Do | |||
06.12.24 | Fr | 8. Speicherbasierte Interaktion | Aufgabe 8 | |
07.12.24 | Sa | |||
08.12.24 | So | |||
09.12.24 | Mo | RÜ 8 | ||
10.12.24 | Di | |||
11.12.24 | Mi | |||
12.12.24 | Do | |||
13.12.24 | Fr | 9. Betriebsmittelverwaltung, Synchronisation und Verklemmung | Aufgabe 9 | |
14.12.24 | Sa | |||
15.12.24 | So | |||
16.12.24 | Mo | RÜ 9 | ||
17.12.24 | Di | |||
18.12.24 | Mi | |||
19.12.24 | Do | |||
20.12.24 | Fr | 10.Interprozesskommunikation | ||
Semesterunterbrechung | ||||
06.01.25 | Mo | |||
07.01.25 | Di | |||
08.01.25 | Mi | |||
09.01.25 | Do | |||
10.01.25 | Fr | Testatklausur | Aufgabe 10 | |
11.01.25 | Sa | |||
12.01.25 | So | |||
13.01.25 | Mo | RÜ 10 | ||
14.01.25 | Di | |||
15.01.25 | Mi | |||
16.01.25 | Do | |||
17.01.25 | Fr | 11. Speicherorganisation | Aufgabe 11 | |
18.01.25 | Sa | |||
19.01.25 | So | |||
20.01.25 | Mo | RÜ 11 | ||
21.01.25 | Di | |||
22.01.25 | Mi | |||
23.01.25 | Do | |||
24.01.25 | Fr | 12. Speichervirtualisierung | Aufgabe 12 | |
25.01.25 | Sa | |||
26.01.25 | So | |||
27.01.25 | Mo | RÜ 12 | ||
28.01.25 | Di | |||
29.01.25 | Mi | |||
30.01.25 | Do | |||
31.01.25 | Fr | Testat Besprechung | ||
ENDE Vorlesungszeit | ||||
Fragestunde | ||||
Klausur |
Abgaben
- Abgabesystem: Die Abgaben werden über unser Abgabesystem via git-Repos abgegeben. Diese werden anschließend bewertet und die Punkte sind ebenfalls in den Repos einsehbar.
- Korrekturhinweise: Die Bewertung findet unter Beachtung der Korrekturhinweise statt.
Vorkenntnisse
- Grundlagen der Rechnerarchitektur, notwendig
- Programmieren in C, notwendig
Literaturempfehlungen
Die genannten Bücher dienen zur Ergänzung des Vorlesungsstoffes, decken ihn aber nicht zu hundert Prozent ab. Die genannte Auflage versteht sich als Mindestauflage, es kann also problemlos eine neuerer Auflage herangezogen werden.
-
- Operating Systems. Internals and Design Principles
-
Prentice Hall PTR2008978-0136006329.
[BibTex]
-
- Operating System Concepts
-
John Wiley & Sons, Inc.20050-471-69466-5.
[BibTex]
-
- Modern Operating Systems
-
Prentice Hall PTR2007978-0136006633.
[BibTex]
-
- Structured Computer Organization
-
Prentice Hall PTR2006978-0131485211.
[BibTex]
Falls die Anwendung der Programmiersprache C noch Schwierigkeiten bereitet:
-
- C als erste Programmiersprache: Vom Einsteiger zum Fortgeschrittenen
-
Vieweg+Teubner2010978-3834812216.
[BibTex]
Anmeldung und weitere Infos
Für diese Veranstaltung ist eine Online-Anmeldung über Stud.IP erforderlich. Bitte registrieren Sie sich (falls noch nicht geschehen) für Stud.IP und tragen Sie sich dort in die entsprechende Veranstaltung ein.