Systèmes distribués : Rappel sur ordre et temps logique

Documents pareils
L exclusion mutuelle distribuée

PROBLEMES D'ORDONNANCEMENT AVEC RESSOURCES

Université de La Rochelle. Réseaux TD n 6

Introduction à JDBC. Accès aux bases de données en Java

Introduction a l'algorithmique des objets partages. Robert Cori. Antoine Petit. Lifac, ENS Cachan, Cachan Cedex. Resume

A.-M. Cubat PMB - Import de notices à partir d un tableur Page 1 Source :

Systèmes Répartis. Mr. Mehrez Boulares, Mr. Nour Ben Yahia

Terminal Infocomm et Poste Infocomm

La conversion de données : Convertisseur Analogique Numérique (CAN) Convertisseur Numérique Analogique (CNA)

PREINSCRIPTION EN LIGNE

Eléments de spécification des systèmes temps réel Pierre-Yves Duval (cppm)

Initiation à la programmation en Python

REALISATION d'un. ORDONNANCEUR à ECHEANCES

FONCTION COMPTAGE BINAIRE ET DIVISION DE FRÉQUENCE

Systemes d'exploitation des ordinateurs

Algorithmique répartie

Sauvegarder et restaurer les données PMB

Chap 4: Analyse syntaxique. Prof. M.D. RAHMANI Compilation SMI- S5 2013/14 1

Transmissions série et parallèle

Cours de Génie Logiciel

UE 503 L3 MIAGE. Initiation Réseau et Programmation Web La couche physique. A. Belaïd

Recherche dans un tableau

Gestion de projets. avec. Microsoft Office PROJECT 2003

3. SPÉCIFICATIONS DU LOGICIEL. de l'expression des besoins à la conception. Spécifications fonctionnelles Analyse fonctionnelle et méthodes

Chapitre 5 : Flot maximal dans un graphe

A. Définition et formalisme

Docteur José LABARERE

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

LE PROBLEME DU PLUS COURT CHEMIN

Certificat Informatique et internet Niveau 1 TD D1. Domaine 1 : Travailler dans un environnement numérique évolutif. 1. Généralités : Filière

Conception des systèmes répartis

Les réseaux cellulaires vers la 3G

2.1 Le point mémoire statique Le point mémoire statique est fondé sur le bistable, dessiné de manière différente en Figure 1.

N oubliez pas de sauvegarder après avoir intégré ce fichier dans votre espace extranet!

La NP-complétude. Johanne Cohen. PRISM/CNRS, Versailles, France.

Chapitre 4 : Exclusion mutuelle

Ordonnancement. N: nains de jardin. X: peinture extérieure. E: électricité T: toit. M: murs. F: fondations CHAPTER 1

Chap III : Les tableaux

Introduction aux algorithmes répartis

3 Les premiers résultats des plans d'actions

MANUEL PROGRAMME DE GESTION DU CPL WI-FI

Code_Aster. Procédure IMPR_RESU aux formats 'RESULTAT' et 'ASTER' 1 But

Chapitre 3. Les distributions à deux variables

1. Création d'un état Création d'un état Instantané Colonnes Création d'un état Instantané Tableau... 4

Configuration de SQL server 2005 pour la réplication

VoIP et "NAT" VoIP et "NAT" 1/ La Traduction d'adresse réseau. 1/ La traduction d'adresse réseau. 1/ La traduction d'adresse réseau

Equipement. électronique

Régler les paramètres de mesure en choisissant un intervalle de mesure 10µs et 200 mesures.

Comme chaque ligne de cache a 1024 bits. Le nombre de lignes de cache contenu dans chaque ensemble est:

Caractéristiques principales : 1. Prise en charge des réseaux GSM et PSTN 2. Quadri-bande : 850/900/1 800/1 900 MHz 3. Enregistrement vocal sur 2

Propagation sur réseau statique et dynamique

Exercices de dénombrement

REGLEMENT DU PROGRAMME INTERNATIONAL DE LA SOLVAY BRUSSELS SCHOOL OF ECONOMICS & MANAGEMENT

Guide de la migration EBICS

MODE OPERATOIRE CIEL GESTION COMMERCIALE VERSION EVOLUTION BTS PME PMI

