1 / 121

Sommario degli argomenti

Sommario degli argomenti. Sistemi operativi : DOS, Unix/Linux,Windows Word processors : Word Fogli elettronici : Excel Sistemi per la gestione di basi di dati : Access Reti : TCP/IP, Internet, ftp, telnet, posta elettronica WWW : http, Netscape, HTML, motori di ricerca. Sistemi Operativi.

Download Presentation

Sommario degli argomenti

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Sommario degli argomenti Sistemi operativi: DOS, Unix/Linux,Windows Word processors: Word Fogli elettronici: Excel Sistemi per la gestione di basi di dati: Access Reti: TCP/IP, Internet, ftp, telnet, posta elettronica WWW: http, Netscape, HTML, motori di ricerca

  2. Sistemi Operativi Insieme di programmi che gestiscono l’hardware Hardware: Processori Memorie Dispositivi di I/O Detto software di base Software applicativo: insieme dei programmi scritti dall’utente

  3. Bootstrap Fase iniziale che carica il SO in memoria principale (RAM) Prima una parte, che poi ne carica un’altra, ..., fino a che tutto il SO e’ in memoria e in esecuzione

  4. Comandi al SO Attivano l’esecuzione di un programma del SO Il program counter viene modificato per contenere l’indirizzo d’inizio del programma Alla fine si puo’ dare un nuovo comando

  5. Shutdown Memorizza su memoria di massa (non volatile) tutte le informazioni temporaneamente in RAM Se non viene effettuata (es.: guasto)  queste informazioni vengono perse

  6. SO di oggi Possono gestire: Piu’ utenti anche con un solo processore Piu’ programmi per ogni utente Senza che gli utenti se ne rendano conto Macchina virtuale: tanti processori virtuali, uno per ogni programma

  7. Virtualizzazione Molti programmi in esecuzione  simultanea presenza in memoria centrale possibili conflitti  memoria virtuale (come si si avesse piu’ memoria di quella reale) Anche dispositivi di I/O virtuali gestione simultanea di piu’ richieste (es., stampe)

  8. Indipendenza dall’hardware SO sempre piu’ indipendenti dall’hardware Riduce la porzione di codice da modificare per poter usare un SO su un altro calcolatore Programmi applicativi piu’ portabili

  9. Vari SO Negli anni ’80, molti SO Poi, convergenza su pochi SO: DOS (Microsoft) Unix e Linux Windows (Microsoft)

  10. Modalita’ utente/supervisore Nei primi SO, ogni programma poteva attivare ogni altro programma Per dare una struttura, solo Modalita’ utente: permesso di attivare solo alcune procedure Modalita’ supervisore: tutto permesso

  11. SO strutturati In seguito, struttura in livelli Ogni livello si appoggia a quello inferiore Livello piu’ basso: nucleo (kernel) Il nucleo gestisce le funzioni di base

  12. Modello client/server Macchine con caratteristiche diverse collegate in rete Su ogni macchina, vengono eseguiti i programmi che piu’ si adattano alle sue caratteristiche Interfaccia utente e grafica su PC (cliente) Gestione risorse condivise e programmi pesanti su macchine piu’ potenti (server) Un server e molti client

  13. Vantaggi e svantaggi Riduzione del carico sui sistemi centrali Maggiori garanzie di sicurezza e integrita’ Maggiore modularita’ e uniformita’ Maggiore flessibilita’ Necessita’ di rete veloce Maggior oneri di gestione dell’intero sistema

  14. Funzioni del SO Programmi suddivisi in moduli Ogni modulo ha una funzione diversa Funzioni piu’ importanti: gestione processori gestione processi gestione memoria (principale e secondaria) gestione dispositivi di I/O

  15. Servizi richiesti dagli utenti al SO Interfaccia nucleo verso l’esterno File system Gestore I/O Gestore processi Gestore memoria Gestore processori nucleo hardware Struttura di un SO

  16. Gestione dei processi Controlla la sincronizzazione, interruzione e riattivazione dei programmi in esecuzione Piu’ programmi si alternano nell’uso della CPU Ogni programma puo’ essere: Eseguito Sospeso Fatto ripartire Struttura che mantiene lo stato di avanzamento di ogni programma: processo.

  17. Esempio: esecuzione di una ricetta Ricetta = programma Noi = processore Ingredienti = dati in input Attivita’ di leggere la ricetta, usare gli ingredienti, mescolare, cuocere = processo Telefonata durante l’esecuzione della ricetta = interrupt Il processo interrompe l’esecuzione, prende nota del punto (riga della ricetta, ...) e gestisce l’evento Alla fine della telefonata, l’esecuzione riprende e viene conclusa Dolce = output

  18. Vari processi in esecuzione • Bisogna gestire anche • Condivisione risorse fisiche (CPU, memoria) • Condivisione risorse logiche (dati) • Modularita’: piu’ processi per una singola operazione • Maggiore velocita’ per parallelismo tra processi • Anche piu’ processi per un programma • Es.: piu’ programmatori usano lo stesso editore di testi

  19. Ambiente monotasking • Viene gestita l’esecuzione di un solo programma per volta • L’esecuzione non puo’ essere sospesa (per assegnare la CPU ad un altro programma)  prima bisogna terminare l’esecuzione in corso • Alla terminazione di un programma, si puo’ attivare un altro programma • Piu’ programmi attivati con un solo comando: job

  20. Svantaggi del monotasking • Lentezza: • la CPU non puo’ essere usata da nessun processo mentre il programma in esecuzione svolge operazioni di I/O (molto piu’ lente di letture/scritture in Memoria) • DOS e’ un SO monotasking: non si puo’ fare niente altro mentre si formatta un floppy o si memorizzano dati su disco

  21. Ambiente multitasking • SO che permettono l’esecuzione contemporanea di piu’ programmi • Se una sola CPU esecuzione contemporanea virtuale (una sola istruzione alla volta) • Minimizzano il tempo di inattivita’ ella CPU durante le operazioni di I/O, che possono anche occupare l’80% del tempo

  22. Time sharing • Ripartizione del tempo di CPU tra tutti i processi che la vogliono • Durata del quanto di tempo: tra 100 e 200 millisecondi  granularita’ molto fine • A ciascun utente sembra di avere la CPU tutta per lui, solo piu’ lenta

  23. Coda dei processi pronti • I processi sono messi in una coda • Il processo in cima alla coda ha a disposizione la CPU per un quanto di tempo, fissato e uguale per tutti • Quando il tempo finisce, viene interrotto e messo in fondo alla coda • Se richiede un’operazione di I/O, va nel gruppo dei processi sospesi, quando l’operazione finisce viene rimesso in coda per la CPU • La CPU va al primo in coda

  24. Stati dei processi • Durante la vita di un processo, vari stati: • In esecuzione: quando usa la CPU (solo un processo alla volta) • Pronto: quando aspetta la CPU • Bloccato: in attesa di un evento (es.: fine di op. di I/O) • Passaggio da uno stato ad un altro: context switching

  25. In esecuzione richiesta di I/O schedulazione fine tempo, evento esterno pronti bloccati conclusione I/O Coda ordinata in attesa della CPU Insieme in attesa di eventi Transizioni tra stati

  26. Interrupt • Segnali hardware • Collegati al verificarsi di un evento • Provocano l’esecuzione immediata di un programma del SO (vettore di interrupt) che serve a gestire l’evento • Una CPU puo’ gestire piu’ interrupt • Interrupt anche per fine di quanto di tempo (generato dal timer)

  27. Tipi di interrupt • Rilevazione malfunzionamento hardware • Fine del quanto di tempo • Arrivo di dati in input • Rilevazione di segnali da sensori • Rilevazione di errori software Ogni interruzione ha la sua priorita’, cosi’ il processo che la gestisce puo’ interrompere solo processi con priorita’ inferiore

  28. Tabelle dei processi • Ogni processo ha una sua tabella che lo descrive, che contiene: • Identificativo • Indirizzo prossima istruzione • Contenuto registri CPU • Stato corrente (pronto, bloccato, esecuzione) • Collocazione programma e dati in memoria • Priorita’ • Ammontare CPU time gia’ speso • …

  29. Operazioni sui processi • La tabella e’ sempre in memoria centrale (per accedervi velocemente) • Usando le informazioni contenute nella tabella, si possono fare varie operazioni: • Creazione di nuovi processi • Cambio di priorita’ • Blocco • Assegnamento della CPU • Terminazione

  30. Processi concorrenti • Necessita’ di sincronizzazione e comunicazione • Threads: cammini di esecuzione della CPU su un programma • Piu’ thread possono condividere codice, dati, memoria, file, … • Task: insieme di thread e delle cose condivise tra loro • Processo tradizionale: un solo task con un solo thread

  31. Processi indipendenti o concorrenti • Processi indipendenti: • L’esecuzione di un processo non e’ influenzata da quella degli altri processi • Dipende solo dall’input (deterministica) • Processi cooperanti o concorrenti: • Lo stato puo’ essere influenzato da altri processi, e dati condivisi • Esecuzione non deterministica (dipende dalle velocita’ relative dei processi)

  32. Pipe • Permette il passaggio dei dati tra due processi • I dati sono messi da una parte di un ‘’tubo’’ (pipe) da un processo ed estratti dall’altro lato, nello stesso ordine, da un altro processo • Molto usato nel SO Unix

  33. Coda di messaggi • Esplicite funzioni per scambio messaggi: (send e receive) • Scambio di messaggi tra piu’ processi • Messaggi gestiti secondo il loro arrivo in coda

  34. Condivisione di memoria • Forma di comunicazione piu’ veloce • Pero’ anche piu’ difficile da implementare: bisogna evitare che piu’ processi modifichino contemporaneamente gli stessi dati • Meccanismi piu’ usati: semafori, monitor, rendez-vous

  35. Gestione dei processori • Criteri in base ai quali i processori vengono assegnati ai processi • Programma schedulatore: • Distribuisce il tempo di CPU tra i processi • Decide l’avvicendamento dei processi

  36. Criteri per lo schedulatore • Massimo tasso di uso della CPU • Massimo numero di processi completati per unita’ di tempo (throughput) • Minimo tempo tra la sottomissione di un processo e il suo completamento • Minimo tempo passato in attesa nella coda dei processi pronti

  37. Gestione della coda dei pronti:FIFO • FIFO (first in, first out): • Secondo l’ordine di arrivo, senza interruzione • Implementazione banale • Tempo di attesa non minimizzato

  38. Gestione della coda dei pronti:altri metodi • SJF (Shortest Job First): prima i processi piu’ corti • Round-robin: con quanti di tempo associati a FIFO • Scadenza: prima i processi con la scadenza piu’ vicina • SRT (Shortest Remaining Time): prima i processi a cui manca meno tempo per finire

  39. Gestione della memoria principale • Criteri per allocare la memoria principale tra piu’ entita’ che la richiedono: • SO • Processi • Buffer di I/O • …

  40. Vari tipi di memoria • Memoria principale: • Veloce da accedere • Volatile • Piccola • Programmi da eseguire devono risiedere qui • Granularita’fine (bit o byte) • Memoria di massa (o secondaria): • Molto piu’ grande e meno costosa • Non volatile • Lunghi tempi di accesso • Granularita’ non fine (blocchi di byte)

  41. SO programma dati Gestione della memoria reale • Alloco una prima parte di M per il SO • Poi una parte contigua successiva al programma in esecuzione e ai suoi dati •  Limiti alla grandezza del programma • Overlay: • carico il M solo la sezione del programma che serve ora • Il programmatore deve suddividere il programma in sezioni

  42. Partizioni della memoria reale • Piu’ task  partizioni della memoria • Partizioni fisse:un pezzo fisso di memoria per ciascun processo • Partizioni variabili: minimo spazio per l’esecuzione di un processo • Frammentazione: • Dopo vari caricamenti e scaricamenti, nessuna porzione libera e’ grande abbastanza per il prossimo programma •  ricompattamento delle parti libere (garbage collection)

  43. Memoria virtuale • Tecnica per • Svincolare il codice di un programma dalla sua collocazione in memoria • Funzionare come se si avesse piu’ memoria di quella reale • Da indirizzi virtuali (usati dai programmi) a indirizzi reali (per l’accesso alla RAM)

  44. Indirizzi virtuali e reali -- esempio • Processore a 32 bit 232 indirizzi, da 0 a 232(4 gigabyte) • RAM di solito con alcun centinaia di megabyte • Il programma puo’ usare tutti gli indirizzi, anche se non ci sono cosi’ tante celle di memoria • Gli indirizzi sono virtuali e vengono poi tradotti in indirizzi fisici • Basta che non tutti gli indirizzi fisici siano usati assieme

  45. Gestione della memoria secondaria • Fatta dal modulo del SO detto file system, che si occupa di: • Associare un nome di file ad una parte dello spazio di memoria • Fornire metodi per accedere ai file • Rendere trasparente la struttura fisica della memoria • Ottimizzare l’occupazione di memoria

  46. File • Unica unita’ logica di informazione usata dal SO • Fisicamente: • sequenza di byte che contiene informazioni omogenee • Es.: programma, testo, dati simili, … • Byte = 8 bit • Tutti i dati vengono suddivisi in file • I file vengono memorizzati nelle memorie di massa

  47. Modi di accesso a un file -- 1 • Byte-stream: • File = sequenza di byte • Soprattutto per file di testo • Sequenziale: • File = sequenza di record di lunghezza fissa o variabile • Record = sequenza di byte • Accesso sequenziale ai record

  48. Modi di accesso a un file -- 2 • Diretto: • File = sequenza di record di lunghezza fissa • Accesso immediato ai record • A indice: • File = sequenza di record ordinati secondo un indice • Record = valore dell’indice + informazione • Due file: uno per i record, e uno per indici + indirizzo fisico del record con qull’indice • Accesso veloce, ma piu’ spazio

  49. Organizzazione dei file • Organizzazione gerarchica • Solo logicamente, nessuna relazione con la posizione fisica sulle memorie di massa • Directory: gruppo di file e altre directory, piu’ elenco

  50. directory file Organizzazione ad albero • Albero rovesciato (come genealogico) • Nodi e collegamenti padre-figlio tra nodi • Nodo: file o directory • Nodi divisi per livelli • Collegamenti tra nodi di livelli vicini: nodo sopra = padre, nodo sotto = figlio • Ogni nodo ha un solo padre • Padre piu’ in alto = radice • I nodi file non hanno figli • Cammino assoluto o relativo (per file)

More Related