Gestion des fichiers. Telecom-ParisTech BCI Informatique
|
|
|
- Danielle Beaupré
- il y a 10 ans
- Total affichages :
Transcription
1 319
2 Gestion des fichiers 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 320
3 321
4 Qu'est-ce qu'un fichier? Définition : ensemble d'informations regroupées en vue de leur conservation et de leur utilisation dans un système informatique. Type des informations : - Programmes : fichier binaire exécutable, «script», byte code,, - Données : fichiers ASCII, binaires, images, son, fichiers d administration (/etc/passwd),, Caractéristiques d un fichier : - il possède un nom qui permet de l'identifier de manière unique (unicité), - il est rangé sur un support permanent (disques), 322
5 Sécurité et intégrité : La sécurité concerne la résistance aux attaques (gestion correcte des droits d'accès aux informations), l'intégrité concerne la résistance aux pannes (duplication des données, par exemple). Stockage des données et leur représentation : Le format de représentation des données pose le problème de la portabilité. Par exemple, quel format choisir pour un fichier contenant des données du type "flottants", c'est à dire des réels, si on veut échanger ces données entre deux machines d'architectures différentes (un PC et un MacIntosh)? Si on range les données sous forme de suite de caractères ASCII, pas de problème, les données seront lues correctement par toutes les machines, mais le volume de stockage pourra être très important, en particulier si les nombres ont une grande dynamique et une précision de plusieurs décimales. Inversement, le rangement en binaire est moins consommateur de surface disque, mais pose le problème de la compatibilité des représentations internes (IEEE ou non). Pour les applications qui utilisent plusieurs machines simultanément (client/serveur, par exemple) on adopte des représentations normalisées (format XDR des RPC, CDR de CORBA, ou primitives hton() et ntoh() de la bibliothèque des sockets). 323
6 Services assurés par le SGF Le Système de Gestion de Fichiers (SGF) ou File System doit fournir les services suivants : - intégrité (non altération des informations rangées dans les fichiers), - sécurité (contrôle d accès aux fichiers), - permanence (pérennité des informations : rôle de conservation des informations), - datation (mémorisation des dates des actions effectuées : mise à jour, ), Lorsque les fichiers sont utilisés comme support de communication (par transfert ou partage), se pose la question de la représentation des informations (données, programmes) : - représentation suivant un format «local», propre à une architecture (cf. : exécutable, entiers de 8 à 64 bits, little endians et big endians ) qui permet seulement l échange d informations entre machines ayant la même architecture, - représentation adoptant un format normalisé (ASCII, bytecode java, gif, doc, mp3, XDR, CDR ) qui autorise l échange d informations entre différents types d architectures, 324
7 325
8 Place du SGF Place du SGF (file system) dans Unix (qui comporte seulement deux couches K et U) : Compilateurs Interfaces utilisateur Editeurs... Gestion mémoire Matériel Gestion fichiers Gestion processus Le SGF (comme d'autres gestionnaires de ressources) peut être déporté à l'extérieur du noyau, ou ne pas exister (systèmes embarqués) 326
9 Le répertoire permet de passer du stockage " à plat" des fichiers sur le disque à l'organisation en arbre vue par les utilisateurs. Les fichiers répertoires servent uniquement à l'organisation de l'arbre et aux déplacements dans celui-ci. 327
10 Rôle du SGF (aspect système) Assurer la correspondance entre l'organisation logique (hiérarchie) des fichiers (celle que voit l'utilisateur) et l'organisation physique (organisation "à plat") des fichiers (leur implantation physique sur les mémoires de masse) Organisation logique : toujours une arborescence. Par exemple, sous UNIX : root etc bin usr dev util1 dupont dupond melon melon Les fichiers qui ont des successeurs dans l'arbre s'appellent les répertoires (directories), un répertoire est donc un fichier qui contient la liste de ses fils. Les répertoires sont des annuaires qui assurent la correspondance et la séparation entre organisation logique et physique, au même titre qu un annuaire réseau, qui associe nom de machine et adresse IP 328
11 329
12 Plan 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 330
13 La i-list d un file system UNIX, comme ses équivalents sur d autres systèmes, est dupliquée sur le disque : en effet la destruction d'une partie de la i-list signifie que les fichiers qui y sont décrits sont inaccessibles, mêmes s'ils sont parfaitement intègres sur le disque. De plus, chacun des exemplaires de la i-list est réparti aléatoirement sur le disque pour limiter les pertes en cas de destruction partielle du support physique. 331
14 Organisation physique des fichiers Sur chaque disque, un fichier spécial décrit l'ensemble des fichiers implantés sur ce disque. Citons : - la MFT (Master File Table) de NTFS (NT File System) sous Windows, - la i-list de UFS (Unix File System) sous UNIX, - la FAT (File Allocation Table) de MicroSoft DOS, Il existe différentes techniques pour gérer l omplantation des fichiers sur un disque : - chaînage de blocs à partir de la FAT pour MS-DOS, - le HFS (Hierarchical File System) de Mac OS est basé sur le concept de b-tree (balanced tree, b-arbre), - UFS (Unix File System) des familles Unix utilise un mélange d accès direct et de chaînage, - le NTFS (NT File System) de Windows conjugue b-arbre, compression et journalisation, 332
15 333
16 Organisation physique, exemple : UNIX La i-list est une table qui décrit l'ensemble des fichiers implantés sur un disque. Sa taille, qui détermine le nombre de ses entrées, est fixée à l'initialisation du disque. Elle doit être proportionnelle au nombre maximum de fichiers que l in autorise sur ce disque. Chaque entrée de la i-list s'appelle un i-node et occupe 64 octets. Comment calculer T, la taille de la i-list? On peut choisir : - T grand, pour permettre la création d un grand nombre de fichiers : une grande surface disque est alors confisquée par la i- list, peut-être de façon inutile, - T petit, donc gain de place, mais risque de ne pas pouvoir créer un fichier bien qu'il reste de la place sur le disque. 334
17 - On donne ici la structure fonctionnelle du disque. Dans la réalité des implantations, la i-list est dupliquée et dispersée sur le disque, pour des raisons de sécurité. Un disque peut être divisé en plusieurs file systems, c'est à dire être structuré en plusieurs disques logiques. 335
18 Organisation générale des file systems sous UNIX Si ce file system permet le démarrage du système, alors le boot-bloc contient les informations de démarrage (bootstrap) Le super-bloc contient, entre autres, les informations suivantes : - La taille en blocs de la i-list, celle du volume, - La liste des blocs libres, - Le nom du système de fichiers. La commande "df." donne l'occupation de la surface disque : Filesystem 512-blocks Used Avail Capacity Mounted /dev/disk0s % / 336
19 Le i-node contient TOUTES les informations concernant un fichier : droits d'accès, adresses d'implantation sur le disque, taille, date de création, etc. 337
20 La i-list de Unix : Un i-node Format d'un i-node : Commentaire sur les champs du i-node : - «Protections» : droits d accès sur le fichier (cf. umask plus loin) - «uid, gid» : (user identifier, group identifier), paire qui identifie le créateur (cf. /etc/passwd) - «taille» : taille, en octets, du fichier. (Remplacée par les numéros de majeur et de mineur pour les fichiers de/dev: périphériques). - «Adresse disque» : chacune de ces entrées peut contenir un numéro de bloc sur le disque. (Détails page suivante), - «Nombre de liens» : initialisé à 1 lors de la création du fichier, c'est le nombre d'arcs qui arrivent sur le fichier dans l arborescence, 338
21 Les 13 adresses de blocs sur le disque contenues dans un i-node sont séparées en deux catégories : - 10 adresses de blocs dits «d'information» (sur lesquelles sont rangés les 10 premiers blocs du fichier), - 3 adresses de blocs dits «d'index» (qui contiennent des adresses de blocs d'information). Les accès à un fichier qui se font en utilisant les 10 premières adresses sont plus rapides (directs!) et plus sûrs (la perte d'un de ces blocs signifie perte des seules informations qu'il contient) que les accès utilisant les trois dernières adresses. Les accès qui se font par l intermédiaire de ces 3 dernières sont moins rapides (une ou plusieurs indirections, ces blocs contiennent des pointeurs) et moins sûrs (la perte d'un de ces blocs signifie perte des informations contenues dans tous les blocs dont il contient les adresses). Mais cette organisation, qui permet d'avoir une taille fixe pour les i-nodes, convient dans la plupart des cas : un bloc UNIX peut faire jusqu'à 8Ko, ce qui permet des accès directs aux blocs d informations pour tous les fichiers dont la taille est inférieure à 80 Ko. Concevoir des applications modulaires organisées en petits fichiers permet de respecter le dicton : small is beautiful et la consigne KISS (keep it simple and stupid), où stupid veut dire que le programme inclus dans chaque module doit fait des opérations élémentaires Cette inégalité entre les accès aux premiers et derniers blocs d'un fichier est résolue par l'utilisation d'un cache par le système de gestion de fichiers d'unix. Remarque : la taille du bloc était fixée à 512 octets sur les premiers systèmes UNIX, elle est maintenant souvent beaucoup plus grande (4 K octets). Nous avons choisi cette taille de 512 octets, taille "historique", pour faciliter l'exposé. 339
22 Du i-node aux blocs alloués sur disque Dans chaque i-node on trouve13 adresses de blocs (à l origine, 1 bloc = 512 octets) : - les 10 premières pointent sur les 10 premiers blocs du fichier (B 0,..., B 9 ), - la 11ème pointe sur un bloc de 128 pointeurs qui adressent les 128 blocs de données suivants (B 10 à B 137 ), - la 12ème pointe sur un bloc de 128 pointeurs donnant chacun l'adresse d'un autre bloc de 128 pointeurs vers les blocs de données suivants. Ces blocs sont donc au nombre de : (B 138 à B ), - la 13ème pointe sur un bloc de 128 pointeurs donnant chacun l'adresse d'un bloc de 128 pointeurs vers des blocs de 128 pointeurs vers des blocs de données. Ces blocs sont donc au nombre de : (B à B ). 340
23 Les pointeurs contenant les adresses de blocs sur le disque sont rangés sur 4 octets. Les 10 pointeurs sur les 10 premiers blocs (accès direct) et les trois suivant (de plus en plus d indirections) occupent donc (13*4) octets quelle que soit la taille du fichier. Le jeu des indirections permet d avoir des i-node de taille fixe, au prix d une légère perte de place dans le cas des petits fichiers. Ce style de gestion favorise les petits fichiers : le temps d accès à une information n est pas le même suivant qu ell e se trouve dans les 10 premiers blocs ou dans les suivants. Ce travers est compensé par l utilisation d un cache disque en mémoire (cf. chapitre sur la hiérarchie de mémoire). 341
24 Du i-node aux blocs alloués sur disque : illustration Sur UNIX originel : 1 bloc = 512 octets 342
25 343
26 Du i-node aux blocs alloués sur disque : Exemple avec des blocs de 4 Ko : Nombre maximum de fichiers que l'on peut ranger sur un disque de 800 Mo (on ne tient pas compte de la place pour ranger le super bloc et la i- list) en supposant que la taille de chacun des fichiers est de 600 Ko : - Pour un fichier, il faut 600/4 (=150) blocs d information, - Les 10 premières adresses d un i-node sont donc utilisées (elles donnent un accès direct aux premiers 40 Ko des fichiers), - La 11 ème pointe sur un bloc d index qui contient 4K/4 (= 1K) adresses de blocs de données. - Il faut donc (=151) blocs par fichiers. Or y a 800M/4K (=200K) blocs sur le disque, donc on range 200K/151 fichiers, environ Cette organisation est un compromis entre accès direct pur (plus rapide, plus sûr, mais qui demanderait des i-nodes de taille variable) et accès indexé, Cette organisation favorise les petits fichiers : le temps d'accès à une information est différent selon que cette information est en fin ou en début de fichier Le cache rend équitable (en terme de latence) l'accès aux informations 344
27 On remarquera que le répertoire UNIX reflète parfaitement la séparation organisation logique / organisation physique. La première organisation concerne l'utilisateur et la seconde le système. Chacune des entrées du répertoire comporte deux champs : l'un contient le i-node qui décrit complètement le fichier, l'autre contient le nom du fichier, information fondamentale pour l'utilisateur mais qui intéresse peu UNIX. Le répertoire est un annuaire qui assure la correspondance entre adresse physique et nom logique de l'information. On pourra faire le rapprochement avec le fichier /etc/hosts qui associe nom de machine et adresse IP, la table de pages qui associe adresse virtuelle et adresse physique, etc. L'implantation historique décrite ci-contre a été améliorée. Dans les versions actuelles d'unix, la taille du champ «nom de fichier» est variable, ce qui élimine la contrainte sur la taille des noms de fichiers. 345
28 Répertoire Unix Structure "historique" du répertoire UNIX : le répertoire fait correspondre organisation logique et physique qui sont complètement séparées exemples de commandes concernant les répertoires : cd (simple déplacement dans l arbre) ls (simple affichage du contenu du répertoire courant) ls-l (pour chaque fichier du répertoire courant, on ouvre le i-node correspondant, le nombre d accès disque est beaucoup plus grand que dans le cas de ls) 346
29 L'exemple ci-contre montre comment le SGF navigue dans les répertoires pour retrouver l'information cherchée. On suppose que tous les droits d'accès sont suffisants. La commande donnée peut échouer si celui qui l'a émise n'a pas le droit de traverser un répertoire menant vers le fichier, s'il n'a pas les droits de lecture sur le fichier, ou s'il n'a pas le droit d'utiliser la commande, ici cat
30 Exemple d'accès à un fichier Rappel : format d'une entrée d'un répertoire : 2 octets No d'i-node 14 octets Nom du fichier Entrée d'un répertoire UNIX Effet de la commande cat /usr/dep/titi : 348
31 Un disque est divisé en pistes (tracks) ; 75 à 500 pistes par surface de disque. Une piste est divisée en secteurs ; 32 à 4096 octets par secteur, 4 à 32 secteurs par piste. Les secteurs sont l'unité de base. Le SGF manipule des blocs qui correspondent aux secteurs. Un disque peut comprendre plusieurs plateaux chacun ayant deux surfaces. Un cylindre est un ensemble des pistes qui ont la même position sur les disques. Les accès se font en précisant un numéro de piste (ou de cylindre), un numéro de surface, un numéro de secteur. Soit un disque qui possède les caractéristiques suivantes : - longueur d'une piste : octets, - temps d'une rotation : ms, - temps moyen de déplacement du bras : 30 ms. Le temps moyen de lecture d'un bloc quelconque de k octets est : ,3 + (k / 32768) x 16,67 ms 349
32 Rappel : fonctionnement d'un disque Les têtes de lecture/écriture sont déplacées jusqu'à la piste, positionnées sur la surface, puis attendent que le secteur voulu arrive jusqu'à elles par rotation : Plateau Rotation Secteur Tête de lecture/écriture Piste Cylindre Bras Remarque : les blocs dits "contigus" sont ceux qui ont les mêmes adresses de secteur sur des pistes différentes (lecture simultanée); 350
33 L'unité d'échange d un disque se comporte comme le fait le système : elle doit ordonnancer les accès aux pistes, comme le système ordonnance l'accès au processeur. Les algorithmes utilisés pour gérer les disques présentent les mêmes propriétés que les algorithmes d ordonnancement. Dans l'exemple ci-contre, l'unité d'échange a mémorisé cet ensemble de pistes à lire : 110, 190, 30, 120, 10, 122, 60, 65. Si on utilise SCAN à partir de 50, on classe les pistes à lire en deux suites : l'une décroissante à partir de 50 vers la piste 0 : (30,10), l'autre croissante vers la fin du disque : (60, 65, 110, 120, 122, 190). Il peut y avoir famine si la liste est modifiée dynamiquement et si de nombreuses demandes d'accès sont faites vers des pistes voisines de la piste courante et quelques unes vers des pistes "lointaines". 351
34 Gestion des déplacements de la tête Algorithmes disponibles (à rapprocher de ceux qui décident de l'ordonnancement des processus) : FIFO (First In First Out), accès dans l ordre des demandes, SSF (Shortest Seek First ), accès à la piste la plus proche, optimal, mais possibilité de famine, SCAN (ou ascenceur, ou chasse neige)le plus utilisé en pratique. Exemple : la tête est sur la piste 50, l'unité d'échange a mémorisé les demandes d accès sur les pistes suivantes : (110, 190, 30, 120, 10, 122, 60, 65) FIFO SSF SCAN
35 353
36 Plan 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 354
37 355
38 Organisation logique : l'arborescence On prendra celle d UNIX comme exemple d organisation logique. Commentaires sur quelques répertoires d administration : /dev pour les fichiers spéciaux (périphériques) : les périphériques sont BANALISES et vus comme des fichiers /etc pour les fichiers d'administration comme passwd, group, hosts,... /bin et /usr/bin pour les commandes du shell,..., /usr/include pour les fichiers.h /var/spool/mail pour la messagerie Un répertoire bien pratique : - /tmp dans lequel tout le monde peut lire et écrire 356
39 357
40 Les différents types de fichiers Plusieurs catégories : - fichiers ordinaires (exécutables, données, ) : ce sont des sommets pendants dans l arbre), - fichiers répertoires (les nœuds qui ont un successeur dans l'arbre), - fichiers spéciaux (sommets pendants dans l arbre) : périphériques, liens symboliques, tubes,... Exemple. On obtient le type d'un fichier grâce à la commande ls l : $ls l drwxr-xr-x 56 dupont 3072 May 14 09:04.. -rw-r dupont 5 May 14 09:05 fic1 lrwxrwxrwx 1 dupont 4 May 14 09:05 fic2 -> fic1 les fichiers de /dev sont en mode bloc (b) ou caractère (c) : crw dupont 28, 128 Feb audio brw-rw-rw- 1 root 36, 0 Feb fd0 crw-rw-rw- 1 root 11, 0 Jul tcp En mode bloc, on utilise le cache, pas en mode caractère. 358
41 Fonction lseek : lseek(int file,int Offset,int From); From : début, fin ou position courante Offset : nombre d'octets à partir de Depuis Redirection des entrées/sorties : ls > fichier ls > /dev/ptty2 cat bark.au > /dev/audio ls -lr > /dev/audio mail dupont -s "fichier.c" < fichier.c 359
42 Structure des fichiers et modes d'accès sous UNIX Contrairement à d'autres systèmes, Unix ne propose pas de format de fichier : un fichier Unix est une simple suite d'octets. - avantages : o portabilité et faible encombrement du SGF, o banalisation : les périphériques étant traités comme des fichiers, ceci permet la redirection des entrées/sorties, exemples : ls > fichier ls > /dev/ptty2 cat bark.au > /dev/audio mail le_prof -s "TP 1" < fichier.c - inconvénients : nombreuses fonctions à réaliser par l'utilisateur (exemple : développer une base de données!). Accès aux fichiers : - l'accès par défaut est séquentiel : une fonction d'accès (read, write, etc) à un fichier reprend le curseur dans le fichier là où l'avait laissé le traitement précédent. - Pour faire un accès direct, il faut utiliser la fonction lseek 360
43 Pour lire un fichier, il faut avoir le droit de lecture (r) sur ce fichier et le droit de traverser (x) le, ou les, répertoires qui y conduisent. Exemple : Pour créer un répertoire privé, c'est à dire qui peut être lu seulement si on en donne le nom : $mkdir private $chmod 711 private $cd private $mkdir dir1 $chmod 755 dir1 Personne ne peut lire dans private, (par exemple faire : ls private) c'est à dire voir qu'il contient dir1, mais on peut accéder aux informations contenues dans dir1 (cd dir1). En effet : pour faire cd il faut x sur le répertoire visé pour faire ls il faut r sur le répertoire visé 361
44 Les droits d'accès aux fichiers A la création du fichier, le SGF : - copie les uid et gid (trouvés dans /etc/passwd) du créateur dans le i-node, - initialise les droits d'accès, aussi dans le i-node, en utilisant le umask (trouvé dans le fichier qui définit l'environnement), Ces droits d accès sont codés sur 10 bits : user group others r w x r w x r w x Exemple : droits d accès pour le fichier fic.c : -rw-r dupont 8229 Mar 20 10:08 fic.c umask renvoie (ou initialise) les accès interdits par défaut sur les fichiers créés. Par exemple, un umask 022 signifie écriture interdite pour group et others. 362
45 La commande chmod permet de positionner le bit s : Commandes ls -l ma_commande chmod u+s ma_commande ls -l ma_commande Résultats affichés à l'écran -rwxr--r-- 1 dupont ma_commande -rwsr--r-- 1 dupont ma_commande Lorsqu'un utilisateur quelconque exécutera le fichier ma_commande il prendra l'identité "dupont" et aura donc accès à tous les fichiers appartenant à dupont comme s'il était dupont. Dans /etc/passwd, un utilisateur peut modifier son mot de passe (et son shell ) par défaut, pourtant, il n'a pas l'accès en écriture sur ce fichier, qui appartient à root! Mais il utilise la commande passwd qui appartient à root, sur laquelle le bit s est positionné à 1, il prend ainsi l'identité "root" et peut écrire sur les fichiers appartenant à root, en particulier il peut modifier /etc/passwd. 363
46 Droits d'accès : le bit s Si le bit s est positionné sur un fichier : l'utilisateur U du fichier prend l'identité du PROPRIETAIRE P du fichier : - on parle de real uid et gid pour ceux de U, - on parle de effective uid et gid pour ceux de P, Exemple, les droits sur/bin/passwd sont positionnés comme suit par root pour que les utilisateurs puissent accéder à /etc/passwd : -r-sr-sr-x 1 root -rw-r--r-- 1 root 7728 Jul /bin/passwd 559 Jul /etc/passwd ici le bit s est positionné sur l'exécutable /bin/passwd, celui qui utilise cette commande prend donc l'identité de root pendant cette utilisation. Il pourra donc mettre à jour le fichier /etc/passwd, bien qu'il n'ait pas le droit d'y écrire
47 365
48 Plan 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 366
49 Commande cp Cette commande copie un fichier dans un autre, le SGF enchaîne les actions suivantes : chercher un i-node libre dans la i-liste, s'il en existe un, chercher de la place libre sur le disque, si il y en a assez, copier les blocs, mettre à jour le i-node trouvé, Un fichier peut ne pas être créé pour plusieurs raisons : pas le droit d'écrire dans le répertoire visé, de lire dans le rép. source, pas le droit de lire le fichier source, pas de i-node libre, bien qu'il y ait de la place sur disque, i-node libre, plus de place sur disque, 367
50 Commande cp dupont fait : cp f1 f2 dans son home directory Etats de l arborescence et du répertoire dupont avant l exécution de cette commande: f1 dupont util g1 martin Catalogue dupont f1 Catalogue martin g1 Etats de l arborescence et du répertoire dupont après l exécution de cette commande: f1 dupont f2 util g1 martin Catalogue dupont f1 62 f2 Catalogue martin g1 368
51 Note : Si on passe un fichier d un file system à un autre par mv, il y copie puis destruction (équivalent de cp suivi de rm). 369
52 Commande mv dupont fait maintenant : mv f2 f50 Etats de l arborescence et du répertoire dupont avant l exécution de cette commande: f1 dupont f2 util g1 martin Catalogue dupont f1 62 f2 Catalogue martin g1 Etats de l arborescence et du répertoire dupont après l exécution de cette commande: f1 dupont f50 util g1 martin Catalogue dupont f1 62 f50 Catalogue martin g1 Très peu de travail sur le disque pour le SGF : seul le nom du fichier dans le répertoire change, pas de gestion d'espace disque. 370
53 Commande ln (lien) Appels système : - link (Origine, Destination); Pas de ln entre file system différents 371
54 Commande ln Cette commande s appelle hard link dans le jargon UNIX : - Le fichier n'est pas dupliqué - ln augmente de 1 le nombre de liens sur le fichier Exemple, martin fait : ln../dupont/f50 g2 Etats de l arborescence et du répertoire dupont avant l exécution de cette commande : f1 dupont f50 util g1 martin Catalogue dupont f1 62 f50 Catalogue martin g1 Etats de l arborescence et du répertoire dupont après l exécution de cette commande : f1 dupont f50 util g2 g1 martin Catalogue dupont f1 62 f50 Catalogue martin g1 62 g2 372
55 373
56 Commande ln -s Cette commande (symbolic link) crée un fichier, donc alloue un i-node qui contient la chaîne de caractère entrée et marque ce fichier comme étant de type l, Exemple, la commande : ln -s../dupont/f50 g3 va donc créer dans dupont un fichier g3 dont le contenu est../dupont/f50 et dont le type est l. un lien symbolique est donc un pointeur, 374
57 375
58 Commande ln -s martin fait : ln -s../dupont/f50 g3 Etats de l arborescence et du répertoire avant l exécution : f1 dupont f50 util g2 g1 martin Catalogue dupont f1 62 f50 Catalogue martin g1 62 g2 Etats de l arborescence et du répertoire après l exécution : f1 dupont f50 util g2 g1 martin g3 Catalogue dupont f1 62 f50 Catalogue martin g1 62 g2 101 g3 Contenu du fichier g3 :../dupont/f50 attention si dupont fait : mv f50 f60, alors cat g3 donnera file not found! 376
59 377
60 Commande ln et ln s (différence) Depuis le répertoire courant, faire : Commande Commentaire mkdir dir1 dir2 créer deux répertoires cd dir1 aller dans le répertoire dir1 echo abc > fic1 créer fic1 cd../dir2 aller dans dir2 ln../dir1/fic1 fic2 fic2 est un synonyme de fic1 ln -s /dir1/fic1 fic3 fic3 est un pointeur vers fic1 Contenu du répertoire dir2, obtenu par ls -il : rw-r--r-- 2 dupont fic lrwxrwxrwx 1 dupont fic3 ->../dir1/fic1 Contenu du répertoire dir1, obtenu par ls -il : rw-r--r-- 2 dupont fic1 - Les fichiers fic2 dans dir2 et fic1 dans dir1 ont le même numéro de i-node. : 23117, - fic3 est de type l, c est à dire un lien symbolique, un pointeur, c est un autre fichier : il a un numéro de i-node différent :
61 C'est ainsi que l'on peut récupérer les fichiers détruits. En fait, ils sont détruits dans l'organisation logique, mais pas forcément dans l'organisation physique. 379
62 Situation initiale : Commande rm f1 dupont f50 util g2 g1 martin g3 Catalogue dupont f1 62 f50 Catalogue martin g1 62 g2 101 g3 Effet de rm /util/martin/g1: f1 dupont f50 util g2 martin g3 Catalogue dupont f1 62 f50 Catalogue martin g1 62 g2 101 g3 La commande rm (remove) porte bien son nom (contrairement à de nombreuses commandes Unix), elle ne veut pas dire delete : seul l'arc conduisant au fichier est détruit : nbre de liens =nbre de liens - 1 Mais, il peut y avoir plusieurs arcs (links) conduisant à ce fichier! Le fichier n'est détruit, c'est à dire le i-node considére comme libre, seulement quand le dernier lien sur le fichier est détruit ; 380
63 381
64 Nom de fichier et i-node : récapitulatif l'utilisateur s'intéresse aux noms des fichiers, les PATHNAMES ou nom des arcs, Unix gère les i-nodes, noms des nœuds : dupont util 12 martin Catalogue dupont f1 62 f50 f1 29 f g g3 101 Catalogue martin g1 62 g2 101 g3 Le répertoire assure la correspondance pathname/i-node ; sous Unix il peut y avoir plusieurs chemins (pathnames) pour accèder au même fichier (i node) Le répertoire assure l'indépendance des organisation logiques et physiques : Unix gère des i-nodes, les véritables fichiers, l'utilsateur construit l'arbre des pathnames Un fichier n'est détruit que si le dernier arc (link) qui y conduit disparaît 382
65 383
66 Plan 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 384
67 385
68 Processus et fichiers : Table des fichiers Descripteur/ nom de fichier : - Pour accéder à un fichier, un processus ne le désigne pas directement par son nom, mais il passe par un intermédiaire, appelé descripteur, qui peut être un simple numéro, - Cette association se fait en utilisant les fonctions du type «open». Table des fichiers ouverts (User Open File Table, UOFT) - Sous UNIX, le mécanisme repose sur l utilisation d un table appelée User Open File Table. Elle contient une entrée par fichier ouvert pour le processus. (Pas forcément ouvert par lui). Il y a une telle table par processus. - Chaque entrée de cette UOFT contient un pointeur sur une table appelée System Open File Table, commune à tous les processus. Chaque ouverture de fichier ajoute une entrée dans cette table. Les entrées de la SOFT contiennent le nom du fichier et la valeur courante du pointeur dans celui-ci. 386
69 387
70 Processus et fichiers : Premier exemple Dans l exemple suivant, on suppose que d autres appels à open ont précédé ceux faits par Pi sur le fichier titi et Pj sur le fichier toto: Programme exécuté par Pi Programme exécuté par Pj int main(void){ int Ret; Ret= open ("titi", O_RDONLY); printf ("retour de open = %d\n", Ret); int main(void){ int Ret; Ret= open ("toto", O_RDONLY); printf ("retour de open = %d\n", Ret); Résultat : retour de open = 10 Résultat : retour de open = 6 Effet de ces deux appels à open sur les tables : Une entrée de la SOFT contient deux champs : - Ptr: la valeur du curseur dans la fichier - Fic: le nom du fichier (pathname complet) 388
71 On obtient le nom du terminal courant en utilisant la commande tty. 389
72 Processus et fichiers : Création de la table UOFT Initialisation de la table des fichiers ouverts pour un processus : - un processus hérite (par duplication) de la table des fichiers ouverts de son père, - Ainsi, lors de la création d un processus à partir du shell, le système lui associe une copie de la user open file table du shell dans laquelle les trois premières entrées : 0 (stdin), 1 (stdout), et 2 (sdterr) pointent vers le terminal, ou pseudo terminal, courant : Table fic. processus père Table fic. système fork /dev/tty Table fic. processus fils On note que ces trois entrées contiennent un pointeur vers la même entrée de la system open file table qui donne le nom de la ressource. 390
73 391
74 Redirection des Entrées/Sorties (1) La redirection des E/S montre l intérêt de passer par un descripteur logique plutôt que de donner directement le nom de l objet sur lequel on travaille, Rappelons que l on peut rediriger les E/S, en particulier en utilisant les symboles > et < : - > redirige 1, la sortie standard, - < redirige 0, l entrée standard Exemple de redirection : - ls l > titi demande au shell de créer un processus dont les sorties ne se feront pas sur le terminal courant mais dans le fichier titi, - le schéma de la page suivante indique comment se fait une redirection dans la UOFT 392
75 393
76 Redirection des Entrées/Sorties (2) Effet de la commande ls l > titi au niveau des tables: 1- création et ouverture d un fichier titi, 2- attribution à ce fichier d une entrée dans la table commune (SOFT) 3- modification du contenu de l entrée 1 de la table propre au processus (UOFT) qui pointe maintenant vers l entrée attribuée à titi dans la table commune Etat de la table UOFT avant et après la redirection : Avant la redirection Après la redirection 394
77 Par défaut 0, 1 et 2 sont associés au terminal courant (/dev/tty). Chaque open sur un fichier renvoie le numéro de l'entrée qui a été associée à ce fichier dans la table des fichiers ouverts par le processus. L allocation se fait ainsi : la table est scrutée à partir de l entrée zéro, et la première entrée libre est associée au fichier à ouvrir. #include <stdio.h> #include <fcntl.h> #include <unistd.h> int main(void) { int Ret_Op, i; for (i=0; i<3; i++){ Ret_Op = open ("/etc/hosts", O_RDONLY); printf ("retour de open = %d\n", Ret_Op); } close (0); for (i=0; i<3; i++){ Ret_Op = open ("/etc/hosts", O_RDONLY); printf ("retour de open = %d\n", Ret_Op); } return 1; } Résultat de l exécution du programme précédent : retour de open = 3 retour de open = 4 retour de open = 5 retour de open = 0 retour de open = 6 retour de open = 7 Commentaire: L appel à close a libéré l entré d index 3, qui devient ainsi la première entrée libre. Exemple d exécution de la commande limit : cputime unlimited filesize unlimited datasize 6MB stacksize 8MB coredumpsize 0kB memoryuse unlimited memorylocked unlimited maxproc 100 descriptors 256 (256 fichiers maximum ouverts simultanémént) 395
78 Processus et fichiers : Gestion de la table Comment sont attribuées les entrées de la user open file table : - Lors de l ouverture d un fichier, le système lui associe la première entrée libre dans la user open file table : programme : int Ret_Op; Ret_Op = open("titi", O_RDONLY); printf("retour de open = %d\n", Ret_Op); résulat: retour de open = 3 Remarques: - dans le cas d un environnement multi fenêtres, à la création du processus, la première entrée libre peut être largement supérieure à 3, - le nombre maximum de fichiers ouverts simultanément est un paramètre dont on peut connaître la valeur en utilisant limit 396
79 Soit le programme : int main (void){ int Fic1, Etat, Ret, Ret_f; Fic1 = open ("/etc/hosts",0); /* Ouverture d un fichier */ /* Le pere positionne le curseur en 3 dans le fichier */ lseek(fic1, 3, SEEK_CUR); /* Creation d un processus fils */ Ret_f = fork (); if (Ret_f == 0) { /* Le fils decale le curseur de 7 positions dans le fichier */ Ret = lseek(fic1, 7, SEEK_CUR); printf("pid : %d : Valeur de Fic1= %d et Ret= %d\n", (int)getpid(), Fic1, Ret); exit (1); } wait(&etat); /* verifier la position courante dans le fichier pour chaque processus */ Ret = lseek(fic1, 0, SEEK_CUR); printf("pid : %d : Valeur de Fic1= %d et Ret= %d\n", (int)getpid(), Fic1, Ret); return 1; } Résultat de l exécution du programme précédent : Pid : 869 : Valeur de Fic1= 13 et Ret= 10 Pid : 868 : Valeur de Fic1= 13 et Ret= 10 On constate que les deux processus trouvent le curseur en 10 : - Le fils a trouvé le curseur en 3 et l a avancé de 7, il est donc en 10 - Le père le voit aussi en
80 Processus et fichiers : Partage de pointeur Soit cet extrait de programme : Fic1 = open ("titi", O_RDWR) ; /* Positionner le curseur en 3 */ lseek(fic1, 3, SEEK_CUR); /* Creation d un processus fils */ Ret_f = fork (); if (Ret_f == 0) { /* Decaler le curseur de 7 positions */ lseek(fic1, 7, SEEK_CUR); } Illustration du déplacement du curseur et de l évolution des tables : Voir suite 398
81 399
82 suite : Partage de pointeur 400
83 401
84 Les fichiers du type «pipe» (tubes) Les accès à un fichier déclaré comme «tube» (pipe) sont gérés par Unix suivant le schéma producteur/consommateur : - Les read et write sur ce fichier seront en fait respectivement des «consommer» et «déposer» Conséquences : - Les lectures sont destructrices : un caractère «lu» est retiré du tube, - Un read est bloquant si le tube est vide - Un write est bloquant si le tube est plein. 402
85 403
86 Les fichiers du type «pipe» (tubes) Il existe deux types de «tubes» : Le tube standard o créé par la fonction pipe : seuls y accèdent les processus qui ont le créateur pour ancêtre o il est détruit une fois que tous les processus qui l utilisent sont terminés (process persistent), Le tube nommé (named pipe) o créé par la fonction mkfifo ou mknod : tous les processus qui connaissent son nom, et ont les droits d'accès adéquats, peuvent y accéder (il a une entrée dans la i-list), o system persistent : il n est pas détruit quand le processus qui l a créé se termine, 404
87 Exemple d'utilisation de la primitive pipe correspondant au schéma ci-contre. Le père dépose dans le tube les caractères saisis au clavier par un getchar. Le fils les affiche. Les read et write sur ce fichier seront en fait des consommer et déposer, c'est à dire que le read sera bloquant si le tube est vide et le write bloquant s'il est plein. int main (void){ int Ret_Fork, Tube[2], Etat; char c; pipe(tube); Ret_Fork = fork(); if (Ret_Fork!= 0 ){ close(tube[0]); printf("envoyer les caracteres!\n"); while( (c = getchar())!= EOF ) write (Tube[1], &c, 1); wait (&Etat); } if (Ret_Fork == 0 ){ printf ("Fils pret en lecture.\n"); close (Tube[1]); while ( read (Tube[0], &c, 1) ) { printf ("caract recu = %c (0x%x)\n", c, c); } exit (0); } } 405
88 Les fichiers du type «pipe» (tubes) Le programme suivant montre l utilisation des tubes standards en C: int main (void){ int, Tube[2], Ret_Fork; char c; pipe(tube); Ret_Fork = fork(); if (Ret_Fork!= 0){ write (Tube[1], &c, 1); } if (Ret_Fork == 0){ read (Tube[0], &c, 1); } } 406
89 Exemple de création d'un tube nommé, il sera accessible à tous les utilisateurs puisque les droits sont read-write pour toutes les catégories d'utilisateurs (0666). Les read et write sur ce fichier seront en fait des consommer et déposer, c'est à dire que le read sera bloquant si le tube est vide et le write bloquant s'il est plein. /* Creation d'un tube nomme visible de partout */ #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> int main (int nb_arg, char ** argv){ int Ret_mknod; if (nb_arg!= 2){ printf (" Utilisation : %s Nom_du_tube a creer\n", argv[0]); exit (1); } Ret_mknod = mknod(argv[1], S_IFIFO 0666, 0); if ( ret_mknod!= 0){ perror (" mknod "); exit(1); } printf (" On a cree le tube %s \n", argv[1]); } 407
90 Utilisation des "tubes" Tubes standards : ne sont vus que par les descendants d'un ancêtre commun, plusieurs producteurs/consommateurs possibles sur le tube. Ils sont créés par la commande pipe. Tubes nommés : accessibles pour peu qu'on connaisse leur nom et qu on ait les droits d accès adéquts. Ils sont créés par mknod ou mkfifo. Les tubes en shell. Le symbole est un tube sur lequel arrivent les sorties du processus situé à sa gauche et où le processus situé à sa droite prend ses entrées : ps -aux grep dupont ypcat passwd grep -i dupont 408
91 /* Lister les noms des fichiers sources C du repertoire courant.(on pourrait les ranger dans un fichier en faisant le fprint dans un fichier et non pas sur stdout) */ #include <stdio.h> #include <stdlib.h> int main(void){ char *cmd = "/usr/bin/ls *.c"; char buf[bufsiz]; FILE *Ptr_Fichier; long nbfic = 0; Ptr_Fichier = popen(cmd, "r"); if (Ptr_Fichier!= NULL) while (fgets(buf, BUFSIZ, ptr)!= NULL) { nbfic = nbfic + 1; fprintf(stdout, "Fichier %ld -> %s", nbfic, buf); } } /* Envoi de mail */ #include <stdio.h> int main (int argc, char *argv[]){ FILE *Tube; char Com[128]; char Sujet [] = "essai"; if (argc!= 3) { printf (" Utilisation : %s destinataire message\n", argv[0]); exit(1); } sprintf(com, "/usr/bin/mail -s %s %s", Sujet, argv [1]); Tube = popen(com, "w"); fprintf(tube, argv [2]); fflush(tube); pclose(tube); } 409
92 La primitive popen Description de l'appel système : FILE * popen(const char *com, const char *mode_acces) Cette fonction crée un processus qui exécute la commande contenue dans com et qui se synchronise avec le processus appelant via un tube. L'accès au tube se fait suivant le mode d'accès désigné par mode_acces. Exemple : int Nb_Util; char *Commande = "who wc -l"; FILE *Le_Tube; Le_Tube = popen (Commande, "r"); fscanf (Le_Tube, "%d", & Nb_Util ) ; fclose (Le_Tube); printf ("Il y a %d utilisateurs\n", Nb_Util); 410
93 /* utilisation d'un fichier-verrou ATTENTION, utiliser un fichier visible PAR TOUS LES UTILISATEURS du verrou cet exemple suppose deux processus dans le meme repertoire!!!!!!!!! UTILISER LOCKF (cf. la suite) */ #define VERROU "verrou" int main (void){ int f2, i, ret; while (1){ printf ("Pid %d : avant entree dans SC\n", (int)getpid() ); do{ f2=open (VERROU, O_EXCL O_CREAT O_TRUNC O_EXCL, 0666); sleep (2); /* pour limiter l'attente active */ } while (f2 == -1) ; printf ("Pid %d : entree dans SC\n", (int)getpid() ); /* Debut de section critique */ for (i=0; i< ; i++) ; /* Fin de section critique */ ret = remove (VERROU); sleep(2); printf ("Pid %d : sortie SC, ret = %d \n", (int)getpid(), ret ); } return 1; } 411
94 Synchronisation des accès fichiers Utilisation de "fichiers-verrous" : ret = open ("Verrou", O_CREAT O_EXCL, 0666) on vérifie la valeur de ret pour savoir si le verrou existe ou non : Processus 1 do { i = open ("Verrou", O_CREAT O_EXCL...) sleep (n); /* pour limiter l'attente active */ } while ( i == -1); Processus 2 do { i = open ("Verrou", O_CREAT O_EXCL...) sleep (n); /* pour limiter l'attente active */ } while ( i == -1); Section critique Section critique remove ( "Verrou" ) remove ( "Verrou" ) Conditions de bon fonctionnement : - mettre le fichier-verrou dans /tmp ou tout autre répertoire accessible par tous les utilisateurs concernés, - donner à ce fichier-verrou un nom bien particulier Utiliser plutôt un vrai verrou (à l aide de la fonction lockf)! 412
95 /******************************************************** synchro par lockf remarque : les processus qui n'utilisent pas lockf accedent sans controle au fichier ********************************************************/ int main (int argc, char *argv[]){ Sortie = open (argv[1], O_RDWR)) == -1) ; /* verrouillage de tout le fichier */ lockf (Sortie, F_LOCK, 0); printf ("Pid %d : entree dans SC\n", (int)getpid() ); /* Debut de section critique */ write (Sortie, Tab, strlen(tab); /* Fin de section critique */ /* se repositionner au debut du fichier, sinon on ne deverrouille que ce qui suit la position courante */ lseek(sortie, 0, SEEK_SET); lockf (Sortie, F_ULOCK, 0); printf ("Pid %d : sortie SC, = %d\n", (int)getpid()); } 413
96 Synchronisation des accès fichiers Pour verrouiller les accès à un fichier : lockf. Cette fonction gère des «advisory locks» c est à dire que le passage par le verrou n est pas obligatoire pour accéder au fichier. Le verrouillage et le déverrouillage se font sur nb_octets en partant de la position courante. Ceci évite le problème du faux partage : verrouiller toute la ressource, alors que seule un sousensemble est utilisé. verrouillage : lockf(fichier, F_LOCK, nb_octets) déverrouillage : lockf(fichier,f_ulock, nb_octets) où fichier est la valeur renvoyée par un open, creat, dup ou pipe. si nb_octets = 0, tout le fichier est verrouillé. Interblocage possible, Remarque : lockf agit à partir de la position courante, utiliser lseek pourgérer cette position. 414
97 415
98 Récapitulatif : fichiers Unix Fichiers standards, ouverts par open, (lecteurs/écrivains) pas de synchronisation implicite : - les processus accèdent aux fichiers en fonction de leurs seuls droits d accès, pas de contrôle de concurrence, - synchronisation possible via le "verrou à la Unix" : creat et test d'existence, - synchronisation en utilisant lockf ou flock. Fichiers tubes, synchronisés producteur/consommateur : - tube standard (ouvert par pipe) : il faut un ancêtre créateur - tube nommé (ouvert par mkfifo ou mknod) : il suffit d'en connaître le nom - popen : un tube est créé entre le processus courant et celui qui exécute la commande passée en paramètre à popen 416
99 417
100 Plan 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique L'arborescence UNIX, Différents types de fichiers Modes et droits d'accès 4 Organisation logique/physique : illustration par quelques commandes : cp, mv, rm, ln, ln -s 5 Processus et fichiers, Annexe: la bibliothèque d'entrées-sorties du langage C 418
101 Fichiers standards (associés au terminal courant) Haut niveau Bas niveau Défaut Entrée standard stdin 0 clavier Sortie standard stdout 1 écran Sortie erreur stderr 2 écran Ces fichiers standards sont toujours ouverts, sauf si l'utilisateur les ferme explicitement. 419
102 E/S en C sous UNIX On peut utiliser deux bibliothèques : - celle dite de bas niveau (famille d'appels liés à open : read, write, etc) - celle dite de haut niveau (famille d'appels liés à fopen : fread, fwrite, etc) Relation entre processus et fichier : on va associer une variable locale au fichier dont on connait le nom global : - Haut niveau : pointeur sur une structure décrivant le fichier ( variable de type FILE* renvoyée par fopen) - Bas niveau : descripteur de fichier :c'est à dire un index dans la table des fichiers ouverts par le processus ( variable de type int, renvoyée par open) Par la suite on présente la bibliothèque de bas niveau (open, read, write, etc), les fonctions de haut niveau seront données dans les pages de commentaires 420
103 Ces fonctions de bas niveau sont spécifiques à UNIX. open renvoie une entrée dans la table des fichiers ouverts par le processus. Elle associe un numéro local à un nom global. Ouverture et fermeture des fichiers avec la biblio. de haut niveau : FILE * fopen (char * nom_externe, char * type) "r" "w" "a" "r+" "w+" "a+" lecture seule écriture seule; s'il existe, il est détruit concaténation; création s'il n'existe pas lecture et écriture (mise à jour) écriture et lecture lecture et concaténation Exemple d'utilisation de fopen, on ouvre le fichier dont le nom est passé sur la ligne de commande : #include <stdio.h> int main (int argc, char *argv[] ){ } FILE *Ptr_Fichier; Ptr_Fichier = fopen (argv[1],"r"); if (Ptr_Fichier == (FILE *) 0) { printf ("Pas pu ouvrir %s!\n", argv[1]); exit (1); } printf ("Fichier %s ouvert!\n", argv[1]); Fermeture : fclose (FILE *fp) Par exemple pour fermer l'entrée standard : fclose (stdin); 421
104 E/S bas niveau Avant d'accéder à un fichier il faut l'ouvrir par un open : int Fichier; Fichier = open ("toto", O_RDWR); if (Fichier == -1) { perror ("open toto"); exit (1); } Création de fichier int creat (char *nom, int mode/* droits d'acces */); 422
105 /****************************************************** exemple d'open, creat, read et write ********************************************************/ int main (int argc, char *argv[]) { int i, f1, f2; f1 = open (argv[1],0); if (f1 == -1){ perror ("open"); exit (1); } f2 = creat (argv[2],0666); if (f2 == -1){ perror ("creat"); exit (1); } while(1){ i = read (f1,&c,1); if (i!= 1) break; write (f2, &c, 1); } } Bibliothèque de haut niveau. on lit ou écrit des enregistrements dont on donne la taille et le nombre : Lecture : int fread (char * buf, int size, int nb_rec, FILE * fp) - Valeur retournée : nombre d'enregistrements de taille size lus. - En cas d'erreur ou fin de fichier renvoie 0 Ecriture : int fwrite (char * buf, int size, int nb_rec, FILE * pf) - Valeur retournée : nombre d'enregistrements de taille size écrits. 423
106 E/S bas niveau Lecture / Ecriture : int write (int fildes, char * buffer, unsigned nbyte) int read (int fildes, char * buffer, unsigned nbyte) Fermeture d'un fichier : int close (int fildes) ; Attention aux valeurs de retour (utiliser man pour les vérifier ). Exemple : int main ( void ){ int Mon_Fic, Ret_Read, Ret_Write; char Tableau [512] ; /* ouverture en lecture*/ Mon_Fic= open ("toto", O_RDONLY) ; if (Mon_Fic== -1) { perror ("open"); } while((ret_read=read(mon_fic, Tableau, 512)) > 0){ } Ret_Write = write(1, Tableau, Ret_Read); if (Ret_Write == -1) { / * Traiter l'erreur */ }; close (Mon_Fic) ; } 424
107 Informations sur un fichier : void stat (char * path, struct stat *buffer) ; void fstat (int fildes, struct stat *buffer) ; int access (char * path, int access_mode) ; Bibliothèque de haut niveau (équivalent de lseek) long fseek (FILE *pf, long offset, int from) valeur de from déplacement depuis début position fin courante offset est un déplacement en octets. il peut être posifif ou négatif. fseek ne s'applique pas aux fichiers "pipes". - Retourne 0 si ok, sinon une valeur 0 (!!!) Pour obtenir la P OSITION COURANTE : long ftell (FILE *pf) - retourne -1 si erreur. 425
108 E/S bas niveau Positionnement dans un fichier : long lseek (int fildes,long offset,int from) ; from : 0 depuis le début 1 depuis la position courante 2 à partir de la fin Retourne : la position du pointeur à partir du début du fichier, -1 en cas d'erreur. Changer les droits d'accès : int chmod (char *nom, int mode) ; 426
109 Exemple d'utilisation de fgets sur stdin : while ( fgets(tab, sizeof(tab), stdin) ) { if (!strncmp (Tab, "fin", 3)) break; if (write (Sortie, Tab, strlen(tab)) < 0) { printf ("Erreur d'ecriture\n"); break; } 427
110 E/S par caractère et par ligne Par caractère : Lecture int getc(file *fp) int fgetc(file *fp) int getchar() idem getc(stdin) int getw(file *fp) Ecriture int putc(char c, FILE *pf) int fputc(c, pf) int putchar(c) idem putc(c,stdout); int putchar(c) Par ligne, par convention, une ligne de fichier texte se termine par '\n'. Lecture char * gets(char *buffer) : depuis stdin Ecriture intputs(char *chaine) stdout : vers char * fgets(char *buffer, int longmax, fp) int fputs (char *chaine, fp) 428
111 Format pour les appels de la famille printf : d u f x c s g Spécificateur Correspondance entier entier non signé flottant hexadecimal caractère chaîne de caractères flottant double Options : l : complète le spécificateur pour les entiers longs- : justifier à gauche + : visualiser le signe (+ ou -) 0 : compléter par des 0 Formats variables : printf ("%*.*s", 9, 5, chaine) ; etc...(cf. man) Formats pour les appels de la famille scanf : %d décimal %x hexadécimal %s lit une chaine jusqu'à blanc, TAB ou LF ajoute un '/n' à la chaine %c lit un caratère %[..] Si le caractère lu fait partie de l'ensemble, on continue la scrutation et l'affectation. Les autres caractères sont considérés comme des séparateurs. Dans le cas où le caractère '^' apparait en 1ère position (%[^..]), il s'agit du complément de cet ensemble. %*d Pas d'affectation à une variable pour ce format d'entrée....cf le man.. 429
112 E/S standards formatées : LECTURE ECRITURE clavier/écran scanf printf Fichier fscanf fprintf Mémoire sscanf sprintf Syntaxe : printf (format, liste de valeurs) fprintf (fichier, format, liste de valeurs) sprintf (buffer, format, liste de valeurs) scanf (format, liste d'adresses) fscanf (fichier, format, liste d'adresses) sscanf (buffer, format, liste d'adresses) Exemples : fprintf (stderr, "usage: %s [-d] [conf]", progname); fprintf (stderr, "httpd: could not get socket\n"); sprintf (identite, "Client: %s@%s", user, machine); 430
113 431
114 E/S standards formatées : fscanf, exemple scanf retourne le nombre d'éléments affectés. Il s'arrête lors du premier conflit. /* lecture dans un fichier ou sur /dev/tty : on lit des mots et on s arrete sur EOF */ #include <stdio.h> #include <stdlib.h> #define MAX_MOTS 80 int main(int argc, char *argv[]){ int ret_sc; FILE *Fichier; char Mots_lu[MAX_MOTS]; } Fichier = fopen(argv[1], "r"); if(fichier == NULL){ printf("pb ouverture %s\n", argv[1]); return 1; } ret_sc=0; while ( (ret_sc!= EOF) ){ ret_sc=fscanf(fichier,"%s", Mots_lu); if (ret_sc == 1) printf("mot lu : %s\n", Mots_lu); } printf("\n main : fin\n"); return 0; 432
Le système de gestion des fichiers, les entrées/sorties.
Le système de gestion des fichiers, les entrées/sorties. Luigi Santocanale Laboratoire d Informatique Fondamentale, Centre de Mathématiques et Informatique, 39, rue Joliot-Curie - F-13453 Marseille 19
Dans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers.
I Présentation : Dans le chapitre 1, nous avons vu comment utiliser les appels-systèmes de bas niveau pour créer et accéder à des fichiers sur le disque. Nous avons notamment mis en évidence leur dépouillement
Cours 6 : Tubes anonymes et nommés
Cours 6 : Tubes anonymes et nommés Mécanisme de communications du système de fichiers I-node associé. Type de fichier: S_IFIFO. Accès au travers des primitives read et write. Les tubes sont unidirectionnels
Cours de Système : Gestion de Fichiers
Cours de Système : Gestion de Fichiers Bertrand Le cun et Emmanuel Hyon bertrand.le cun{at}u-paris10.fr et Emmanuel.Hyon{at}u-paris10.fr Université Paris Ouest Nanterre 25 octobre 2011 B.L.C. & E.H. (UPO)
Programmation impérative
Programmation impérative Cours 4 : Manipulation des fichiers en C Catalin Dima Organisation des fichiers Qqs caractéristiques des fichiers : Nom (+ extension). Chemin d accès absolu = suite des noms des
Programmation système I Les entrées/sorties
Programmation système I Les entrées/sorties DUT 1 re année Université de Marne La vallée Les entrées-sorties : E/O Entrées/Sorties : Opérations d échanges d informations dans un système informatique. Les
Programmation système de commandes en C
Programmation système de commandes en C Cours de Programmation système Tuyêt Trâm DANG NGOC Université de Cergy-Pontoise 2012 2013 Tuyêt Trâm DANG NGOC Programmation système de commandes
GESTION DES FICHIERS C/UNIX
Licence IG Page 1 sur 6 GESTION DES FICHIERS C/UNIX Introduction Deux modes d appel - Par la bibliothèque standard C (appel de haut niveau) - Par appels système (bas niveau) Nécessite les includes suivant
SYSTÈME DE GESTION DE FICHIERS
SYSTÈME DE GESTION DE FICHIERS - DISQUE 1 Les couches logiciels réponse requête Requêtes E/S Système E/S Pilote E/S Interruptions utilisateur traitement S.E. commandes S.E. S.E. matériel Contrôleur E/S
SYSTÈME DE GESTION DE FICHIERS SGF - DISQUE
SYSTÈME DE GESTION DE FICHIERS SGF - DISQUE C.Crochepeyre MPS_SGF 2000-20001 Diapason 1 Les couches logiciels réponse SGF requête matériel matériel Requêtes E/S Système E/S Pilote E/S Interruptions Contrôleur
Cours Programmation Système
Cours Programmation Système Filière SMI Semestre S6 El Mostafa DAOUDI Département de Mathématiques et d Informatique, Faculté des Sciences Université Mohammed Premier Oujda [email protected] Février
3IS - Système d'exploitation linux - Programmation système
3IS - Système d'exploitation linux - Programmation système 2010 David Picard Contributions de : Arnaud Revel, Mickaël Maillard [email protected] Environnement Les programmes peuvent être exécutés dans des
6 - Le système de gestion de fichiers F. Boyer, UJF-Laboratoire Lig, [email protected]
6 - Le système de gestion de fichiers F. Boyer, UJF-Laboratoire Lig, [email protected] Interface d un SGF Implémentation d un SGF Gestion de la correspondance entre la structure logique et la structure
Programmation C. Apprendre à développer des programmes simples dans le langage C
Programmation C Apprendre à développer des programmes simples dans le langage C Notes de cours sont disponibles sur http://astro.u-strasbg.fr/scyon/stusm (attention les majuscules sont importantes) Modalités
La mémoire. Un ordinateur. L'octet. Le bit
Introduction à l informatique et à la programmation Un ordinateur Un ordinateur est une machine à calculer composée de : un processeur (ou unité centrale) qui effectue les calculs une mémoire qui conserve
Systèmes d Exploitation - ENSIN6U3. Aix-Marseille Université
Systèmes d Exploitation - ENSIN6U3 Systèmes de gestion de fichiers - SGF Leonardo Brenner 1 Jean-Luc Massat 2 1 [email protected] 2 [email protected] Aix-Marseille Université Faculté
Chapitre 3 : Système de gestion de fichiers
: 3.1- Introduction Le système de gestion de fichiers (SGF) est la partie la plus visible d un système d exploitation qui se charge de gérer le stockage et la manipulation de fichiers (sur une unité de
Système de Gestion de Fichiers
Chapitre 2 Système de Gestion de Fichiers Le système de gestion de fichiers est un outil de manipulation des fichiers et de la structure d arborescence des fichiers sur disque et a aussi le rôle sous UNIX
Programmation système en C/C++
Programmation système en C/C++ Jean-Baptiste Vioix ([email protected]) LE2I - ENESAD http://jb.vioix.free.fr 1-41 Programmation en C/C++ sous Unix Il existe des très nombreux outils de développement sous
Les fichiers. Chapitre 4
Chapitre 4 Les fichiers Jusqu à maintenant tous les programmes que nous avons conçus travaillaient sur des données qui étaient perdues après chaque session de travail. On peut cependant, c est bien naturel,
Bases de programmation. Cours 5. Structurer les données
Bases de programmation. Cours 5. Structurer les données Pierre Boudes 1 er décembre 2014 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. Types char et
Unix/Linux I. 1 ere année DUT. Université marne la vallée
Unix/Linux I 1 ere année DUT Université marne la vallée 1 Introduction 2 Fonctions et spécifité d Unix Architecture 3 4 5 Fichier Unix Arborescence de fichiers Quelques commandes sur les fichiers Chemins
Structure fonctionnelle d un SGBD
Fichiers et Disques Structure fonctionnelle d un SGBD Requetes Optimiseur de requetes Operateurs relationnels Methodes d acces Gestion de tampon Gestion de disque BD 1 Fichiers et Disques Lecture : Transfert
Le langage C. Séance n 4
Université Paris-Sud 11 Institut de Formation des Ingénieurs Remise à niveau INFORMATIQUE Année 2007-2008 Travaux pratiques d informatique Le langage C Séance n 4 But : Vous devez maîtriser à la fin de
Outils pour la pratique
Cinquième partie Outils pour la pratique 121 CHAPITRE 1 Les bases des séances de TP Avant de lire cettre section, il est suggéré de relire vos notes de cours se rapportant au système d exploitation Unix.
1. Systèmes d entrée/sortie 2. Systèmes de fichiers 3. Structure de mémoire de masse (disques)
Chapitre 4 Le système de Gestion de Fichiers 1. Systèmes d entrée/sortie 2. Systèmes de fichiers 3. Structure de mémoire de masse (disques) 1 Systèmes d entrée/sortie Concepts importants : Matériel E/S
Processus! programme. DIMA, Systèmes Centralisés (Ph. Mauran) " Processus = suite d'actions = suite d'états obtenus = trace
Processus 1) Contexte 2) Modèles de Notion de Points de vue Modèle fourni par le SX Opérations sur les 3) Gestion des Représentation des Opérations 4) Ordonnancement des Niveaux d ordonnancement Ordonnancement
Travaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation
Université de Savoie Module ETRS711 Travaux pratiques Compression en codage de Huffman 1. Organisation du projet 1.1. Objectifs Le but de ce projet est d'écrire un programme permettant de compresser des
Gestion répartie de données - 1
Gestion répartie de données - 1 Sacha Krakowiak Université Joseph Fourier Projet Sardes (INRIA et IMAG-LSR) http://sardes.inrialpes.fr/~krakowia Gestion répartie de données Plan de la présentation Introduction
Introduction aux Systèmes et aux Réseaux
Introduction aux Systèmes et aux Réseaux Cours 5 Processus D après un cours de Julien Forget (univ Lille1) Laure Gonnord http://laure.gonnord.org/pro/teaching/ [email protected] Master CCI -
Introduction au langage C
Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les
Généralités sur le Langage Java et éléments syntaxiques.
Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...
Cours 14 Les fichiers
Cours 14 Les fichiers F. Gayral 1 Fichier : définition /media/travaux/documents/fgenseignement/java1/courstpsfgfc/14-fichiers/voirtypefichiers Fichier = ensemble d informations codées et stockées sur une
IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C
IN 102 - Cours 1 Qu on le veuille ou non, les systèmes informatisés sont désormais omniprésents. Même si ne vous destinez pas à l informatique, vous avez de très grandes chances d y être confrontés en
Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java
Langages objets Introduction M2 Pro CCI, Informatique Emmanuel Waller, LRI, Orsay présentation du module logistique 12 blocs de 4h + 1 bloc 2h = 50h 1h15 cours, 45mn exercices table, 2h TD machine page
Partie 7 : Gestion de la mémoire
INF3600+INF2610 Automne 2006 Partie 7 : Gestion de la mémoire Exercice 1 : Considérez un système disposant de 16 MO de mémoire physique réservée aux processus utilisateur. La mémoire est composée de cases
Algorithmique et Programmation, IMA
Algorithmique et Programmation, IMA Cours 2 : C Premier Niveau / Algorithmique Université Lille 1 - Polytech Lille Notations, identificateurs Variables et Types de base Expressions Constantes Instructions
1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.
1. Structure d un programme C Un programme est un ensemble de fonctions. La fonction "main" constitue le point d entrée pour l exécution. Un exemple simple : #include int main() { printf ( this
Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :
Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de
Titre: Version: Dernière modification: Auteur: Statut: Licence:
Titre: Installation de WebObjects 5.3 Version: 2.1 Dernière modification: 2011/02/17 11:00 Auteur: Aurélien Minet Statut: version finale Licence: Creative Commons
MEDIAplus elearning. version 6.6
MEDIAplus elearning version 6.6 L'interface d administration MEDIAplus Sommaire 1. L'interface d administration MEDIAplus... 5 2. Principes de l administration MEDIAplus... 8 2.1. Organisations et administrateurs...
4. Utilisation d un SGBD : le langage SQL. 5. Normalisation
Base de données S. Lèbre [email protected] Université de Strasbourg, département d informatique. Présentation du module Contenu général Notion de bases de données Fondements / Conception Utilisation :
Licence Sciences et Technologies Examen janvier 2010
Université de Provence Introduction à l Informatique Licence Sciences et Technologies Examen janvier 2010 Année 2009-10 Aucun document n est autorisé Les exercices peuvent être traités dans le désordre.
Les chaînes de caractères
Les chaînes de caractères Dans un programme informatique, les chaînes de caractères servent à stocker les informations non numériques comme par exemple une liste de nom de personne ou des adresses. Il
TP1 - Prise en main de l environnement Unix.
Mise à niveau UNIX Licence Bio-informatique TP1 - Prise en main de l environnement Unix. Les sujets de TP sont disponibles à l adresse http://www.pps.jussieu.fr/~tasson/enseignement/bioinfo/ Les documents
TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique
Communications entre Processus Communication par tubes. TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique Exemple 1: On a deux processus Père/Fils. Le père
Compression de Données - Algorithme de Huffman Document de Conception
ROLLET Samuel SALLE Jennifer Compression de Données - Algorithme de Huffman Document de Conception Projet d'algorithmique et Structure des Données 1 SOMMAIRE 1. Domaine d application....4 1.1 Objectifs
Stockage du fichier dans une table mysql:
Stockage de fichiers dans des tables MYSQL avec PHP Rédacteur: Alain Messin CNRS UMS 2202 Admin06 30/06/2006 Le but de ce document est de donner les principes de manipulation de fichiers dans une table
1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles)
1/4 Objectif de ce cours /4 Objectifs de ce cours Introduction au langage C - Cours Girardot/Roelens Septembre 013 Du problème au programme I passer d un problème exprimé en français à la réalisation d
Gestion de mémoire secondaire F. Boyer, Laboratoire Sardes [email protected]
Gestion de mémoire secondaire F. Boyer, Laboratoire Sardes [email protected] 1- Structure d un disque 2- Ordonnancement des requêtes 3- Gestion du disque - formatage - bloc d amorçage - récupération
03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing
3/4/27 Programmation Avancée Multimédia Multithreading Benoît Piranda Équipe SISAR Université de Marne La Vallée Besoin Programmes à traitements simultanés Réseau Réseau Afficher une animation en temps
INITIATION AU LANGAGE C SUR PIC DE MICROSHIP
COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par
Chapitre 1 : Introduction aux bases de données
Chapitre 1 : Introduction aux bases de données Les Bases de Données occupent aujourd'hui une place de plus en plus importante dans les systèmes informatiques. Les Systèmes de Gestion de Bases de Données
«Astrophysique et instrumentations associées» Cours UNIX. 2006 Benoît Semelin
M2 «Astrophysique et instrumentations associées» Cours UNIX 2006 Benoît Semelin Les OS OS = Operating System : Programme de base qui assure la gestion du matériel (clavier, écran, disque dur...), du système
Le prototype de la fonction main()
Le prototype de la fonction main() 1. Introduction...1 2. Paramètres et type de retour de la fonction main()...1 3. Exemple 1...2 4. La fonction exit() du C...2 5. Détecter le code de retour d un programme
UEO11 COURS/TD 1. nombres entiers et réels codés en mémoire centrale. Caractères alphabétiques et caractères spéciaux.
UEO11 COURS/TD 1 Contenu du semestre Cours et TDs sont intégrés L objectif de ce cours équivalent a 6h de cours, 10h de TD et 8h de TP est le suivant : - initiation à l algorithmique - notions de bases
Les structures de données. Rajae El Ouazzani
Les structures de données Rajae El Ouazzani Les arbres 2 1- Définition de l arborescence Une arborescence est une collection de nœuds reliés entre eux par des arcs. La collection peut être vide, cad l
Gestion de la mémoire
433 43 3 Gestion de la mémoire + 1. Qu'est-ce que la mémoire? - Définitions, exemples 2. Allocation contiguë en mémoire - Partitions de taille fixe, de taille variable 3. Pagination et mémoire virtuelle
Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski [email protected]
Introduction à la programmation orientée objet, illustrée par le langage C++ Patrick Cégielski [email protected] Mars 2002 Pour Irène et Marie Legal Notice Copyright c 2002 Patrick Cégielski Université
Bon ben voilà c est fait!
Bon ben voilà c est fait! Au programme : - Exploration de l arborescence et informations systèmes - Action sur les dossiers et fichiers - Gestion des autorisations - Conversion pdf en text - Connexion
Premiers pas en Linux
Premiers pas en Linux 1 Bref historique Linux Système d'exploitation créé en 1991. Par Linus Torvalds un étudiant nlandais. Développé et amélioré par des centaines de spécialistes dans le monde. Particularité
REALISATION d'un. ORDONNANCEUR à ECHEANCES
REALISATION d'un ORDONNANCEUR à ECHEANCES I- PRÉSENTATION... 3 II. DESCRIPTION DU NOYAU ORIGINEL... 4 II.1- ARCHITECTURE... 4 II.2 - SERVICES... 4 III. IMPLÉMENTATION DE L'ORDONNANCEUR À ÉCHÉANCES... 6
Personnes ressources Tice. Académie de Rouen
Personnes ressources Tice Académie de Rouen Objectifs Acquérir les connaissances de base concernant Linux Découvrir la solution technique SambaEdu3 : serveur de fichiers sous Linux Mettre en oeuvre cette
École Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Contrôle périodique.
École Polytechnique de Montréal Département de Génie Informatique et Génie Logiciel Cours INF2610 Contrôle périodique Automne 2013 Date : 11 octobre 2013 de 18h à 20h Professeur : Boucheneb Hanifa Documentation
UE Programmation Impérative Licence 2ème Année 2014 2015
UE Programmation Impérative Licence 2 ème Année 2014 2015 Informations pratiques Équipe Pédagogique Florence Cloppet Neilze Dorta Nicolas Loménie [email protected] 2 Programmation Impérative
TP 1 Prise en main de l environnement Unix
Introduction aux systèmes d exploitation (IS1) TP 1 Prise en main de l environnement Unix Le but de ce premier TP est de commencer à vous familiariser avec l environnement Unix. 1 Ouverture de session
Le Network File System de Sun (NFS)
1 sur 5 Le Network File System de Sun (NFS) Le Network File System de Sun (NFS) Architecture Protocoles Mounting Automounting vs Static mounting Directory et accès aux fichiers Problèmes Implémentation
TP3 : Manipulation et implantation de systèmes de fichiers 1
École Normale Supérieure Systèmes et réseaux Année 2012-2013 TP3 : Manipulation et implantation de systèmes de fichiers 1 1 Répertoire de travail courant Le but de l exercice est d écrire une commande
LES SYSTÈMES DE FICHIERS
SECTION M.R.I.M. - L.P. CHATEAU-BLANC 45120 CHALETTE SUR LOING LES SYSTÈMES DE FICHIERS Table des matières : Supports physiques (média) Les fs supportés par MS-Windows Principe de la table d'allocation
Domain Name System. F. Nolot
Domain Name System F. Nolot 1 Domain Name System Principe F. Nolot 2 Les besoins Internet est composé de plusieurs réseaux Chaque réseau est composé de sous réseaux Les sous réseaux sont constitués de
Licence ST Université Claude Bernard Lyon I LIF1 : Algorithmique et Programmation C Bases du langage C 1 Conclusion de la dernière fois Introduction de l algorithmique générale pour permettre de traiter
PRESENTATION RESSOURCES. Christian Dupaty BTS Systèmes Numériques Lycée Fourcade Gardanne Académie d Aix Marseille
PRESENTATION RESSOURCES Christian Dupaty BTS Systèmes Numériques Lycée Fourcade Gardanne Académie d Aix Marseille 1) Introduction, Objectifs et Intentions Le BTS SN (Systèmes Numériques) intègre la formation
Présentation du SC101
Présentation du SC101 True SAN (Storage Area Network) Boîtier intégrant la technologie Z-SAN 2 emplacements IDE 3,5" (jusqu'à 2 disques durs) 1 port Ethernet RJ45 10/100 Logiciel SmartSync Pro Backup Stockage
INTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Documentation Honolulu 14 (1) - 0209
Documentation Honolulu 14 (1) - 0209 Honolulu 14 3 Sommaire Honolulu 14 le portail Intranet / Internet de votre entreprise PARTIE 1 -MANUEL UTILISATEUR 1. LE PORTAIL HONOLULU : PAGE D ACCUEIL 8 1.1 Comment
Techniques de stockage. Techniques de stockage, P. Rigaux p.1/43
Techniques de stockage Techniques de stockage, P. Rigaux p.1/43 Techniques de stockage Contenu de ce cours : 1. Stockage de données. Supports, fonctionnement d un disque, technologie RAID 2. Organisation
I. Introduction aux fonctions : les fonctions standards
Chapitre 3 : Les fonctions en C++ I. Introduction aux fonctions : les fonctions standards A. Notion de Fonction Imaginons que dans un programme, vous ayez besoin de calculer une racine carrée. Rappelons
CARPE. Documentation Informatique S E T R A. Version 2.00. Août 2013. CARPE (Documentation Informatique) 1
CARPE (Documentation Informatique) 1 CARPE Version 2.00 Août 2013 Documentation Informatique S E T R A Programme CARPE - Manuel informatique de l'utilisateur CARPE (Documentation Informatique) 2 Table
Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples
Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation impérative et structures de données simples Introduction au langage C Sandrine Blazy - 1ère année 24 octobre 2007 Cours d Algorithmique-Programmation
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE QCM Remarque : - A une question correspond au moins 1 réponse juste - Cocher la ou les bonnes réponses Barème : - Une bonne réponse = +1 - Pas de réponse = 0
(Langage de commandes) Les commandes sont données par l'utilisateur grâce au clavier, à partir d'une "invite" ou "prompt" (par exemple "c:\>" )
Système d Exploitation d : MS-DOS MicroSoft Disk Operating System C est un système d exploitation développé par la société Microsoft. Il offre une interface textuelle basée sur un ensemble de commandes.
Projet gestion d'objets dupliqués
Projet gestion d'objets dupliqués Daniel Hagimont [email protected] 1 Projet Service de gestion d'objets dupliqués Mise en cohérence lors de la prise d'un verrou sur un objet Pas de verrous imbriqués
PROBLEMES D'ORDONNANCEMENT AVEC RESSOURCES
Leçon 11 PROBLEMES D'ORDONNANCEMENT AVEC RESSOURCES Dans cette leçon, nous retrouvons le problème d ordonnancement déjà vu mais en ajoutant la prise en compte de contraintes portant sur les ressources.
TD séances n 3 et n 4 Répertoires et Fichiers sous Unix
Ce TP est destiné à vous familiariser avec les fichiers sous l'environnement UNIX. Fortement axé sur la pratique, il aborde la création, la manipulation et la suppression des répertoires et fichiers. 1
FreeNAS 0.7.1 Shere. Par THOREZ Nicolas
FreeNAS 0.7.1 Shere Par THOREZ Nicolas I Introduction FreeNAS est un OS basé sur FreeBSD et destiné à mettre en œuvre un NAS, système de partage de stockage. Pour faire simple, un NAS est une zone de stockage
Systèmes d exploitation
Systèmes d exploitation Virtualisation, Sécurité et Gestion des périphériques Gérard Padiou Département Informatique et Mathématiques appliquées ENSEEIHT Novembre 2009 Gérard Padiou Systèmes d exploitation
Simulation d un système de paiement par carte bancaire
Simulation d un système de paiement par carte bancaire Mini projet IN301/IN3ST01-2009-2010 Sujet rédigé par Jean Cousty et Laurent Najman, très librement inspiré d un projet de Jérome Gueydan pour l ENSTA
l'ordinateur les bases
l'ordinateur les bases Démarrage de l'ordinateur - Le bureau, mon espace de travail - J'utilise la souris - Ouvertes ou fermées, les fenêtres - Dans l'ordinateur, tout est fichier - Le clavier : écrire,
DE L ALGORITHME AU PROGRAMME INTRO AU LANGAGE C 51
DE L ALGORITHME AU PROGRAMME INTRO AU LANGAGE C 51 PLAN DU COURS Introduction au langage C Notions de compilation Variables, types, constantes, tableaux, opérateurs Entrées sorties de base Structures de
Conventions d écriture et outils de mise au point
Logiciel de base Première année par alternance Responsable : Christophe Rippert [email protected] Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette
1 Mesure de la performance d un système temps réel : la gigue
TP TR ENSPS et MSTER 1 Travaux Pratiques Systèmes temps réel et embarqués ENSPS ISV et Master TP1 - Ordonnancement et communication inter-processus (IPC) Environnement de travail Un ordinateur dual-core
PLAN Introduction à UNIX Patrick Fuchs Dynamique des Structures et Interactions des Macromolécules Biologiques Université Paris Diderot [email protected] 2 PLAN Système d'exploitation
Introduction aux Systèmes et aux Réseaux, Master 2 CCI
aux Systèmes et aux Réseaux, Master 2 CCI Cours 1 : Introduction et contexte Unix/Linux Laure Gonnord http://laure.gonnord.org/pro/teaching/ [email protected] Master CCI - Université Lyon 1 -
Aide-Mémoire unix. 9 février 2009
Aide-Mémoire unix Nicolas Kielbasiewicz 9 février 2009 Le système d exploitation unix est de plus en plus présent aujourd hui. Comme tous les projets Open Source, on le trouve sous différentes formes :
Configuration d'un annuaire LDAP
Le serveur Icewarp Configuration d'un annuaire LDAP Version 10.3 Juillet 2011 Icewarp France / DARNIS Informatique i Sommaire Configuration d'un annuaire LDAP 1 Introduction... 1 Qu'est-ce que LDAP?...
Systemes d'exploitation des ordinateurs
! " #$ % $ &' ( $ plan_ch6_m1 Systemes d'exploitation des ordinateurs Conception de Systèmes de Gestion de la Mémoire Centrale Objectifs 1. Conception de systèmes paginés 2. Conception des systèmes segmentés
Formateurs : Jackie DAÖN Franck DUBOIS Médiapôle de Guyancourt
Client sur un domaine stage personnes ressources réseau en établissement janvier 2004 Formateurs : Jackie DAÖN Franck DUBOIS Médiapôle de Guyancourt Lycée de Villaroy 2 rue Eugène Viollet Le Duc BP31 78041
Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java
Info0101 Intro. à l'algorithmique et à la programmation Cours 3 Le langage Java Pierre Delisle, Cyril Rabat et Christophe Jaillet Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique
Projet Administration Réseaux
EL KHATIT Zouhair, L3 ASR N : 20072486 Projet Administration Réseaux Thème : SFTP & SCPOnly I- SFTP (Secure File Transfer Protocol) : Introduction: Le SFTP permet de transférer des fichiers par une connexion
Rappels Entrées -Sorties
Fonctions printf et scanf Syntaxe: écriture, organisation Comportement Données hétérogènes? Gestion des erreurs des utilisateurs 17/11/2013 Cours du Langage C [email protected] ibrahimguelzim.atspace.co.uk