GEA II Introduction aux probabilités Poly. de révision. Lionel Darondeau

AGASC / BUREAU INFORMATION JEUNESSE Saint Laurent du Var Tel : bij@agasc.fr Word: Les tableaux.

Les réseaux cellulaires

Chapitre III : Qui gère la monnaie? Le cas de la France

Guide pratique

Configuration O.box Table des matières

SUR MODULE CAMÉRA C38A (OV7620)

Vue d'ensemble OBJECTIFS

Série TD 3. Exercice 4.1. Exercice 4.2 Cet algorithme est destiné à prédire l'avenir, et il doit être infaillible! Exercice 4.3. Exercice 4.

Le module Supply Chain pour un fonctionnement en réseau

TD n o 8 - Domain Name System (DNS)

Utiliser les supports d'exemplaires

6.5.2 Reset_Scénario Démarrage_Zibase Mise sous alarme, surveillance Eclairage Allée Temp

TD : Codage des images

1 Mesure de la performance d un système temps réel : la gigue

Référentiel C2i niveau 1 Version 2 :

Timy. Programme Doublage ("Backup") Français

Service client LSC 1

Composition Présidente: Anne-Sophie Peyraud Gabrielle Multone, Josef Hayoz Greffier-rapporteur: Alexandre Vial

Contrôle parental NetAddictFree 8 NetAddictFree 8 - Guide d utilisation

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting

Notice d utilisation. Thermo Call TC3

Transférer et enregistrer les photos sur l'ordinateur

Table des matières. 1. Description du matériel : Données techniques : Présentation de la serrure :... 4

GdsCompta. Logiciel de comptabilité générale

C++ COURS N 2 : CLASSES, DONNÉES ET FONCTIONS MEMBRES Classes et objets en C++ Membres d'une classe Spécification d'une classe Codage du comportement

PORTAIL INTERNET DE LA GESTION PUBLIQUE Guide d'utilisation du Portail Internet de la Gestion Publique

CODE TRANSACTION VA01

1. Introduction Création d'une macro autonome Exécuter la macro pas à pas Modifier une macro... 5

Les chaînes de caractères

TD 2 Chapitre 4 : Support des Services et Serveurs. Objectifs : Maîtriser l'exploitation des tables de routage dynamique.

Windows Internet Name Service (WINS)

1. Contexte général page Le compte auprès de la BCGE...page La procuration 2.2 Les accès e-banking 2.3 Le bon de retrait 2.

1. Introduction Création d'une requête...2

Par combien de zéros se termine N!?

DESCRIPTIF DU DOCUMENT. Déploiement Nouveau système de rémunération au ème salaire

THEMIS-ACCES GESTION DES TEMPS ET DES ACCES

Master IMEA 1 Calcul Stochastique et Finance Feuille de T.D. n o 1

INTRODUCTION AUX SYSTEMES D EXPLOITATION. TD2 Exclusion mutuelle / Sémaphores

CONNECTEUR PRESTASHOP VTIGER CRM

MYOSOTIS. Logiciel de supervision et de conduite de réseau NC. 107/2B

Logiciel d'application Tebis

Modules InnovationCRM

Transcription:

Systèmes distribués : Rappel sur ordre et temps logique Eric Cariou Master Technologies de l'internet 1 ère année Université de Pau et des Pays de l'adour Département Informatique Eric.Cariou@univ-pau.fr 1

Temps dans un système distribué Définir un temps global cohérent et «identique» (ou presque) pour tous les processus Soit synchroniser au mieux les horloges physiques locales avec une horloge de référence ou entre elles Soit créer un temps logique Temps logique Temps qui n'est pas lié à un temps physique But est de pouvoir préciser l'ordonnancement de l'exécution des processus et de leur communication En fonction des événements locaux des processus, des messages envoyés et reçus, on créé un ordonnancement logique Création horloge logique 2

Chronogramme Chronogramme Décrit l'ordonnancement temporel des événements des processus et des échanges de messages Chaque processus est représenté par une ligne Trois types d'événements signalés sur une ligne Émission d'un message à destination d'un autre processus Réception d'un message venant d'un autre processus Événement interne dans l'évolution du processus Les messages échangés doivent respecter la topologie de liaison des processus via les canaux 3

