Modelli di interazione tra processi
|
|
|
- Alina Torre
- 9 anni fa
- Visualizzazioni
Transcript
1 Modelli di interazione tra processi
2 Modelli di interazione Modello a memoria comune (ambiente globale) Modello a scambio di messaggi (ambiente locale, message passing)
3 Modello a memoria comune Il sistema è visto come un insieme di processi oggetti (risorse) O2 Diritto di accesso P1 P2 O3 O1, O4 risorse private O1 P3 O4 O2, O3 risorse comuni Tipi di interazioni tra processi: - competizione - cooperazione
4 Il modello a memoria comune rappresenta la naturale astrazione del funzionamento di un sistema in multiprogrammazione costituito da uno o più processori che hanno accesso ad una memoria comune O2 O3 Memoria comune P1 P2. Pn PR1 PR2 PRn Ad ogni processore può essere associata una memoria privata, ma ogni interazione avviene tramite oggetti contenuti nella memoria comune
5 Modello a scambio di messaggi Il sistema è visto come un insieme di processi ciascuno operante in un ambiente locale che non è accessibile a nessun altro processo. P1 canali P2 canali P3 Ogni forma di interazione tra processi avviene tramite scambio di messaggi. Non esiste più il concetto di risorsa accessibile direttamente ai processi; sono possibili due casi: alla risorsa è associato un processo servitore la risorsa viene passata da un processo all altro sotto forma di messaggi
6 Il modello a scambio di messaggi rappresenta la naturale astrazione di un sistema privo di memoria comune, in cui a ciascun processore è associata una memoria privata PR1 PR2 PRn M1 M2 Mn Il modello a scambio di messaggi può essere realizzato anche in presenza di memoria comune, che viene utilizzata per realizzare canali di comunicazione.
7 Modello a memoria comune
8 Aspetti caratterizzanti Ogni applicazione viene strutturata come un insieme di componenti, suddiviso in due sottoinsiemi disgiunti: processi (componenti attivi) risorse (componenti passivi). Risorsa: Qualunque oggetto, fisico o logico, di cui un processo necessita per portare a termine il suo compito. Le risorse sono raggruppate in classi; ogni classe identifica l insieme di tutte e sole le operazioni che un processo può eseguire per operare su risorse di quella classe. Il termine risorsa si identifica con quello di struttura dati allocata nella memoria comune.
9 Risorsa privata di un processo P (o locale a P):P è il solo processo che può eseguire operazioni sulla risorsa. Risorsa comune (o globale): è una risorsa su cui più processi possono operare. In un modello a memoria comune i processi interagiscono esclusivamente operando su risorse comuni (competizione e cooperazione). Meccanismo di controllo degli accessi: è necessario definire quali processi ed in quali istanti possono correttamente accedere alla risorsa. Allocatore o gestore di una risorsa R: entità che ha il compito di definire in ogni istante t l insieme SR(t) dei processi che possono accedere ad R in quell istante.
10 Allocazione delle risorse Risorsa allocata staticamente. Il gestore di R definisce l insieme SR all istante T 0 (istante iniziale dell elaborazione) senza modificarlo durante l elaborazione. Il gestore della risorsa è il programmatore che in base alle scope rules del linguaggio stabilisce quale processo possa vedere e quindi elaborare la risorsa. Il compito di controllare gli accessi è svolto dal compilatore che, secondo le regole di visibilità, assicura che soltanto i processi ai quali la risorsa è stata allocata possano accedervi.
11 Allocazione delle Risorse Risorsa allocata dinamicamente L insieme SR è variabile nel tempo: a) Risorsa dedicata. Sr(t) contiene al più un processo b) Risorsa condivisa. Sr(t) contiene più processi contemporaneamente Il gestore della risorsa opera a tempo di esecuzione. Nel modello a memoria comune il gestore è una risorsa (nel modello a scambio di messaggi è un processo). Sr(t) è inizialmente vuoto. Per operare sulla risorsa il processo deve chiedere il permesso al gestore. Il gestore può accettare, ritardare o rifiutare la richiesta. Schema logico seguito dal processo: 1) richiesta della risorsa, 2) uso 3) rilascio del diritto di accedere.
12 risorsa dedicata risorsa condivisa risorsa allocata staticamente privata comune ai processi cui la risorsa è allocata risorsa allocata dinamicamente comune comune Una risorsa allocata staticamente e dedicata ad un solo processo è una risorsa privata. In tutti gli altri casi le risorse sono comuni, o perché condivise tra più processi o perché dedicate, ma dinamicamente, a processi diversi in tempi diversi.
13 Meccanismi linguistici per la programmazione di interazioni Per presentare alcuni meccanismi linguistici usati nella programmazione di interazioni tra processi si seguirà il seguente schema: 1. Presentazione del meccanismo 2. Esempi di uso del meccanismo 3. Traduzione del meccanismo linguistico in termini di un meccanismo primitivo di sincronizzazione fornito dal supporto a tempo di esecuzione (nucleo) Il meccanismo primitivo di riferimento è quello semaforico con le due operazioni wait e signal (Dijkstra).
MODELLO A MEMORIA COMUNE. Aspetti caratterizzanti
MODELLO A MEMORIA COMUNE Aspetti caratterizzanti 1 Ogni applicazione viene strutturata come un insieme di componenti, suddiviso in due sottoinsiemi disgiunti: processi (componenti attivi) e risorse (componenti
Modelli di interazione tra processi
Modelli di interazione tra processi Modello a memoria comune (ambiente globale, global environment) Modello a scambio di messaggi (ambiente locale, message passing) 1 Modello a memoria comune Il sistema
Modelli di interazione tra processi
Modelli di interazione tra processi Modello a memoria comune (ambiente globale, global environment) Modello a scambio di messaggi (ambiente locale, message passing) 1 Modello a memoria comune Il sistema
Le risorse. Alcune definizioni
Le risorse Dicesi risorsa un qualunque oggetto, fisico o logico, di cui un processo necessita per portare a termine la sua evoluzione. Poiché un processo evolve eseguendo istruzioni (procedure), una risorsa
Modello a scambio di messaggi
Modello a scambio di messaggi Aspetti caratterizzanti il modello Canali di comunicazione Primitive di comunicazione 1 Aspetti caratterizzanti il modello modello architetturale di macchina (virtuale) concorrente
Il Modello a scambio di messaggi
Il Modello a scambio di messaggi 1 Interazione nel modello a scambio di messaggi Se la macchina concorrente e` organizzata secondo il modello a scambio di messaggi: PROCESSO=PROCESSO PESANTE non vi è memoria
Università di Roma Tor Vergata Corso di Laurea triennale in Informatica Sistemi operativi e reti A.A Pietro Frasca.
Università di Roma Tor Vergata Corso di Laurea triennale in Informatica Sistemi operativi e reti A.A. 2016-17 Pietro Frasca Lezione 8 Martedì 8-11-2016 1 Algoritmi di scheduling basati sulle priorità Assegnano
Linguaggi, Traduttori e le Basi della Programmazione
Corso di Laurea in Ingegneria Civile Politecnico di Bari Sede di Foggia Fondamenti di Informatica Anno Accademico 2011/2012 docente: Prof. Ing. Michele Salvemini Sommario Il Linguaggio I Linguaggi di Linguaggi
Funzioni, Stack e Visibilità delle Variabili in C
Funzioni, Stack e Visibilità delle Variabili in C Programmazione I e Laboratorio Corso di Laurea in Informatica A.A. 2016/2017 Calendario delle lezioni Lez. 1 Lez. 2 Lez. 3 Lez. 4 Lez. 5 Lez. 6 Lez. 7
Il Sistema Operativo. Informatica Sistema Operativo 1
Il Sistema Operativo Informatica Sistema Operativo 1 O.S.:.: un intermediario SW Applicativo Sistema Operativo HW Informatica Sistema Operativo 2 O.S. vs applicativi Applicativi accesso a un insieme ridotto
Processi non sequenziali e tipi di interazione
Processi non sequenziali e tipi di interazione Algoritmo, programma, processo Algoritmo: Procedimento logico che deve essere eseguito per risolvere un determinato problema. Programma: Descrizione di un
Sistemi Operativi. Lezione 7-bis Esercizi
Sistemi Operativi Lezione 7-bis Esercizi Esercizio Problema dei lettori e scrittori Un insieme di processi condivide un file dal quale alcuni possono solo leggere i dati, altri solo scriverli Più lettori
I SISTEMI OPERATIVI. Insieme di programmi che implementano funzioni essenziali per l uso di un sistema elaboratore.
I SISTEMI OPERATIVI Insieme di programmi che implementano funzioni essenziali per l uso di un sistema elaboratore. Le funzioni di un S.O. non sono definibili in modo esaustivo e puntuale così come non
Il Modello a scambio di messaggi
Il Modello a scambio di messaggi PRIMITIVE PER LO SCAMBIO DI MESSAGGI Un messaggio si può considerare costituito da: origine, destinazione e contenuto typedef struct{ origine; destinazione; contenuto;
AXO - Architettura dei Calcolatori e Sistema Operativo. organizzazione strutturata dei calcolatori
AXO - Architettura dei Calcolatori e Sistema Operativo organizzazione strutturata dei calcolatori I livelli I calcolatori sono progettati come una serie di livelli ognuno dei quali si basa sui livelli
Visibilità e tempo di vita delle variabili. (più sintesi di alcuni concetti della prima parte del corso)
Visibilità e tempo di vita delle variabili (più sintesi di alcuni concetti della prima parte del corso) Struttura dei programmi C/C++ Un programma C/C++ deve essere contenuto in uno o più file (per ora
Modelli di programmazione parallela
Modelli di programmazione parallela Oggi sono comunemente utilizzati diversi modelli di programmazione parallela: Shared Memory Multi Thread Message Passing Data Parallel Tali modelli non sono specifici
Modello a scambio di messaggi
Modello a scambio di messaggi PRIMITIVE PER LO SCAMBIO DI MESSAGGI Un messaggio si può considerare costituito da: origine, destinazione e contenuto type messaggio = record origine:. ; destinazione:. ;
Corso di Linguaggi di Programmazione
Corso di Linguaggi di Programmazione Lezione 20 Alberto Ceselli [email protected] Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 14 Maggio 2013 Programmazione concorrente:
PROCESSI NON SEQUENZIALI E TIPI DI INTERAZIONE
PROCESSI NON SEQUENZIALI E TIPI DI INTERAZIONE 1 ALGORITMO, PROGRAMMA, PROCESSO Algoritmo Procedimento logico che deve essere eseguito per risolvere un determinato problema. Programma Descrizione di un
ACSO Programmazione di Sistema e Concorrente
ACSO Programmazione di Sistema e Concorrente P2 Modello Thread 2/12/2015 programma e parallelismo il tipo di parallelismo dipende dal grado di cooperazione (scambio di informazione) necessario tra attività
Organizzazione di un SO monolitico
Organizzazione di un SO monolitico Applicazioni Interprete di comandi (shell) Interfaccia grafica (desktop) Gestore del Gestore delle processore / Gestore della periferiche/ Scheduler(s) memoria dispositivi
SEMAFORI SEMAFORI. Sul semaforo sono ammesse solo due operazioni (primitive)
SEMAFORI 1 SEMAFORI Variabile intera non negativa con valore iniziale >= 0 Al semaforo è associata una lista di attesa Qs nella quale sono posti i descrittori dei processi che attono l autorizzazione a
Linguaggio C: le funzioni. Visibilità variabili e passaggio parametri
Dipartimento di Elettronica ed Informazione Politecnico di Milano Informatica e CAD (c.i.) - ICA Prof. Pierluigi Plebani A.A. 2008/2009 Linguaggio C: le funzioni. Visibilità variabili e passaggio parametri
Il Sistema Operativo
Il Sistema Operativo Il sistema operativo Con il termine sistema operativo si intende l insieme di programmi e librerie che opera direttamente sulla macchina fisica mascherandone le caratteristiche specifiche
Caratteristiche di un linguaggio ad alto livello
Caratteristiche di un linguaggio ad alto livello Un linguaggio ad alto livello deve offrire degli strumenti per: rappresentare le informazioni di interesse dell algoritmo definire le istruzioni che costituiscono
Scope, Memoria e Tabella dei Simboli
Scope, Memoria e Tabella dei Simboli La tabella dei simboli è uno strumento fondamentale attraverso il quale interpreti e compilatori implementano la traduzione da un programma scritto in un linguaggio
