NSY103

Linux : principes et programmation


6 crédits Joëlle DELACROIX-GOUIN EPN05 - Informatique Unité d'enseignement de type cours

Publié Du 01-09-2007 au 31-08-9999

Prérequis

Avoir des bases sur le fonctionnement des systèmes d'exploitation (cette UE intervient dans des diplômes et certifications de niveau supérieur à Bac + 2).
Savoir lire un programme écrit en langage C

Objectifs pédagogiques

Développement d'applications multiprocessus entralisées et réparties sour un système LINUX.

Compétences

Savoir développer une application multi processus utilisant des outils de communication et de synchronisation en C sous Linux/Unix.
 

Contenu

Introduction générale

  • Rappels sur le fonctionnement des systèmes informatiques.
  • Systèmes mon et multi processeur, centralliés et répartis
  • Installation d'un système Linux et d'un environnement de developpement C  (directement ou dans une machine virtuelle)
  • Fonctionnement général du système Linux

Gestion de processus

  • Processus sous linux
  • Réalisation d'un appel système
  • Threads
  • Gestion de l'espace d'adressage
  • Ordonnancement sous Linux mono et multiprocesseur
  • Langage de commandes associé

Communication centralisée et Synchronisation de processus

  • tubes nommés et anobymes, files de messages
  • segments de mémoire partagée
  • signaux
  • Section critique, sémaphores, problèmes classiques.
  • exemple d'interblocage (par exemple avec les tubes nommés)

Systèmes de fichiers

  • Interfaces des systèmes de fichiers et implémentation
  • programmation
  • langage de commande.
  • fichiers spéciaux
  • gestion des droits

Scripts

  • les notions de bases (variables, boucles, conditionelles)
  • varaibles d'environnement

Systèmes distribués

  • Structure des réseaux et structure des systèmes répartis.
  • Programmation socket
  • Introduction au RPC

Des travaux pratiques permettent d'introduire les notions liées au langage C et de mettre en oeuvre les primitives du système liées au processus et à la communication entre processus

Les différents items sont abordés coté utilisateur (programmation) et coté système (implémentation). Par exemple, on peut détailler le fonctionnement interne de quelques appels système et la présentation des structures de données et algorithmes du noyau.

Modalités de validation

  • Examen final
  • Projet(s)

Description des modalités de validation

L'évaluation de première et deuxième session est axée autour :
1/ d'un projet de mise en oeuvre des outils de communication donné à réaliser aux auditeurs. Ce projet conduit à la spécification et programmation d'une application multiprocessus communicant via les outils étudiés (tubes, MSQ, sockets, etc...). On donnera tout d'abord une spécification centralisée puis on demanderaa à l'etendre en réparti
Ce projet compte pour un quart de la note finale de première et deuxième session.
2/ d'un examen écrit de deux heures comptant pour ¾ de la note finale.

3/ De tps qui peuvent être notés et apporter des points bonus.

Bibliographie

TitreAuteur(s)
Linux : programmation système et réseau, Dunod. Quatrième editionJoëlle Delacroix

Thésaurus du Cnam :

  • Méthode de programmation
  • Système UNIX
  • Développement système
  • Système concurrent
  • Langage C

Thésaurus Formacode :

  • Aucune indexation

Secrétariat

Libellé
EPN05 - Equipe pédagogique AISL
Nom du contact
Emmanuelle BIAR
Adresses email
secretariat.aisl@cnam.fr
Numéros de téléphone
01 40 27 27 02
Adresse postale
2D4P30, 37.0.36, 2 rue Conté
Paris 75003