Chronogramme Trois processus tous reliés entre-eux par des canaux Temps de propagation des messages quelconques et possibilité de perte de message 4

Chronogramme Exemples d'événements Processus P1 e11 : événement d'émission du message m1 à destination du processus P2 e13 : événement interne au processus e14 : réception du message m4 venant du processus P3 Processus P2 : message m5 envoyé avant m6 mais m6 reçu avant m5 Processus P3 : le message m7 est perdu par le canal de communication Règle de numérotation d'un événement exy avec x le numéro du processus et y le numéro de l'événement pour le processus, dans l'ordre croissant 5

Dépendance causale Relation de dépendance causale Il y a une dépendance causale entre 2 événements si un événement doit avoir lieu avant l'autre Notation : e e' e doit se dérouler avant e' Si e e', alors une des trois conditions suivantes doit être vérifiée pour e et e' Si e et e' sont des événements d'un même processus, e précède localement e' Si e est l'émission d'un message, e' est la réception de ce message Il existe un événement f tel que e f et f e' Ordonnancement des événements Les dépendances causales définissent des ordres 6 partiels pour des ensembles d'événements du système

Sur exemple précédent Dépendance causale Quelques dépendances causales autour de e12 Localement : e11 e12, e12 e13 Sur message : e12 e34 Par transitivité : e12 e35 (car e34 e35) et e11 e13 Dépendance causale entre e12 et e32? A priori non : absence de dépendance causale Des événements non liés causalement se déroulent en parallèle Relation de parallélisme : e e' ((e e') v (e' e)) Parallélisme logique : ne signifie pas que les 2 événements se déroulent simultanément mais qu'il peuvent se dérouler 7 dans n'importe quel ordre

Horloges logiques Horloges logiques Datation de chacun des événements du système Avec respect des dépendances causales entre evts 3 familles d'horloge Estampille (horloge de Lamport) Une donnée par événement : information au niveau global Vectorielle (horloge de Mattern) Un vecteur par événement : information sur chacun des autres processus Matricielle Une matrice par événement : information sur les informations que connaisse chacun des processus des autres processus 8

Horloge de Lamport Lamport, 1978 Une date (estampille) est associée à chaque évenement : couple (s, nb) s : numéro du processus nb : numéro d'événement Respect dépendance causale e e' H(e) < H(e') Avec H(s, nb) < H(s', nb') si (nb < nb') ou (nb = nb' et s < s') Mais pas la réciproque : H(e) < H(e') (e' e) C'est-à-dire : soit e e', soit e e' Invariant sur les dates Pour deux dates d'un même processus, les numéros de ces dates sont différentes d,d' : d.s = d'.s d.nb d'.nb Il n'y pas deux événements locaux ayant le même numéro 9

Horloge de Lamport Création du temps logique Localement, chaque processus Pi possède une horloge locale logique Hi, initialisée à 0 Sert à dater les événements Pour chaque événement local de Pi Hi = Hi + 1 : on incrémente l'horloge locale L'événement est daté localement par Hi Émission d'un message par Pi On incrémente Hi de 1 puis on envoie le message avec (i, Hi) comme estampille Réception d'un message m avec estampille (s, nb) Hi = max(hi, nb) +1 et marque l'événement de réception avec Hi Hi est éventuellement recalée sur l'horloge de l'autre processus avant d'être incrémentée 10

Horloge de Lamport Exemple : chronogramme avec ajouts des estampilles Date de e23 : 6 car le message m5 reçu avait une valeur de 5 et l'horloge locale est seulement à 3 Date de e34 : 4 car on incrémente l'horloge locale vu que sa valeur est supérieure à celle du message m3 Pour e11, e12, e13... : incrémentation de +1 de l'horloge locale 11

Horloge de Lamport Ordonnancement global Via Hi, on ordonne tous les événements du système entre eux Ordre total obtenu est arbitraire Si dépendance causale entre 2 evts : ordre respecte dépendance Si indépendance causale entre : choix d'un ordre entre les 2 Pas de problème en pratique puisqu'ils sont indépendants Ordre total, noté e << e' : e s'est déroulé avant e' Soit e événement de Pi et e' événement de Pj : e << e' (Hi(e) < Hj(e')) v (Hi(e) = Hj(e') avec i < j) Localement (si i = j), Hi donne l'ordre des événements du processus Les 2 horloges de 2 processus différents permettent de déterminer l'ordonnancement des événements des 2 processus Si égalité de la valeur de l'horloge, le numéro du processus est utilisé pour les ordonner Ordre total global obtenu pour l'exemple e11 << e31 << e12<< e21 << e32 << e13 << e22 << e33 << e14 << e34 12<< e35 << e23 << e24 << e15

Horloge de Mattern Horloge de Mattern & Fidge, 1989-91 Horloge qui assure la réciproque de la dépendance causale H(e) < H(e') e e' Permet également de savoir si 2 événements sont parallèles (non dépendants causalement) Ne définit par contre pas un ordre total global Principe Utilisation de vecteur V de taille égale au nombre de processus Localement, chaque processus Pi a un vecteur Vi Un message est envoyé avec un vecteur de date Pour chaque processus Pi, chaque case Vi[ j ] du vecteur contiendra des valeurs de l'horloge du processus Pj13

Horloge de Mattern Fonctionnement de l'horloge Initialisation : pour chaque processus Pi, Vi =(0,..., 0) Pour un processus Pi, à chacun de ses événements (local, émission, réception) : Vi [ i ] = Vi [ i ] + 1 Incrémentation du compteur local d'événement Si émission d'un message, alors Vi est envoyé avec le message Pour un processus Pi, à la réception d'un message m contenant un vecteur Vm, on met à jour les cases j i de son vecteur local Vi j : Vi [ j ] = max ( Vm [ j ], Vi [ j ]) Mémorise le nombre d'événements sur Pj qui sont sur Pj dépendants causalement par rapport à l'émission du message La réception du message est donc aussi dépendante causalement de ces événements sur Pj 14

Horloge de Mattern Exemple : chronogramme d'application horloge de mattern Même exemple que pour horloge de Lamport 15

Horloge de Mattern Relation d'ordre partiel sur les dates V V' défini par i : V[ i ] V'[ i ] V < V' défini par V V' et j tel que V [ j ] < V' [ j ] V V' défini par ( V < V' ) ( V' < V ) Dépendance et indépendance causales Horloge de Mattern assure les propriétés suivantes, avec e et e' deux événements et V(e) et V(e') leurs datations V(e) < V(e') e e' Si deux dates sont ordonnées, on a forcément dépendance causale entre les événements datés V(e) V(e') e e' Si il n'y a aucun ordre entre les 2 dates, les 2 événements sont indépendants causalement 16

Retour sur l'exemple Horloge de Mattern V(e13) = (3,0,0), V(e14) = (4,0,3), V(e15) = (5,4,5) V(e13) < V(e14) donc e13 e14 V(e14) < V(e15) donc e13 e15 V(e35) = (2,0,5) et V(e23) = (2,3,5) V(e35) < v(e23) donc e35 e23 L'horloge de Mattern respecte les dépendances causales des événements Horloge de Lamport respecte cela également V(e32) = (0,0,2) et V(e13) = (3, 0, 0) On a ni V(e32) < V(e13) ni V(e13) < V(e32) donc e32 e13 L'horloge de Mattern respecte les indépendances causales L'horloge de Lamport impose un ordre arbitraire entre les événéments indépendants causalement 17

Horloge matricielle Horloge matricielle n processus : matrice M de (n x n) pour dater chaque evt Sur processus Pi Ligne i : informations sur événements de Pi Mi [ i, i ] : nombre d'événements réalisés par Pi Mi [ i, j ] : nombre de messages envoyés par Pi à Pj (avec j i) Ligne j (avec j i) Mi [ j, k ] : nombre de messages que l'on sait que Pj a envoyé à Pk Mi [ j, j ] : nombre d'événements que l'on connait sur Pj (avec j k) Un processus Pi a une connaissance sur le nombre de messages qu'un processus Pj a envoyé à Pk Quand on reçoit un message d'un autre processus, on compare l'horloge d'émission avec l'horloge locale Peut déterminer si on ne devait pas recevoir un message avant 18

Horloges Informations données par les horloges Estampille : connaissance global du nombre d'événements du système Vectorielle: connaissance d'événements sur chacun des autres processus Matricielles : connaissance de la connaissance d'événéments qu'un processus connait sur les autres Application, utilité Estampille : ordonnancement global, gestion priorité Vectorielle : validation de la cohérence d'un état global, propriétés sur de la diffusion Matricielle : assurer la délivrance causale de messages entre plusieurs processus Cf TD systèmes distribués L3 Informatique 19

État global État Global État du système à un instant donné Buts de la recherche d'états globaux Trouver des états cohérents à partir desquels on peut reprendre un calcul distribué en cas de plantage du système Détection de propriétés stables, du respect d'invariants Faciliter le debugging et la mise au point d'applications distribuées Défini à partir de coupures Coupure Photographie à un instant donné de l'état du système Définit les événements appartenant au passé et au futur par rapport à l'instant de la coupure 20

Définition coupure Coupure Calcul distribué = ensemble E d'événements Coupure C est un sous-ensemble fini de E tel que Soit a et b deux événements du même processus : a C et b a b C Si un événement d'un processus appartient à la coupure, alors tous les événements locaux le précédant y appartiennent également Etat associé à une coupure Si le système est composé de N processus, l'état associé à une coupure est défini au niveau d'un ensemble de N événements (e 1, e 2,... e i,... e N ), avec e i événement du processus Pi tel que i : e C et e événement du processus Pi e e i L'état est défini à la frontière de la coupure : l'événement le plus récent pour chaque processus 21

Coupure Exemple de coupure (même chronogramme que pour exemples horloges Lamport et Mattern) Coupure = ensemble { e11, e12, e13, e21, e22, e23, e31, e32, e33, e34 } 22 État défini par la coupure = (e13, e23, e34)

Coupure cohérente Coupure/état cohérent Coupure qui respecte les dépendances causales des événements du système Et pas seulement les dépendances causales locales à chaque processus Soit a et b deux événements du système : a C et b a b C Coupure cohérente : aucun message ne vient du futur État cohérent État associé à une coupure cohérente Permet par exemple une reprise sur faute 23

Coupure cohérente Exemple (même chronogramme que précédent) Coupure C1 : cohérente Coupure C2 : non cohérente car e35 e23 mais e35 C2 La réception de m5 est dans la coupure mais pas son émission 24 m5 vient du futur par rapport à la coupure

Datation Coupure Horloge de Mattern permet de dater la coupure Soit N processus, C la coupure, e i l'événement le plus récent pour le processus Pi, V(e i ) la datation de e i et V(C) la datation de la coupure V(C) = max ( V(e 1 ),..., V(e N ) ) : i : V(C)[ i ] = max ( V(e 1 )[ i ],..., V(e N )[ i ] ) Pour chaque valeur du vecteur, on prend le maximum des valeurs de tous les vecteurs des N événements pour le même indice Permet également de déterminer si la coupure est cohérente Cohérent si V(C) = ( V(e 1 )[ 1 ],..., V(e i )[ i ],..., V(e N ) [ N ] ) Pour un processus Pi, si l'événement e i est le plus récent c'est lui qui a la date la plus récente pour C : sinon un événement e j d'un processus Pj (i j) s'est déroulé après un événement e i ' de Pi avec e i ' plus récent que e i e i e i ' et e i ' e j avec e i C, e j C et e i ' C 25

Datation Coupure Datation des coupures de l'exemple Coupure C1 : état = (e13, e22, e33) V(e13) = (3,0,0), V(e22) = (1,2,1), V(e33) = (0,0,3) V(C) = (max(3,1,0), max(0,2,0), max(0,1,3)) = (3,2,3) Coupure cohérente car V(C)[1] = V(e13)[1], V(C)[2] = V(e22)[2], V(C)[3] = V(e33)[3] Coupure C2 : état = (e13, e23, e34) V(e13) = (3,0,0), V(e23) = (2,3,5), V(e34) = (2,0,4) V(C) = (max(3,2,2), max(0,3,0), max (0,5,4)) Non cohérent car V(C)[3] V(e34)[3] D'après la date de e23, e23 doit se dérouler après 5 événements de P3 or e34 n'est que le quatrième événement de P3 Un événement de P3 dont e23 dépend causalement n'est donc pas dans la coupure (il s'agit de e35 se déroulant dans le futur) 26