Utilisateur:Silex6/Bac à sable - archive 2 - 2011
Intro
[modifier | modifier le code]En informatique un programme est une séquence d'instructions qui spécifie étape par étape les opérations à effectuer pour obtenir un résultat, dans une forme qui permet d'utiliser un ordinateur pour les exécuter. Un programme est la forme électronique d'un algorithme exprimé dans un langage de programmation - un vocabulaire et des règles de ponctuation destinées à exprimer des programmes.
Un programme source sont les opérations telles qu'elles ont été exprimées par un programmeur, souvent dans un langage de programmation de haut niveau, c'est-à-dire dont la notation s'inspire des langues naturelles - le vocabulaire et la ponctuation utilisée sont typiquement inspirés de l'anglais.
Un programme objet ou binaire est la forme sous laquelle il pourra être exécuté par un ordinateur: une suite de valeurs binaires difficiles à manipuler pour le programmeur, et obtenus par traduction automatique du programme source.
Une séquence d'instructions qui spécifie étape par étape les opérations à exécuter par un ordinateur. Le programme décrit de manière exacte ce qu'il y a à faire, quand et avec quelles informations. Un programme est une suite algorithmique d'opérations à effectuer pour réaliser une certaine tâche. Les programmes sont écrits dans un langage de programmation, la plupart des langages de programmation sont dit de haut niveau et visent à imiter les langues naturelles.
Selon les lois du droit d'auteur de 1980, un programme est un ensemble de déclarations et d'instructions qui peut être utilisé directement ou indirectement dans un ordinateur pour obtenir un certain résultat.
La forme objet d'un programme peut être directement exécutée par un ordinateur. Cette forme exprimée en langage machine est composée de suite de nombres binaires difficile à manipuler pour le programmeur. Le programmeur utilise alors un langage de haut niveau, basé sur le vocabulaire et la ponctuation de l'anglais. Un programme sous sa forme en langage de haut niveau doit être traduit en langage objet avant de pouvoir être exécuté.
Brut
[modifier | modifier le code][8] Un programme est une suite d'instructions qui spécifient étape par étape les opérations à exécuter par un ordinateur. Le programme décrit de manière exacte les différentes étapes d'un algorithme: ce qu'il y a à faire, quand et avec quelles informations.[9]Selon l'architecture de von Neumann crée en 1945, un programme est enregistré dans la mémoire de l'ordinateur, ce qui permet de l'exécuter de manière répétée sans intervention humaine.
Un langage de programmation est une notation utilisée pour exprimer des algorithme et les faire exécuter par un ordinateur. Un algorithme est un procédé pour obtenir un résultat par une succession de calculs, décrit sous forme de pictogrammes et de termes simples dans une langue naturelle.[11] Jusqu'en 1950 les programmeurs exprimaient les programmes dans le langage de l'ordinateur, un langage fait de termes bizzarres qui rendait le travail pénible et le résultat sujet à de nombreuses erreurs. Dès 1950 les programmes ont été décrit dans un langage différent - un langage de programmation, ce qui rendait les opérations plus simples à exprimer. Le programme était ensuite traduit automatiquement sous une forme qui permet d'être exécuté par l'ordinateur.
Sur demande, l'ordinateur exécutera les instructions du programme, bien qu'il exécute toujours exactement ce qui est instruit et ne se trompe jamais, il peut arriver que les instructions qu'il exécute soient erronées suite à une erreur humaine lors de l'écriture du programme. Les langages de programmations visent à diminuer le nombre de bugs, ils sont cependant inévitables dans des programmes de plusieurs milliers de lignes.[13] Un programme de traitement de texte peut être fait de plus de 750 000 lignes de programme, et un système d'exploitation peut être fait de plus de 50 millions de lignes. En moyenne un programmeur prépare, écrit, teste et documente environ 20 lignes de programme par jour, et la création de grands programmes est le fait d'équipes et peut nécessiter plusieurs mois voire plusieurs années.
La programmation - la création de programmes - est un sujet central en science informatique. Les instruction qu'un ordinateur devra exécuter doivent pouvoir être exprimées de manière précise et non ambiguë. Pour ce faire, les langages de programmation combinent la lisibilité de l'anglais avec l'exactitude des mathématiques.[15][16] Les programmes sont créés par des programmeurs, ou des ingénieurs logiciels. La création d'un programme comprends une série d'activités telles que la planification, la conception, l'écriture du code, le test et la documentation, en vue d'obtenir un programme de meilleure qualité, le travail de programmation se fait selon une démarche systématique et planifiée.
[17] Un programme fait généralement partie d'un logiciel: un ensemble qui comporte généralement plusieurs programmes, ainsi que tout le nécessaire pour permettre leur utilisation: fichiers de données, fichiers de configuration et documentation.
En droit un programme est une oeuvre écrite, protégé par le droit d'auteur. Le texte peut paraitre à première vue dénué de sens, mais apparaitre très clair et informatif pour un lecteur averti. Le droit d'auteur s'applique au programme du moment qu'il est enregistré de manière permanente, même si il n'existe pas d'édition sur papier. Le droit d'auteur protège autant le programme source - écrit par le programmeur sous une forme formalisée de l'anglais, que le programme binaire - celui traduit sous forme de bits par le compilateur.
Tandis que les algorithmes sont décrits en termes simples, les instructions que la machine exécute sont des ordres bizzarres, difficiles à manipuler pour un humain. Les langages de programmation ont été créés dans le but de faciliter la transformation d'un algorithme en instructions.
Les premiers langages de programmation ont été créée en 1950. Le logiciel sont l'ensemble des instruction qu'un ordinateur utilise pour exécuter des algorithmes, ces instructions dirigent les activités du matériel de l'ordinateur.
Les programmes sont la manière par laquelle nous exprimont aux ordinateur que faire. Jusqu'en 1950 les programmes étaient exprimés dans le langage de l'ordinateur, ce qui rendait l'expression pénible et le résultat sujet à de nombreuses erreurs. Dès 1950 les programmes ont été décrit dans un langage de programmation, ce qui rendait les opérations plus simples à exprimer. Le programme exprimé dans le langage de programmation est alors traduit automatiquement sous une forme compréhensible par l'ordinateur avant d'être exécuté.
D'une manière générale un programme tient compte d'informations entrantes (anglais input), les manipule en vue d'obtenir un résultat sortant (anglais output).
En vue d'obtenir un programme de meilleure qualité, la création de ce dernier - la programmation -se fait selon une démarche systématique et planifiée.
Les qualités recherchées d'un programme sont l'efficacité, la flexibilité, la fiabilité, la portabilité, et robustesse, il doit également être convivial et explicite:
- efficacité: le programme doit demander peu d'effort de programmation, les instructions doivent demander peu de temps et nécessiter peu de mémoire.
- flexibilité: le programme doit pouvoir être utilisé pour de nombreux usages.
- fiabilité: le programme doit donner le résultat attendu quels que soient les changements - permanents ou temporaires - du système informatique.
- portabilité: Un programme écrit pour un ordinateur donné est dit portable si il peut facilement être transféré sur un autre ordinateur.
- robustesse: un programme est dit robuste si il produit des résultats probants y compris lorsque les informations entrées sont incorrectes. Dans tel cas un programme robuste signale le problème par un message.
- convivial: Un programme est dit convivial si il peut être facilement compris par un usager novice. Un tel programme comporte des messages clairs et les résultats sont affichés sous une forme facile à comprendre.
- explicite: les instructions du programme utilisent des noms qui auto-documentent le programme. Un tel programme est plus facile à modifier par la suite
Dans les premières générations d'ordinateurs ces instructions - le code - étaient des suites de codes binaires; en 2011 les instructions sont des mots courants en anglais.
Un programme de traitement de texte peut être fait de plus de 750 000 lignes de programme, et un système d'exploitation peut être fait de plus de 50 millions de lignes. En moyenne un programmeur prépare, écrit, teste et documente environ 20 lignes de programme par jour, et la création de grands programmes est le fait d'équipes et peut nécessiter plusieurs mois voire plusieurs années.
Les programmes sont créés par des programmeurs, ou des ingénieurs logiciels. La création d'un programme comprends une série d'activités telles que la planification, la conception, l'écriture du code, le test et la documentation. Oeuvrant à toutes ces activités, les programmeurs mettent l'accent principalement sur l'écriture de programmes. Quand aux ingénieurs logiciels, ils travaillent à toutes les étapes de la création du programme, en appliquant une démarche formelle et rigoureuse basée sur le génie industriel et les techniques de management, dans le but de réduire les coûts et la complexité du programme tout en augmentant sa fiabilité.
Un programme est typiquement enregistré dans un fichier, puis copié en mémoire en cas de besoin. Il peut également être enregistré dans une puce de mémoire morte. Il peut être composé d'un ou de plusieurs modules et les instructions peuvent être en rapport avec une application informatique, un pilote informatique, ou un système d'exploitation.
[23] Un langage de programmation est un vocabulaire et un ensemble de règles d'écriture utilisées pour instruire un ordinateur d'effectuer certaines tâches.
Cycle de vie:
Avant de commencer à écrire un programme destiné à résoudre un problème, le programmeur doit déterminer le problème à résoudre. Il y a plusieurs manières de le déterminer, la plupart consistent en suite de petites étapes indépendantes du langage de programmation utilisé. La technique courante est un cycle de développement, souvent répété plusieurs fois, qui comporte des étapes de définition, de conception, d'écriture, de test, d'installation et de maintenance:
- définition: le problème est tout d'abord examiné en détail en vue de connaitre l'étendue du programme à créer.
- conception: la conception consiste à choisir des solutions et des algorithmes, puis décrire leur logique sous forme de diagrammes, en vue de clarifier le fonctionnement du programme et faciliter son écriture.
- écriture: l'écriture du programme dans un certain langage de programmation.
- test: consiste à effectuer des essais, puis comparer le résultat donné par le programme avec un résultat obtenu manuellement. Plusieurs opérations d'essai sont nécessaires.
- documentation: une fois les étape précédentes terminées, il est de la responsabilité du programmeur de fournir la documentation pour permettre à l'utilisateur de pouvoir se servir du programme. La documentation permet également à autrui de comprendre le fonctionnement du programme voir de le modifier.
- installation: à cette étape le programme est installé dans la machine de l'utilisateur final, et celui-ci receoit la documentation. Le programme sera ensuite modifié en fonction des commentaires fait par l'utilisateur, et des inconvénients qu'il a signalé.
- maintenance: les besoins des utilisateurs et des systèmes informatiques varient continuellement, et le programme est régulièrement reconstruit et modifié en vue d'être adapté au besoins. De nouvelles fonctions y sont ajoutées, et des erreurs qui n'avaient pas été décelées auparavant sont corrigées.
en droit un programme est un texte, et il est protégé par le droit d'auteur. Le texte peut paraitre à première vue dénué de sens, mais apparaitre très clair et informatif pour un lecteur averti. Le droit d'auteur s'applique au programme du moment qu'il est enregistré de manière permanente, même si il n'existe pas d'édition sur papier. Le droit d'auteur protège autant le programme source - écrit par le programmeur sous une forme formalisée de l'anglais, que le programme binaire - celui traduit sous forme de bits par le compilateur.
Selon les lois du droit d'auteur de 1980, un programme est un ensemble de déclarations et d'instructions qui peut être utilisé directement ou indirectement dans un ordinateur pour obtenir un certain résultat.
Outre les instructions, un programme peut comporter des indications de structure, de séquence, d'organisation, de fonction et d'objectifs, ainsi que des descriptions d'écran et d'interface graphiques.
La programmation - la création de programmes est un sujet central en science informatique. Les instruction qu'un ordinateur devra exécuter doivent pouvoir être exprimées de manière précise et non ambiguë. Pour ce faire, les langages de programmation combinent la lisibilité de l'anglais avec l'exactitude des mathématiques.
langage de programmation
[modifier | modifier le code][28] Un langage de programmation est un vocabulaire et un ensemble de règles d'écriture utilisées pour instruire un ordinateur d'effectuer certaines tâches.[29] La plupart des langages de programmation sont dits de haut niveau, c'est-à-dire que leur notation s'inspire des langues naturelles - le vocabulaire et la ponctuation utilisée sont typiquement inspirés de l'anglais.
[30] Le processeur est le composant électronique qui exécute les instructions. Chaque processeur est concu pour exécuter certaines instructions, dites instructions machine. La palette d'instructions disponibles sur un processeur forme le langage machine.[31] Par exemple le processeur Intel 80486 a une palette de 342 instructions.
[32] Le langage d'assemblage est une représentation textuelle des instructions machine.[33] Un langage de bas niveau qui permet d'exprimer les instructions machines sous une forme symbolique plus facile à manipuler, où il y a une correspondance 1-1 entre les instructions machines et les instructions en langage d'assemblage.
Les langages de programmation de haut niveau permettent d'exprimer des instructions de manière synthétique, en faisant abstraction du langage machine. Ils permettent d'exprimer des structures, permettent d'écrire des programmes plus rapidement, avec moins d'instructions. Par rapport au langage d'assemblage, les programmes écrits dans des langages de haut niveau sont plus simples à modifier et portables - ils peuvent fonctionner avec différents processeurs. [34] Cependant un programme exprimé en langage de haut niveau, puis compilé est moins efficace et comporte plus d'instruction que si il avait été exprimé en langage d'assemblage.
Ci-dessous le programme Hello world exprimé en langage de programmation Java:
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello world!");
}
}
Le même programme, exprimé dans le langage d'assemblage des processeurs x86:
main proc
jmp debut
mess db 'Hello world!$'
debut:
mov dx, offset mess
mov ah, 9
int 21h
ret
main endp
cseg ends
end main
Création
[modifier | modifier le code]La programmation consiste à parcourir le chemin qui va d'une idée - souvent vague - jusqu'à une suite d'instructions précises exécutées par une machine[1]. Les langages de programmation ont été créés dans l'optique de faciliter le travail du programmeur en raccourcissant le chemin qui va de l'idée au code source[2].
Les programmes sont créés par des programmeurs, ou des ingénieurs logiciels. Les programmeurs travaillent principalement sur l'écriture de programmes tandis que les ingénieurs logiciels travaillent à toutes les étapes de la création du programme. Ils appliquent une démarche formelle et rigoureuse basée sur le génie industriel et les techniques de management, dans le but de réduire les coûts de fabrication tout en augmentant la qualité du programme.
[36] Avant de commencer à écrire un programme destiné à résoudre un problème, le programmeur doit déterminer les caractéristiques du problème à résoudre. Ceci se fait en plusieurs étapes indépendantes du langage de programmation utilisé. La technique courante est celle d'un cycle de développement, qui comporte des étapes de définition, de conception, d'écriture, de test, d'installation et de maintenance:
Le problème est tout d'abord examiné en détail en vue de connaitre l'étendue du programme à créer. l'étape suivante consiste à choisir des solutions et des algorithmes, puis décrire leur logique sous forme de diagrammes, en vue de clarifier le fonctionnement du programme et faciliter son écriture.
Une fois le programme écrit, celui-ci subit une suite d'essais. Les résultats produits par le programme sont comparé avec des résultats obtenus manuellement. Plusieurs opérations d'essai sont nécessaires. Ensuite de quoi le programme est installé dans la machine de l'utilisateur final, qui fera ses premières observations. Le programme sera ensuite modifié en fonction des commentaires fait par l'utilisateur, et des inconvénients qu'il a signalé.
Les besoins des utilisateurs et des systèmes informatiques varient continuellement, et le programme est régulièrement reconstruit et modifié en vue d'être adapté au besoins. De nouvelles fonctions y sont ajoutées, et des erreurs qui n'avaient pas été décelées auparavant sont corrigées.
[37] Les qualités recherchées d'un programme sont l'efficacité, la flexibilité, la fiabilité, la portabilité, et robustesse, il doit également être convivial et facile à modifier:
Un programme est de qualité s'il demande peu d'effort de programmation, les instructions demandent peu de temps et nécessitent peu de mémoire, il peut être utilisé pour de nombreux usages et donne les résultats attendus quels que soient les changements - permanents ou temporaires - du système informatique.
Un programme est de qualité s'il peut être facilement transféré sur un modèle d'ordinateur différent de celui pour lequel il est construit, s'il produit des résultats probants y compris lorsque les informations entrées sont incorrectes, s'il peut peut être facilement compris par un usager novice et que le code source peut être facilement modifié par la suite.
Exécution
[modifier | modifier le code]Les programmes sont exécutés non seulement par les ordinateurs, mais par les nombreux appareils qui sont basés sur des composants informatique, par exemple certains robots ménagers, téléphones, fax, instruments de mesure, récepteur de télévision, ainsi que les pièces de matériel informatique telles que disque durs, routeurs, imprimantes, ainsi que les consoles de jeu vidéo, les assistants personnels et les automates bancaires. Contrairement aux ordinateurs, ces appareils ne contiennent souvent pas de système d'exploitation, et la vitesse d'exécution des programmes est souvent d'importance mineure.
Sans contre-indication, les instructions d'un programme sont exécutées une après l'autre, de manière linéaire. Les langages de programmations permettent d'exprimer des alternatives: une suite d'instructions est exécutée uniquement si une condition donnée est remplie, dans le cas contraire une autre suite est exécutée. Les langages de programmation permettent également de faire répéter l'exécution d'une suite d'instruction jusqu'à ce qu'une condition donnée soit remplie.
L'exécution se déroule de manière différente suivant si le langage de programmation s'utilise avec un compilateur ou un interpréteur:
- Un compilateur lit le programme source en entier, et le transforme en instructions machines. La transformation peut se faire en plusieurs étapes et nécessiter plusieurs lectures du programme. Une fois traduit, le programme est enregistré, puis copié en mémoire et exécuté par le processeur tel quel.
- Un interpréteur par contre, opère ligne par ligne: lit une ligne de programme source, puis exécute les instructions machines correspondantes. L'avantage d'un intepréteur c'est que les erreurs peuvent être immédiatement corrigées. Le désavantage est que l'exécution du programme est 5 à 25 fois moins rapide que si le programme avait été préalablement traduit et exécuté tel quel.
L'exécution des programmes est basé sur le principe de la machine à programme enregistré, de John von Neumann.
Les instructions de programme sont exécutées par un processeur. Ce composant électronique exécute chaque instruction de programme selon un cycle charger-décoder-exécuter: l'instruction est tout d'abord copiée depuis la mémoire vers le processeur, puis l'instruction est décomposée bit par bit pour déterminer l'opération à effectuer. La plupart des opérations sont d'ordre arithmétique (addition, soustraction), ou logiques.
[43] L'exécution du cycle charger-décoder-exécuter est rythmé par une horloge branchée au processeur.
En 2011 la fréquence d'horloge supportée par les processeurs contemporains se compte en mégahertz ou en gigahertz, ce qui corresponds à des millions voire des milliards de cycle d'horloge par seconde.
[45] Les processeurs contemporains peuvent traiter plusieurs instructions simultanément: lorsqu'une instruction est chargée, le processeur charge immédiatement l'instruction suivante, sans attendre que cette instruction soit décodée puis exécutée, et les processeurs peuvent également charger / décoder / exécuter plusieurs instructions en une seul cycle d'horloge.
[46] L'exécution de programmes par le processeur central (anglais CPU) contrôle la totalité des opérations effectuées par l'ordinateur.
Le système d'exploitation est un ensemble de programme chargés automatiquement lorsque l'ordinateur est mis en marche.
Il surveille l'exécution des autres programmes. [49]
Les systèmes d'exploitation contemporains permettent d'exécuter simultanément plusieurs programmes, au service de plusieurs utilisateurs, et en utilisant plusieurs processeurs. Le nombre de processeurs est généralement limité, et un processeur donné exécute typiquement plusieurs programmes. Dans les faits, le processeur n'exécute qu'un seul programme à la fois, et un programme planificateur (anglais scheduler) du système d'exploitation effectue un tournus, ou régulièrement il interrompt le programme en cours d'exécution, pour exécuter le programme suivant.
Le rythme du tournus est cependant tellement rapide qu'il donne l'illusion que les programmes sont exécutés en même temps.
L'aquariophilie consiste à reproduire et maintenir en captivité des animaux aquatiques. Contrairement à l'aquaculture dont le but est la production agro-alimentaire, en aquariophilie l'aquarium est utilisé comme une vitrine sur un monde habité différent ou on met en valeur l'aspect esthétique des animaux et du décor. L'aquarium devient alors un centre d'attraction qui remplace les photos, les tableaux ou la télévision.
Les enfants comme les adultes apprécient le spectacle d'observer de façon quotidienne une nature normalement inaccessible. La couleur verte souvent dominante, le silence et le spectacle vivant captivent l'attention, et l'aquarium offre une lucarne sur un havre de paix et un élément de retour à la nature qui libère du stress.[52] Il existe des adeptes d'aquariophilie de tout âge, depuis des adolescents jusqu'à des retraités. Ce peut être des néophytes, des amateurs, voire des professionnels ou des passionnés. Les passionnés d'aquarium y consacrent tout leur temps et toute leur énergie.
Au dela du simple fait d'admirer des animaux et des plantes, l'aquariophilie consiste à maintenir un ensemble hétéroclite de plantes et d'animaux, dont le choix dépends autant des goûts du propriétaire que des caractéristiques de l'eau et du climat: eau de mer, ou eau douce, tropicale ou tempérée. le pratiquant va rechercher à comprendre et reproduire des règles de la nature, dans le but de maintenir dans son équilibre écologique une tranche de nature reconstituée.
L'aquariophilie était autrefois pratiquée par des savants dans leur laboratoire, le milieu clos de l'aquarium se prête bien à l'observation de phénomènes écologiques et des mécanismes qui régulent les relations entre les êtres vivants et leur milieux. L'aquariophilie est maintenant populaire au point qu'il existe des rayons spécialisés dans les magasins grandes surface, ainsi que des magazines spécialisés et des aquariums ouverts au public.
Équilibre écologique
[modifier | modifier le code]Les règles naturelles de l'écosystème d'un aquarium sont essentiellement les mêmes que celles des mers, des lacs et des rivières. Les différences principales sont que la densité des animaux et des plantes est généralement supérieure à celle de la nature et le volume d'eau et réduit: Les millions de mètres cubes d'eau du milieu naturel ont pour effet d'assurer une constance absolue des conditions de l'eau et l'absence de pollution.
La constance des caractéristiques physico-chimiques de l'eau, qui garantis le maintien de l'équilibre écologique est une préoccupation majeure en aquariophilie: son maintien requiert des contrôles réguliers tels que la température de l'eau, son pH, son odeur, la présence de polluants, la couleur des poissons, leur appétit, la présence de bulles et d'algues.
Les poissons d'eau de mer sont souvent des espèces très colorées, et l'aquarium d'eau de mer peut contenir des espèces célèbres telles que le corail et les anémones, cependant les poissons et les plantes d'eau de mer sont plus fragiles et plus coûteux, et les erreurs peuvent entrainer des pertes lourdes et décourageantes, raison pour laquelle les aquariums d'eau de mer sont généralement déconseillés aux personnes inexpérimentées.
Plus l'aquarium est grand plus il est cher, et plus la composition de l'eau est stable. Dans un petit aquarium une pollution même mineure peut entraîner un enchaînement très rapide de dégradations, qui peuvent prendre une ampleur bien plus grande que dans un grand aquarium. Les règles de base de l'aquariophilie - ne pas surpeupler l'aquarium, de ne pas suralimenter les poissons et de remplacer régulièrement une partie de l'eau de l'aquarium par de l'eau propre - visent à assurer la stabilité du milieu.
L'équilibre écologique est un idéal datant des premiers aquariums, dans lequel le cycle production-décomposition-consommation est perpétuel, et l'aquarium ne nécessite ni nourriture ni entretien de l'eau. Bien que possible, cet idéal est rarement recherché par l'aquariophile parce qu'il nécessite beaucoup d'eau et de plantes, et très peu de poissons, d'où un gros investissement pour un résultat peu esthétique.
Seul le filtrage et l'entretien de l'eau de l'aquarium permet de maintenir en vie de nombreux poissons dans le peu d'eau de l'aquarium. Un tel écosystème et en fait déséquilibré et au « bord de la catastrophe » (sic), et il arrive que, suite à des erreurs de l'aquariophile, l'écosystème de l'aquarium bascule, aboutissant à la mort du milieu aquatique.
Le biotope
[modifier | modifier le code][54] En aquariophilie l'aquarium est utilisé comme une vitrine sur un milieu naturel, ou on met en valeur l'aspect esthétique des animaux et du décor. Une pratique courante des débutants, et parfois décriée des puristes, est de faire se côtoyer dans un même aquarium des plantes et des animaux qui ne se rencontrent pas dans la nature, dans un mélange hétéroclite, plus ou moins esthétiques suivant les cas.
Les aquariophiles amateurs ou expérimentés s'intéressent plutôt à reconstituer le plus fidèlement possible un biotope déterminé, et que tout concorde: eau, sol, plantes et poissons. Les biotopes très poissoneux tels que le bassin d'Amazonie, les grands lacs africains (lac Tanganika et lac Malawi), les rivières d'Asie, les mers tropicales ou les récifs de corail sont fréquents. La flore, la faune, mais également les caractéristiques physico-chimiques de l'eau diffèrent d'un biotope à l'autre.
Une autre pratique est celle de l'aquarium hollandais, dans lequel une place prépondérante est donnée aux plantes. Dans ce type de biotope des plantes provenant de plusieurs régions du monde peuvent cohabiter, les poissons n'ont qu'un rôle utilitaire, et le travail de l'aquariophile ressemble davantage à celui d'un horticulteur. Comme son nom l'indique, cette pratique est populaire aux Pays-Bas.
Un bassin de jardin peut être utilisé comme place pour un biotope naturel. Il peut être équipé de plantes et d'animaux résistant au climat local. Dans les régions tempérées il est possible d'y placer des poissons tropicaux durant la saison d'été. Un tel biotope peut être laissé à l'abandon durant les longues périodes. Les animaux qui s'y trouvent peuvent cependant être attaqués par la faune locale.
Les zoos, ainsi que les écoles, se servent souvent d'aquariums comme outils pédagogiques, pour présenter les animaux dans des conditions qui rappellent celles de leur milieu naturel. La couleur verte souvent dominante, le silence et le spectacle vivant captivent l'attention, et les aquariums sont également utilisés, en milieu médical, dans les salles d'attente, les établissements de kinésithérapie, de psychiatrie, ainsi que les prisons.
Impacts écologiques et économiques
[modifier | modifier le code]L'aquariophilie contribue au développement de la recherche scientifique concernant les milieux aquatiques: biologie, écologie, reproduction, alimentation et comportement des animaux et plantes aquatiques. L'aquariophilie est également utilisée pour tester les effets de certaines substances avérées ou supposées polluantes.
Si l'aquariophilie peut être pratiquée dans le but de préserver des espèces menacées, elle est souvent accusée de participer à la destruction de certains milieux. Si les poissons d'eau douce sont souvent élevés en aquaculture, les poissons de mer sont souvent capturés dans leur milieu naturel. Les mauvaises conditions de capture et de transport entraînent une mortalité élevée, et le nombre de poissons capturés dans leur milieu est largement supérieur au nombre introduits dans les aquariums.
En 2000 l'élevage d'espèces non alimentaires, destinées au marché de l'aquariophilie est un secteur très prometteur. La valeur de la vente mondiale de poissons vivants destinés aux aquariums est estimée à 900 mio de dollars US en vente en gros, et 3 milliars de dollars dans le commerce de détail. Vu le fort potentiel économique pour l'emploi rural, l'aquaculture et le commerce de poissons d'aquarium est de plus en plus soutenu par les gouvernements.
Les poissons ayant une haute valeur ajoutée sur le marché de l'aquariophilie sont petits, colorés et ont des mouvements gracieux. Des poissons peu colorés peuvent également devenir populaires en raison de leur morphologie particulière, de leur locomotion peu ordinaire ou de leur rareté.
Dans certaines animaleries, les ventes pour le marché de l'aquariophilie représentent 50% du chiffre d'affaires. Ceci est du non seulement à la vente de poissons mais aussi de nombreux objets de décoration tels que des miniatures de statues grecques, de ruines, d'épaves, de coffres à trésor, de plongeurs ou de monstres marins.
Les mers et les océans représentent 97% du volume total des eaux du globe. On y trouve 75% des espèces animales et végétales. Sur les 30 000 espèces de poissons du monde, seules quelques centaines sont utilisées en aquariophilie.
La majorité des espèces marines destinées à l'aquariophilie sont pêchées dans des pays en voie de développement, et vendues dans des pays développés - europe, amérique du nord et australie. Le volume de vente des ces produits à haute valeur ajoutée avoisine les 10 milliards de dollars US, et sont source de nombreux emplois dans les pays producteurs. Des mauvaises techniques de pêche sont à l'origine de la dégradation des milieux d'origine des poissons qui posent alors des problèmes de subsistance pour les populations locales des pays exportateurs. le Marine Aquarium Council est un organisme régulateur de ce marché, composé de membres d'associations d'aquariophilie, d'associations de protection de la nature, de membre de l'autorité et de scientifiques. Cet organisme labellise des produits obtenus par des procédés de pêche non destructive, sans impact sur la biodiversité des milieux marins.
La pratique de l'aquariophilie est à l'origine de l'introduction - volontaire ou accidentelle - d'espèces dans la nature. Des poissons tropicaux ont été signalés dans les rivières tempérées d'europe et la jacinthe d'eau, une plante aquatique invasive originaire d'amérique du sud, a été introduite en europe comme plante décorative pour les étangs.
Il existe 150 espèces animales et végétales introduites par le biais de l'aquariophilie. Au États-Unis 37 des 59 espèces de poissons introduits sont dus à l'aquariophilie. En Californie 27 des 867 espèces de poissons d'ornement disponibles dans le commerce ont les capacités physiologiques de survivre dans la baie de San Francisco, et 6 espèces y sont déja établies.
Brut
[modifier | modifier le code]Un aquarium récifal est le reflet presque exact de l'écosystème d'un récif de corail. Son entretien et sa maintenance nécessitent beaucoup de doigté, de savoir-faire et de matériel, raison pour laquelle il est généralement réservé aux aquariophiles chevronnés.
Sur le marché de l'aquariophilie, les exportateurs du Sud-Est asiatique pratiquent une conccurence acharnée. Ils pratiquent l'élevage intensif d'espèces nourries aux hormones, dans des bassins traités aux antibiotiques. L'importation d'espèces en Europe pourrait être limitée dans le cadre d'une harmonisation des lois de protection de la nature. L'Allemagne a déjà entrepris d'interdire l'importation de certains poissons devenus rares sur leur milieu naturel, ce qui a favorisé des ventes sauvages, non contrôlées, d'espèces fragiles à des prix surfaits.
La difficulté majeure de l'aquariophilie d'eau de mer est de fabriquer l'eau de mer: la constance dans le dosage des ingrédients permet d'assurer la constance des conditions du milieu. [67]
L'électrification, le progrès technologique et l'évolution des connaissances en chimie de l'eau a facilité la manipulation des aquariums et démocratisé la pratique de l'aquariophilie et permis de re-créer un milieu de vie sain à peu de frais.
Dans un aquarium, l'eau, les poissons, les plantes, le filtre, l'éclairage et les bactéries sont étroitement liés, et l'équilibre entre ces différents éléments nécessite un certain nombre de connaissances telles que:
- L'influence de la taille de l'aquarium sur la facilité d'entretien ainsi que sur la quantité et la taille des poissons qu'il est possible d'y mettre. Quantité de poissons qui dépends non seulement de leur taille, mais également de leur caractère (territorial, agressifs, grégaires...)
- L'équilibre écologique dépends de la constance des caractéristiques physico-chimiques de l'eau. Ce qui nécessite la connaissance des caractéristiques en question: le pH, la dureté totale, la teneur en nitrites et en nitrates, et l'impact des poissons, des plantes, des bactéries et de la nourriture sur les caractéristiques de l'eau.
- L'alimentation, la quantité de nourriture, le fréquence des repas, le régime alimentaire et les préparations pour les animaux aquatiques, ainsi que les dangers de la suralimentation.
- La reproduction, comment cela se passe pour les poissons ovipares ainsi que les poissons ovovivipares. Quels soins apporter aux jeunes poissons, la croissance des poissons et les risques - notamment de surpopulation.
- les poissons. chaque espèce de poisson a ses propres besoins en terme de caractéristiques de l'eau, en fonction de son milieu naturel, les poisson de mer ont tous les mêmes besoins[3]. Le comportement, propre à chaque espèce influence la facilité de cohabitation avec les autres poissons présents dans l'aquarium. Certaines espèces vivent près de la surface, d'autres au milieu ou au fond de l'eau.
Un aquarium transporte dans une autre région du globe, et fait rêver. Dans un aquarium régional les poissons sont dans un environment identique à leur milieu naturel et adoptent spontanément les mêmes comportements que dans la nature.
Un aquarium demande peu de place, et il permet à des gens qui n'ont pas la place nécessaire pour un chat ou chien de posséder des animaux de compagnie. Les poissons d'aquarium sont des animaux silencieux, ils n'endommagent pas l'habitat et ne dérangent pas les visiteurs; ils vivent dans un milieu différent de leur propriétaire, cependant ils réagissent à ce qui se passe à proximité de l'aquarium, en particulier quand il est l'heure de manger. Pour différentes raisons, les problèmes de santé des poissons sont pris en charge par le propriétaire plutôt que par un vétérinaire.
Les plusieurs milliers d'espèces de poissons d'eau douce tropicale font que les passionés d'aquariophilie - qui consacrent tout leur temps à leur passion - ont très peu de risque de s'ennuyer.
Les poissons sont souvent les sujets phares d'un aquarium. Une erreur fréquente des aquariophiles débutants est de choisir les poissons immédiatement au magasin, en fonction de leur apparence et leur taille. Parfois cela se passe bien, ou alors le résultat est un désastre, et l'aquariophile abandonne, découragé: surpopulation, bagarres, poissons mangés par d'autres, ou destruction des plantes. L'approche de l'aquariophile confirmé est de choisir à l'avance les espèces qui l'intéresse, de se renseigner concernant leur taille, leur comportement, et les soins à apporter, puis de retenir uniquement un groupe d'espèces compatibles et de mettre en place un milieu adapté à leur besoins.
Les facteurs de choix pour mettre un poisson dans aquarium déja peuplé sont qu'il n'est ni trop grand, ni trop petit, ni carnivore (mange les autres poissons de l'aquarium), ni trop agité, ni trop calme, ni qu'il mange les plantes ou creuse des trous, et qu'il requiert une eau dont les caractéristiques physico-chimiques correspondent à celle de l'aquarium. Des poissons provenant du même biotope, ou des poissons de la même espèce ne sont pas toujours appropriés - en particulier des mâles.
La région des caraïbes s'intéresse à l'aquaculture pour le marché de l'aquariophilie.
Les plantes aquatiques sont utilisées autant pour leur fonction décorative que pour leur apports bénéfiques pour les animaux. Les plantes se nourissent des nitrates toxiques pour les poissons, et une flore abondante contribue à l'équilibre de l'écosystème. Les plantes permettent en plus aux poissons de se cacher et de pondre des oeufs.
Le recours à l'eau douce est recommandé pour les débutants parce que meilleur marché et plus facile. Les poissons sont meilleurs marché, demandent moins d'équipements. Des espèces d'eau douce tels que le guppy, le platy ou le Xipho sont colorés, peu exigeants et tolérants face aux erreurs, ils sont de plus faciles à trouver dans le commerce et se reproduisent facilement.
Les poissons tropicaux ont été importés au 19ème siècle, et les transporteurs ont recherché à leur re-créer un environnement identique à leur milieu naturel, dans lequel ils pourraient vivre. Le chauffage de l'eau était rudimentaire, les filtres étaient bruyants, les produits de traitement de l'eau n'existaient pas. Il n'y avait pas d'élevage, les poissons étaient pêchés dans leur milieu naturel. La mortalité était élevée, et l'aquariophilie était un loisir de riche.
La technologique des aquariums s'est améliorée, et la reproduction de poissons en aquaculture a permi d'obtenir des espèces d'aquariophilie qui soient moins couteuses, et moins porteuses de parasites, ce qui a rendu ce loisir à la portée de tout un chacun.
Il existe un grand nombre de clubs et d'associations d'aquariophilie. Les membres se rencontrent pour s'échanger des idées, des expériences, des techniques, du matériel et des poissons. Les Magazines d'aquariophilie comportent des articles sur les techniques de maintenance, de nourriture, de reproduction, de lutte contre les maladies. Ils comportent également des avis d'usagers concernant certains produits du commerce.
Poissons
[modifier | modifier le code]95% des poissons d'aquarium vendus dans le commerce sont des espèces d'eau douce. Le prix d'achat moyen d'un poisson d'aquarium d'eau douce est entre 3 et 10 dollars, et celui d'un poisson d'aquarium marin est entre 20 et 50 dollars. L'aquariophile paye en moyenne 230 dollars par année pour l'achat de poissons et 80% des propriétaires de poissons possèdent également d'autres animaux de compagnie.
500 variétés de poissons d'eau douce tropicale, et 10 variétés de poissons rouge sont disponibles couramment dans le commerce. Parmi les espèces de poissons les plus souvent utilisées en aquariophilie il y a le guppy, le platy, le xipho, le néon bleu, le néon cardinalis, le scalaire, le discus, l'oscar, le combattant, le gourami, le macropode, le danio, le barbus, le killie, le corydoras, la loche, le poisson rouge et le koï. 25% des poissons d'eau douce tropicale vendus sont des guppy et des néon bleu.
[81] La mauvaise qualité chronique de l'eau, la présence de toxines, un pH et une température inadaptée stresse les poissons et les empoisonne, ce qui provoque des carences et un affaiblissement des défenses naturelles de l'animal. La surveillance de la qualité de l'eau et des mesures préventives sont vitales pour les poissons: La majorité des problèmes de santé des poissons ont pour origine des conditions de vie inadaptées à leurs besoins, y compris quand il s'agit d'attaques par des agents pathogènes (virus, bactéries, protozoaires, champignons). Le poisson stressé perd de l'appétit, maigris, se cache, devient nerveux et pâle.
L'ammoniaque, les nitrites et les nitrates sont des toxines produites naturellement par la décomposition des déchets présents dans l'aquarium, leur accumulation peut atteindre des niveaux nocifs pour les poissons. La suralimentation des poissons, la surpopulation de l'aquarium, et la présence de déchets non nettoyés tels que feuilles mortes accélèrent le phénomène; le remplacement régulier d'une partie de l'eau et le nettoyage de déchets est une mesure préventive effectuée par l'aquariophile pour éviter une intoxication. Le fait de placer des poissons immédiatement dans un aquarium neuf et non préparé est aussi une cause fréquente d'intoxications à l'ammoniaque. Les dérivés de chlore, les métaux lourds, les détergents, les savons, la colle, les insecticides, et la fumée de cigarette sont nocifs aux poissons.
Le choc osmotique est une lésion provoquée une variation trop rapide de la teneur en minéraux dans l'eau, et peut provoquer la mort du poisson dans les 2 à 6 jours. C'est une cause fréquente de mort des poissons nouvellement achetés et plongés brutalement dans les aquariums par des propriétaires néophytes ou indélicats.
[82] Les poissons sont des animaux de compagnie populaires. Il y a en France 26 millions de poissons de compagnie et 8 millions de chats. 10% des ménages possèdent au moins un poisson d'aquarium, et 25% des ménages possèdent au moins un chat. La principale raison de l'acquision d'un poisson est d'ordre esthétique.
Loisir, commerce et sciences
[modifier | modifier le code]Un des livres de référence concernant les aquariums est le livre de Hans Frey datant de 1950, qui décrit l'aquariophilie comme « une science plaisante et un hobby sérieux ».
Les reconstitutions d'écosystèmes tels que pratiqués en aquariophilie sont une amélioration des dioramas pratiqués par les musées de zoologie dans un but esthétique et pédagogique: ils sont une représentation vivante d'un écosystème dans toute sa complexité, avec ses animaux, ses plantes et ses minéraux.
L'aquarium est un instrument de sciences naturelles: Il permet d'observer le comportement d'organismes dans des conditions quasi-identiques à celles de leur milieu naturel, un milieu qui sinon serait difficile d'accès pour les étudiants.
[87] Les cichlidés sont une famille de poissons évolués apparue tard dans l'évolution animale; ils sont présents en amérique centrale et sud, en afrique et en inde. Ils sont appréciés autant par les aquariophiles que par les ichtyologues, qui observent leur répartition géographique, leurs relations et leur comportement.
les aquariophiles, les pisciculteurs et les scientifiques travaillent avec les mêmes organismes, leurs motivations sont cependant différentes. Les scientifiques travaillent sur des investigations de biologie et d'écologie, dans le but d'améliorer les capacités des piscicultures et apporter la connaissance des milieux aquatiques nécessaires aux aquariums publics. Les aquariophiles ont le privilège d'être à la fois scientifiques et entrepreneurs et de propager la satisfaction de mettre en scène des milieux aquatiques d'une rare beauté. Alors que les scientifiques et les aquariophiles manipulent des petits aquariums, les besoins de rentabilité de la pisciculture nécessitent des grandes installations pour de la production de masse d'espèces pour lesquelles il existe une demande commerciale. Il arrive qu'un aquariophile amateur devient éleveur commercial et prends alors les mêmes motivations que les pisciculteurs; il existe également des mi-hobbyistes mi-scientifiques indépendants qui ont les connaissances et l'expérience, et qui mèlent leur vocation scientifique auvec le loisir de maintenir et d'élever des espèces aquatiques.
D'après un sondage effectué en 2003 auprès de 324 pratiquants de l'aquariophilie marine, 80% cultivent et élèvent eux-mêmes les organismes - principalement du corail, et nombreux sont ceux qui donnent ou vendent l'excès d'élevage dans le commerce ou directement à d'autres hobbyistes.
La gare de Renens a ouvert en 1856, suite à la mise en service de la ligne de train Lausanne-Bussigny-Yverdon. La gare de triage de Lausanne est construite sur le site de Renens en 1876, parce que le site escarpé de la gare de Lausanne ne comporte pas une surface plate suffisamment grande pour une telle installation.
Depuis la construction de la gare au 19ème siècle, la région de l'ouest Lausannois a radicalement changé: En l'an 1900 les communes de Renens, Crissier, Écublens et Chavannes-près-Renens totalisent 3 200 habitants. En 1960 la population est alors de 18 000 habitants. En l'an 2000 celle-ci est de 39 000 habitants.
L'université de Lausanne, et l'école polytechnique fédérale de Lausanne se sont implantés dans les années 1970. Ainsi que des centres commerciaux, des entreprises du secteur tertiaire et des logements. En l'an 2000 la région est en plein développement alors que le centre ville de Lausanne perds des habitants et des emplois. Les 4 communes voisines de la gare ont - chacune de leur coté - tenté de prendre des mesures pour s'adapter à l'évolution du secteur. Celui-ci n'a cependant jamais fait l'objet d'une étude globale et intercommunale
Dans les années 2000 le service régional d'aménagement du territoire est chargé d'étudier la banlieue ouest de Lausanne, et de valoriser la gare de Renens et ses abords. Le professeur architecte et urbaniste Pierre Federsen est chargé d'établir un schéma directeur portant sur le centre de Renens et sa gare. [94]
Situation
[modifier | modifier le code]La gare est le principal pôle d'échange des transports publics urbains ainsi que régionaux et nationaux de l'agglomération ouest de Lausanne; une région qui compte 50 000 habitants, et de nombreux commerces ainsi que des hautes écoles (EPFL et université) qui acceuillent 18 000 étudiants.[95]
En 2001 120 trains RER, 46 trains interregio, 100 rames de métro et 360 bus passent quotidiennement par la gare de Renens. [96] En 1998 un collectif composé d'habitants, d'autorités et de personalités locales examine la gare de Renens, et effectue une visite à pied des alentours. Les usagers de la gare de Renens la jugent « peu attrayante, vieillote et vétuste », le passage sous-voie est jugé « triste et peu attrayant ». Les voyageurs qui passent du train au métro doivent se rendre à l'unique passage sous-voie, puis rebrousser chemin jusqu'à la station de métro, d'ou un détour de plus de 200 mètres. En 2001 le terminal de la gare se trouve au Sud des voies, alors que le centre ville de Renens se trouve au Nord. Les autorités locales des 4 communes proches de la gare se réunissent pour mettre en oeuvre diverses améliorations.
Le terrain de la gare se trouve aux frontières des communes de Renens, Crissier, Écublens et Chavannes-près-Renens, et dessert une des plus importantes zones urbaine de Suisse romande. La gare comporte trois quais de train, exploités par les chemins de fer fédéraux suisses (CFF) pour les liaisons interregio et le réseau express régional vaudois (REV), ainsi que le terminus de la ligne M1 du métro de Lausanne, et deux arrêts de bus exploités par les transports publics de la région lausannoise (TL). En 2008 23 000 personnes ont transité par la gare chaque jour, 35% des voyageurs transitent entre les quais de train et l'arrêt de métro et 20% utilisent la gare comme passage piéton. [97]
La gare de Renens comporte un secteur pour les marchandises, avec une gare de triage de 12 hectares utilisée pour composer des trains de marchandises et transborder les marchandises vers la route. [98]
La région de l'ouest Lausannois, où se trouve la gare, a connu un évolution très rapide depuis 1970. En 2010, suite à l'accroissement de la population et la cadence des trains la gare est « largement sous-dimensionnée », et divers travaux de rénovation et d'amélioration sont prévus jusqu'en 2025.[99] [100]
La gare se trouve entre Lausanne et Genève, sur la transversale ferroviaire est-ouest. En 2010 la ligne à 3 voies qui relie Renens à Lausanne est un goulet d'étranglement et les chemins de fer prévoient de construire une quatrième voie d'ici 2018. Il est prévu de construire un saut-de-mouton; une gare intermédiaire entre Lausanne et Renens doit ouvrir en 2012 et une ligne de tramway en 2017. Toutes ces améliorations sont inscrites dans le schéma directeur du district de l'Ouest lausannois. [101] [102]
Une augmentation significative du traffic sur le RER Vaudois est attendue d'ici 2020, et la gare pourrait devenir, après les gares de Lausanne et de Genève, une des plus fréquentées de la Suisse romande.[103]
Brut
[modifier | modifier le code][104] La gare de Renens est située dans l'agglomération de Lausanne, et dessert une des plus importantes zones urbaines de l'ouest de la Suisse. Le terrain de la gare de trouve à la frontière des communes de Renens, Crissier, Écublens et Chavannes-près-Renens. 4 communes urbaines qui totalisent près de 45'000 habitants. Une augmentation significative du traffic voyageur est en vue, et des travaux d'améliorations sont en cours jusqu'à 2025.
La gare comporte trois quais de train exploités par les chemins de fer fédéraux suisses (CFF), et le RER Vaudois, ainsi d'un arrêt du métro M1 de Lausanne et deux arrêts de bus exploités par les transports publics de la région lausannoise (TL). 35% des voyageurs transitent entre les quais de train et la ligne de métro.
En 2008 19'000 voyageurs par jour transitent par la gare de Renens. Une affluence qui devrait passer à 27'000 voyageurs d'ici 2020. La gare est aujourd'hui sous-dimensionnée, et ne réponds plus aux normes.
La gare est située sur le tronçon à 3 voies qui relie Lausanne avec Genève. Divers travaux sont en cours sur ce tronçon, dont une 4ème voie, et une nouvelle gare à proximité de Renens d'ici 2012, un saut-de-mouton, ainsi qu'une ligne de tramway, attendue pour 2017. Tout ces changements sont inscrits dans le schéma directeur de l'ouest de Lausanne.
Le Poste d'aiguillage de Renens devrait être modernisé, et relié avec celui de Lausanne.
L'axe ferroviaire est-ouest de la Suisse passe par la gare de Renens. La ligne à 3 voies est aujourd'hui insuffisante et fait effet d'un goulot d'étranglement. Une quatrième voie entre Renens et Lausanne est prévue d'ici 2018.
Selon les CFF, « suite à l'augmentation de la cadence des trains et l'accroissement de la population, les installations de la gare de Renens sont largement sous-dimensionnées et ne répondent plus aux normes en vigueur ».
une augmentation de 70% du traffic voyageur d'ici 2020 est prévue sur le RER Vaudois entre les gares de Renens et de Lausanne. La gare de Renens est la deuxième gare la plus fréquentée de ce réseau.
[107] La gare de Renens devrait être en 2020 la troisième gare la plus fréquentée de la Suisse romande, après les gares de Genève et de Lausanne.
En 2008 23'600 voyageurs transitent par la gare de Renens, parmis ceux-ci, 19'000 prennent le train ou le métro et le reste utilisent la gare comme passage piéton. De 19'000, le nombre de voyageurs devrait passer à 27'000 d'ici 2020.
Les améliorations prévues aux installations sont l'ajout d'une passerelle d'accès aux quais, en plus de l'actuel passage souterrain, ainsi que des améliorations en vue de permettre l'accès aux quais en fauteuil roulant, ce que les installations de 2010 ne permettent pas.
La gare est située à ouest de l'agglomération de Lausanne, cette zone a connu un très fort développement ces dernières décennies compte maintenant 50'000 habitants, ainsi que 18'000 étudiants dans les hautes écoles (EPFL et université), et de nombreux commerces.
Outre les fichiers et les répertoires, les systèmes d'exploitation Unix permettent d'enregistrer des liens et des fichiers spéciaux.
Un lien permet de partager des fichiers entre plusieurs utilisateurs, ils permettent d'obtenir qu'un seul contenu soit disponible sous plusieurs noms différents situés dans des répertoires différents, sans avoir à effectuer des copies. Les changements effectués sur le contenu par un des utilisateurs sont immédiatement visible par les autres. Il existe deux types de liens: le lien matériel (hard link) et le lien symbolique (symlink).
- le lien matériel est une deuxième étiquette pour un contenu. L'étiquette comprends le nom, l'auteur, et la date de la dernière modification.
- le lien symbolique contient le nom du répertoire dans lequel se trouve le fichier en question et fonctionne de la même manière que les raccourcis des systèmes d'exploitation Windows.
Les fichiers spéciaux sont une fonctionalité propre aux systèmes d'exploitation Unix uniquement. Un fichier spécial représente une pièce de matériel tel qu'une imprimante ou un lecteur de CD-ROM, qu'il est alors possible de manipuler de la même manière qu'un fichier ordinaire: de lire et d'écrire sur le périphérique en utilisant les mêmes commandes que pour lire et écrire un fichier ordinaire.
En informatique un fichier est une collection d'informations numérisées réunies sous un même nom, enregistrée sur un support de stockage tel qu'un disque dur, un CD-ROM, ou une bande magnétique, et manipulée comme une unité.[112] [113]
En vue de faciliter leur localisation, les fichiers sont classés dans des systèmes de fichier: organisations hiérarchiques de catégories appelées par analogie répertoires ou dossiers, ou chaque catégorie peut contenir d'autres catégories.[114]
Le nom du fichier sert à décrire le contenu. Ce nom comporte souvent un suffixe - l´extension, qui renseigne sur la nature des informations et le logiciel utilisé pour les manipuler. Chaque fichier comporte un certain nombre de métadonnées - des informations concernant les informations: la longueur du fichier, son auteur, les personnes autorisées à le manipuler, ainsi que la date de la dernière modification.[115]
L'essence du fichier sont les informations qu'il contient. Le format de fichier est la convention selon laquelle les informations ainsi que les métadonnées sont numérisées et emballées dans le fichier. Le format du fichier est propriétaire lorsque la convention n'est connue que de son auteur et n'a jamais été publiée. Selon la nature et le format du contenu, les fichiers peuvent être qualifiés d'exécutables, de compressés, de textes, de documents, d'images, d'audio ou de vidéos.[116]
Avant l'arrivée des ordinateurs, les fichiers étaient des piles de fiches réunies dans des classeurs. L'utilisation des ordinateurs et du stockage magnétique a facilité et accéléré la manipulation de grands fichiers tels que ceux utilisés dans le commerce et l'administration publique[117]. La manipulation des fichiers est un des services classiques offerts par les systèmes d'exploitation[118].
Il y a divers catégories de fichiers, parmi lesquels les fichiers exécutables, les fichiers de configuration et les fichiers de données. Un fichier est classifié selon la nature de son contenu, le logiciel utilisé pour manipuler le contenu, et l'usage qu'en fait l'ordinateur.
Le nom du fichier sert à décrire son contenu, et l'extension est un suffixe rajouté au nom et destiné à renseigner sur le format du fichier et le logiciel à utiliser pour le manipuler. Le format de fichier est la convention selon laquelle les informations sont transformées en suite de bits et selon laquelle les suites de bits sont disposées dans le fichier.
Un répertoire - ou un dossier - est un emplacement de stockage d'un fichier. Le nom répertoire vient du fait que tout les supports de stockage comportent un catalogue des fichiers enregistrés sur le support (anglais directory). Chaque fichier peut être enregistré n'importe où sur le système de fichiers, et chaque logiciel et chaque système d'exploitation propose des emplacements conventionnels pour le stockage de ses fichiers. [119]
Le format de fichier est une convention qui décrit comment le contenu - qui est l'essence du fichier - ainsi que les métadonnées sont enregistrées. Certains formats sont propriétaire, c'est-à-dire que la convention n'est connue que de son auteur et n'a jamais été publiée. Le format de fichier sert d'emballage dans lequel sera mis le contenu ainsi que les métadonnées. Le contenu peut être des textes, des images, de l'audio ou de la vidéo; le contenu peut être organisé de manière hiérarchique à l'intérieur du fichier. [120]
Un fichier est une collections de données connexes enregistrées comme une unité et portant un nom. Un système de fichier est une structure hiérarchique contenant des fichiers. Un système de fichier facilite le classement et la localisation des fichiers enregistrés sur un support magnétique. Des structures de données et des logiciels contrôlent l'accès aux fichiers et leur répartition sur le support magnétique et offrent les possibilités de créer, de lire, de modifier ou de supprimer les fichiers. En plus des fichiers, les supports magnétiques sont également utilisées pour enregistrer un certain nombre de métadonnées - des informations concernant les fichiers et le support: longueur du fichier, auteur, droit d'accès, date de la dernière modification, ainsi que la liste des emplacements non utilisés du support.
Le support de stockage est divisé en blocs de taille fixe. La taille d'un fichier est typiquement plus que la taille d'un bloc et le fichier est enregistré sur plusieurs blocs. Le fichier est dit fragmenté lorsqu'il est enregistré sur plusieurs blocs non-contigus. [121]
Un fichier est une collection d'informations réunies sous un même nom. Un fichier peut être un programme, un texte, un document, un fichier son ou vidéo. Chacun de ces fichiers se distingue par la nature des informations qu'il contient et la manière dont ces informations sont enregistrées. La manipulation de fichiers est un service offert par les systèmes d'exploitation, qui permet de:
- créer, altérer ou supprimer des fichiers.
- créer, supprimer ou altérer des répertoires.
- enregister des fichiers sur des mémoires secondaires (exemple: disque dur)
- réserver de l'espace sur les supports de stockage pour permettre le stockage des fichiers
- imposer des conventions concernant la manière de nommer les fichiers.
Mise en oeuvre
[modifier | modifier le code]Dans les années 1950 les informations destinées à être manipulées par ordinateur étaient des piles de fiches en carton. Puis ils ont été remplacés par des enregistrements numériques sur bande magnétique, ce qui a permis d'accélérer les calculs et économiser de la place. L'appareil de lecture lisait la bande par blocs d'environ 1000 octets, [123] et la bande comportait un répertoire, sorte de catalogue qui contient le nom de tout les fichiers enregistrés sur la bande. Lors de la lecture, l'appareil déroule la bande, et lit le contenu du fichier dans l'ordre ou il a été enregistré; c'est le procédé du fichier séquentiel.[124]
En 2011, la manipulation de fichiers est un service classique offert par les systèmes d'exploitation. Le système d'exploitation permet de créer, d'altérer ou de supprimer des fichiers ainsi que des répertoires; il réserve la place nécessaire sur le support de stockage pour le contenu et les métadonnées et impose des conventions sur les noms des fichiers et des répertoires. [125] Le support est divisé en blocs de taille fixe. Un logiciel entretien des structures nécessaires pour conserver la hiérarchie des répertoires et répartir les fichiers ainsi que les métadonnées sur le support de stockage.
L'enregistrement du fichier nécessite typiquement plusieurs blocs. le fichier est dit fragmenté si les blocs ne sont pas contigus. Les métadonnées qui accompagnent les fichiers sont: la longueur du fichier, son auteur, les personnes autorisées à le manipuler, la date de la dernière modification, ainsi que la liste des espaces libre sur le support. [126]
Les systèmes d'exploitation Mac OS de Apple, créent deux hiérarchies par support de stockage: une est destinée à enregistrer le contenu du fichier, tandis que l'autre - le resource fork est destinée à contenir les métadonnées. [127]
Le logiciel NTFS de Microsoft enregistre les métadonnées dans les fichiers $MFT et $Secure, les informations standard enregistrées dans ces fichiers sont les dates de création, de modification et de manipulation du fichier.
Divers format de fichiers permettent d'enregistrer des métadonnées à l'intérieur du fichier. C'est le cas du format de documents PDF, des images numériques au format JPEG ainsi que des documents au formats de Microsoft Office. [128]
En lieu et place des cartes, le contenu des fichiers est alors enregistré sur une bande magnétique sous la forme d'une suite de blocs. Chaque bloc peut contenir environ 1000 octets, et une bande magnétique de 800 mètres de long peut contenir environ 30'000 blocs. Les différentes fiches sont lues une par une, dans l'ordre ou elles sont enregistrées sur la bande; ce procédé appelé fichier séquentiel est utilisé pour le décompte des salaires, ainsi que des abonnements téléphone et gaz. [129]
Un répertoire - ou un dossier - est un emplacement de stockage d'un fichier. Le nom répertoire vient du fait que tout les supports de stockage comportent un catalogue des fichiers enregistrés sur le support (anglais directory). Chaque fichier peut être enregistré n'importe où sur le système de fichiers, et chaque logiciel et chaque système d'exploitation propose des emplacements conventionnels pour le stockage de ses fichiers. [130]
Des structures de données et des logiciels contrôlent l'accès aux fichiers et leur répartition sur le support magnétique et offrent les possibilités de créer, de lire, de modifier ou de supprimer les fichiers. En plus des fichiers, les supports magnétiques sont également utilisées pour enregistrer un certain nombre de métadonnées - des informations concernant les fichiers et le support: longueur du fichier, auteur, droit d'accès, date de la dernière modification, ainsi que la liste des emplacements non utilisés du support.
Le support de stockage est divisé en blocs de taille fixe. La taille d'un fichier est typiquement plus que la taille d'un bloc et le fichier est enregistré sur plusieurs blocs. Le fichier est dit fragmenté lorsqu'il est enregistré sur plusieurs blocs non-contigus. [131]
Un fichier est une collection d'informations réunies sous un même nom. Un fichier peut être un programme, un texte, un document, un fichier son ou vidéo. Chacun de ces fichiers se distingue par la nature des informations qu'il contient et la manière dont ces informations sont enregistrées. La manipulation de fichiers est un service offert par les systèmes d'exploitation, qui permet de:
- créer, altérer ou supprimer des fichiers.
- créer, supprimer ou altérer des répertoires.
- enregister des fichiers sur des mémoires secondaires (exemple: disque dur)
- réserver de l'espace sur les supports de stockage pour permettre le stockage des fichiers
- imposer des conventions concernant la manière de nommer les fichiers.
[132] Sur les systèmes d'exploitation Mac OS de Apple, les supports de stockage comportent deux hiérarchies: une est destinée à enregistrer le contenu du fichier, tandis que l'autre - le resource fork est destinée à contenir les métadonnées. [133]
Sur les systèmes de fichier NTFS de Microsoft, les métadonnées sont enregistrées dans les fichiers $MFT et $Secure, les informations standard enregistrées dans ces fichiers sont les dates de création, de modification et de manipulation du fichier.
Divers format de fichiers permettent d'enregistrer des métadonnées à l'intérieur du fichier. C'est le cas du format de documents PDF, des images numériques au format JPEG ainsi que des documents au formats de Microsoft Office. [134]
Contenu
[modifier | modifier le code]Le contenu est l'essence du fichier. Il existe des centaines, voire des milliers de types de fichiers[135], qui se différencient par la nature du contenu, le format, le logiciel utilisé pour manipuler le contenu, et l'usage qu'en fait l'ordinateur. La nature du contenu peut être des textes, des images, de l'audio ou de la vidéo. [136]
Le format de fichier est la convention selon laquelle les informations sont numérisées et organisées dans le fichier et sert d'emballage dans lequel sera mis le contenu ainsi que les métadonnées. [137] L´extension est un suffixe ajouté au nom du fichier, et destiné à renseigner sur le format du fichier et le logiciel à utiliser pour le manipuler.[138] Chaque fichier peut être enregistré n'importe où dans le système de fichiers, et le logiciel qui le manipule propose un emplacement conventionnel de stockage. [139] Certains formats sont dit propriétaire, c'est-à-dire que le format n'est connu que de son auteur et n'a jamais fait l'objet de publications. [140]
Les principales catégories de fichiers sont:
- exécutable: fichiers qui peuvent être exécutés par l'ordinateur - autrement dit des programmes.
- compressés: des fichiers codés selon un procédé qui les rends plus petit que le fichier original non codé. Un programme décompresseur est nécessaire pour effectuer le codage inverse et retrouver ainsi le fichier original. voir compression de données.
- images, audio et vidéo: des fichiers qui contiennent des images et du son sous une forme exploitable par l'ordinateur. De tels fichiers peuvent contenir des photos, des pictogrammes, des graphiques, des chansons, de la musique, des émissions radio, ou des films.
- documents: Il s'agit de documents écrits, destinés à être imprimés et lus. Le fichier contient le texte ainsi que les informations de typographie (polices de caractères, couleurs).
- fichiers texte: les fichiers texte brut contiennent des textes écrits, sans indications de typographie. Il peut s'agir de textes destinés aux humains tels que des modes d'emploi, ou des brouillons; ou alors de textes destinés à l'ordinateur tels que du code source ou des données pour un programme.
Les extensions courantes sur Internet sont:
- textes et documents: .asc, .doc, .htm, .html, .txt, .msg
- images: .gif, .jpg, .bmp, .png, .eps, .tif
- audio: .au, .wav, .ra, .ram
- vidéo: .avi, .mpg, .mov
- exécutables: .exe, .com, .bat
- compressés: .arc, .zip, .z, .arj, .tar, .sit, .gz
Un fichier est une collection de données portant un nom, enregistrée sur un support de stockage tel qu'un disque dur, un CD-ROM, ou une bande magnétique.
Il y a divers catégories de fichiers, parmi lesquels les fichiers exécutables, les fichiers de configuration et les fichiers de données. Un fichier est classifié selon la nature de son contenu, le logiciel utilisé pour manipuler le contenu, et l'usage qu'en fait l'ordinateur.
Le nom du fichier sert à décrire son contenu, et l'extension est un suffixe rajouté au nom et destiné à renseigner sur le format du fichier et le logiciel à utiliser pour le manipuler. Le format de fichier est la convention selon laquelle les informations sont transformées en suite de bits et selon laquelle les suites de bits sont disposées dans le fichier.
Un répertoire - ou un dossier - est un emplacement de stockage d'un fichier. Le nom répertoire vient du fait que tout les supports de stockage comportent un catalogue des fichiers enregistrés sur le support (anglais directory). Chaque fichier peut être enregistré n'importe où sur le système de fichiers, et chaque logiciel et chaque système d'exploitation propose des emplacements conventionnels pour le stockage de ses fichiers. [144]
Le format de fichier est une convention qui décrit comment le contenu - qui est l'essence du fichier - ainsi que les métadonnées sont enregistrées. Certains formats sont propriétaire, c'est-à-dire que la convention n'est connue que de son auteur et n'a jamais été publiée. Le format de fichier sert d'emballage dans lequel sera mis le contenu ainsi que les métadonnées. Le contenu peut être des textes, des images, de l'audio ou de la vidéo; le contenu peut être organisé de manière hiérarchique à l'intérieur du fichier. [145]
d'ordinaire sur Internet, l'extension - le suffixe du nom du fichier - donne une indication sur le type du fichier. Il existe des centaines, voire des milliers de types de fichiers. Les principales catégories de fichiers sont:
- exécutable: fichiers qui peuvent être exécutés - autrement dit des programmes.
- compressés: des fichiers codés selon un procédé qui les rends plus petit que le fichier original non codé. Un programme décompresseur est nécessaire pour effectuer le codage inverse et retrouver ainsi le fichier original.
- images
- audio et vidéo: des fichiers qui contiennent des images et du son sous une forme exploitable par l'ordinateur. De tels fichiers peuvent contenir des chansons, de la musique, des émissions radio, des cours de formation ou des films.
- fichiers texte: les fichiers texte brut contiennent des textes écrits, sans indications de formatage (polices de caractères ou couleurs). Il peut s'agir de textes destinés aux humains tels que des modes d'emploi, des manuscrits, ou des brouillons de livre; ou alors de textes destinés à l'ordinateur tels que le code source ou les données d'un programme.
- documents: Il s'agit de documents écrits, destinés à être imprimés et lus. Le fichier contient le texte ainsi que toutes les indications de formatage (polices de caractères, couleurs, ainsi que d'autres caractéristiques typographiques).
Des extensions courantes sur Internet sont:
- textes et documents: .asc, .doc, .htm, .html, .txt, .msg
- images: .gif, .jpg, .bmp, .png, .eps, .tif
- audio: .au, .wav, .ra, .ram
- vidéo: .avi, .mpg, .mov
- exécutables: .exe, .com, .bat
- compressés: .arc, .zip, .z, .arj, .tar, .sit, .gz
Histoire
[modifier | modifier le code]Le fichage - la collecte de renseignements - est une pratique qui date de l'antiquité. Les premières fiches de ce type étaient des plaquettes gravées par les Babyloniens en 400 av. J. C.
Au début du 20ème siècle, avant l'arrivée des ordinateurs, l'utilisation de fiches documentaires était courante dans de nombreux domaines; Les informations étaient enregistrées sur du papier, sur des documents, des formulaires, des dossiers, rangés dans les tiroirs d'une armoire. C'est en particulier dans l'administration publique, le commerce et l'industrie que se trouvaient les plus grands fichiers. L'enregistrement, puis la mise à jour de toutes les informations contenues sur les documents demandait un effort considérable, prenait beaucoup de temps et a pu être simplifiée par l'utilisation de cartes perforées, dont la lecture pouvait être réalisée par des machines.[149] [150]
En 1950, les fichiers informatique étaient sous la forme d'une pile de cartes perforées qu'un appareil lisait sans intervention humaine, ce qui permettait de les traiter 100 fois plus vite que ci les informations avaient été introduites manuellement. De tels fichiers étaient cependant volumineux, et ont rapidement été remplacées par des dispositifs de stockage magnétique, plus compacts et plus rapides: Une bobine de bande magnétique peut contenir autant d'informations qu'une pile de cartes de 60 mètres de haut, et le contenu de la bande magnétique peut être lu 100 fois plus vite que celui d'un fichier de cartes perforées.
L'organisation des fichiers sur bande magnétique était à l'image des fichiers de carte perforées: Il étaient composés d'enregistrements, chaque enregistrement corresponds à un ensemble d'informations concernant un sujet - par exemple concernant un étudiant. Chaque enregistrement contient un certain nombre de champs qui contiennent des renseignements en rapport avec le sujet: nom, prénom, age, résultats scolaires, etc. Il y avait différents fichiers contenant les différentes informations concernant le même sujet: résultats scolaires, santé, curriculum vitæ, ... [151] Les fiches enregistrées sur bande magnétique sont lues une par une, dans l'ordre ou elles sont enregistrées sur la bande; ce procédé appelé fichier séquentiel était utilisé pour le décompte des salaires, ainsi que des abonnements téléphone et gaz. [152]
Depuis 1980 les systèmes d'exploitation tel que Unix offrent la possibilité de stocker de grande quantités d'informations, de les rechercher, de les classer d'une manière analogue à un bloc-notes dans une hiérarchie ou chaque répertoire peut contenir d'autres répertoires. [154] [155]
En Suisse, la A1 est l'autoroute qui relie Genève à l'Ouest du pays avec Sankt Margrethen à l'Est. Longue de 383 km, c'est une transversale qui relie les principales régions culturelles ainsi que les principaux pôles économiques du pays.
La construction de cette autoroute a débuté en 1960. Les premiers tronçons ont été inaugurés en 1964 et les derniers en 2001. L'autoroute A1 traverse les cantons de Genève, Vaud, Fribourg, Berne, Soleure, Argovie, Zürich, Thurgovie et Saint-Gall. Initialement appellée N1, le nom a été changé en A1 en 1996, en vue de s'aligner aux réglements en vigueur dans les pays voisins.
Le coût de construction est estimé à 9 milliards de franc suisse, entièrement payés par les impôts sur les carburants et la vignette automobile.
Histoire
[modifier | modifier le code]- En 1951 l'Office fédéral des routes publie un projet d'amélioration du réseau routier. Ce projet prévoit la construction d'autoroutes reliant les principales villes du pays que sont Berne, Bâle, Genève et Zürich.
- Le 6 juin 1958, suite à votation populaire, le peuple suisse approuve à 85% l'autorité du gouvernement dans la planification de la construction d'autoroutes.
- Le premier tronçon d'autoroute est mis en service en 1964: Il s'agit du tronçon Lausanne-Genève de l'autoroute A1, réalisé en urgence en perspective de l'exposition nationale suisse de 1964 qui se tenait à Lausanne.
- divers tronçons d'autoroute sont construits dans les années suivantes, et en 1987 celle-ci relie d'un trait Zürich avec Sankt Margrethen.
- toujours en 1987, une initiative populaire est lancée, en vue d'abandonner le projet du tronçon de la A1 qui relie Berne à Lausanne via Morat et Yverdon. Cette initiative est finalement rejetée à 67% suite à une votation populaire en 1992.
- Le 5 avril 2001, le dernier tronçon de l'autoroute A1, qui relie Morat à Yverdon est finalement mis en service, plus de 15 ans après la date prévue.
[list=1115%2C801%2C933%2C1117%2C1458%2C747%2C800%2C1165%2C934%2C802%2C935%2C936%2C803&tx_ttnews[tt_news]=1115&tx_ttnews[backPid]=251&cHash=1805537b0a]
L'équilibrage de charge (anglais load balancing) est la technique de distribuer le trafic réseau entre différents serveurs à l'aide d'un appareil réseau. L'appareil intercepte le trafic destiné à un service, et le dévie vers un serveur à l'insu de l'utilisateur. Il peut y avoir des dizaines voire des centaines de serveurs derrière un service. [157]
Un calculateur parallèle est un ensemble de dispositifs de calcul qui communiquent et coopérent dans le but de résoudre efficacement un grand problème. Selon leur construction, les calculateurs parallèles vont exécuter simultanément le même calcul sur plusieurs données, ou bien exécuter en même temps plusieurs calculs sur plusieurs données. Ils peuvent être équipée d'une mémoire partagée - la même mémoire est utilisée par toutes les unités de calcul, ou au contraire une mémoire distribuée - une mémoire différente est associée à chaque unité de calcul.
Un procédé peu couteux est de construire un calculateur parallèle à l'aide d'une batterie d'unités de calcul, ou chaque unité comporte un processeur, une mémoire et une connexion au réseau - des composants disponibles dans le commerce. Le nombre d'unités est choisi en fonction de la grandeur du problème, et peut être modifié par la suite, de plus il n'est pas nécessaire que les unités de calcul soient toutes identiques.
Un programme parallèle est composé d'une suite de processus, ou chaque processus exécute une ou plusieurs tâches. Le processus est une entité logicielle qui exécute les tâches assignées à un processeur. La création d'un programme parallèle implique la décomposition de l'ensemble du calcul en petites tâches et l'affectation des tâches aux processus. Le nombre de processus n'est pas forcément égal au nombre de processeurs, et chaque processeur peut exécuter des tâches d'un, de plusieurs processus ou rien.
La décomposition est optimale lorsque le travail est réparti de manière équilibrée entre les processeurs, et que les communications entre les différents processeurs sont réduites au minimum. Le but visé par les algorithmes de répartition de charge est d'obtenir une décomposition optimale. En plus de la répartition des tâches, réalisée avant l'exécution des tâches, il existe également des algorithmes visant à déplacer des tâches en cours d'exécution vers un processeur moins occupé.
Un algorithme de répartition statique distribue les tâches sur la base de la quantité de travail à priori de chaque tâche. Ce type d'algorithme donne de bons résultats lorsque la durée d'exécution de chaque tâche est prévisible. Un algorithme dynamique vise à obtenir de meilleurs résultats en effectuant continuellement des mesures de la quantité de travail de chaque processeur. Ces mesures peuvent cependant entraîner un ralentissement de l'exécution des tâches.[158]
La popularisation d'Internet dans les années 1990 a permis pour la première fois de mettre des services à disposition de très nombreux utilisateurs. De tels services doivent cependant avoir la scalabilité nécessaire pour supporter de manière sûre, fiable et rapide des demandes provenant de plusieurs millions d'utilisateurs. L'architecture de tels services est une groupe de machines en réseau qui travaillent collectivement à répondre aux demandes des clients. Un dispositif d'équilibrage de charge (anglais load balancing) distribue le travail entre les différentes machines. Un tel ensemble est appelé serveur web distribué ou cluster.
Selon une étude parue en 2003, le moteur de recherche Google utilise 6000 micro-ordinateurs et peut répondre à 1000 demandes de recherche par seconde. De la même manière, tout les services Internet populaires utilisent à l'insu du client une batterie d'ordinateurs, et la technique de l'équilibrage de charge.
Cette technique était utilisée à l'origine sur les ordinateurs parallèles, ou les tâches de calcul sont réparties entre les différents processeurs, en évitant qu'un processeur soit au repos et en diminuant au maximum les communications entre les processeurs; le but final était alors de diminuer la durée totale du calcul. Pour un serveur Internet les demandes de services sont réparties, dans le but final de diminuer le temps de réponse, augmenter la scalabilité et la disponibilité du serveur. [159]
Une technique courante pour obtenir des systèmes informatiques très puissants est d'utiliser une collection d'ordinateurs similaires - souvent appelé ferme de serveurs (anglais server farm) ou cluster, et répartir le travail entre les ordinateurs. Dans la construction typique de ce type d'assemblage, il y a plusieurs clients qui envoient des demandes de service (tels que la lecture d'une page web). Au lieu d'être envoyées directement à un serveur, ces demandes sont envoyées à un routeur - un appareil réseau, qui distribue les demandes à tour de rôle à chaque serveur du groupe. Des priorités peuvent être attribuées en vue de rediriger les demandes de préférence aux serveurs qui ont peu de travail.
Dans un dispositif dynamique, le routeur répartit équitablement les demandes entre les différents serveurs, puis un dispositif mesure le taux d'activité de chaque serveur, et modifie les priorités en vue de diriger plus de demandes vers le serveur dont le taux d'activité est le plus bas. [160]
La répartition de charge permet de distribuer des applications à travers un réseau. Bien que principalement utilisé pour les serveurs web, cette technique permet de distribuer n'importe quel service entre différents ordinateurs et emplacements géographiques. La visite d'un site web provoque l'émission de requêtes HTTP. Chaque requête contient le nom du serveur à qui elle est destinée, qui devra alors la traiter. Le travail du serveur peut être allégé en envoyant les requêtes suivantes à d'autres serveurs.
Une technique consiste à faire correspondre le nom du serveur avec plusieurs ordinateurs en modifiant continuellement les tables de correspondance du service DNS.
Les machines utilisées pour la répartition doivent avoir accès au même lot de fichiers, ceci peut être réalisé à l'aide d'un système de fichier distribué ou à l'aide d'un réseau de stockage (agr. SAN). Les serveurs ne vérifient pas individuellement les sessions parce que, du fait de la répartition, plusieurs serveurs peuvent être impliqués lors d'une même session. La répartition de charge peut être réalisée par des routeurs, des switch, des logiciels applicatifs ou des systèmes d'exploitation. [161]
Dans une ferme de serveurs (anglais server cluster) un groupe de serveurs fonctionnent comme un dispositif informatique unique. Les machines sont reliées entre elles et exécutent un logiciel qui contrôle leur activité et leur disponibilité, dans le but d'exploiter leur disponibilité par la répartition de charge. Cette technique consiste à répartir le travail en vue d'éviter la saturation d'une des machines de la ferme. La répartition de charge est mise en oeuvre à l'aide d'un logiciel qui récupère des informations relative à la disponibilité de chaque machine; puis ces informations sont envoyées à un serveur maître, qui distribue les tâches entre les machines de la ferme.
Les institutions favorisent les fermes de serveurs, en particulier pour les applications Internet, parce que celles-ci permettent d'assurer une haute disponibilité de l'application, et que la croissance peut être prise en charge par l'adaptation du matériel dans une très large mesure. [162]
La distribution par le DNS ne tient cependant pas compte de l'état des serveurs, en particulier de la disponibilité et des pannes éventuelles. Les demandes peuvent être envoyées à des serveurs qui sont déja 100% occupés, ou à des serveurs en panne. L'utilisation d'un appareil de répartition permet de résoudre ces deux problèmes. L'appareil répartit les demandes en les distribuant uniquement aux serveurs disponibles. Le destinataire des demandes peut également être imposé: dans un site de e-commerce, lorsqu'une demande sécurisée est faite par un acheteur - par exemple l'achat d'un produit - les demandes suivantes provenant de cet acheteur seront toutes envoyées au même serveur.
Dans ce type d'installation, le répartiteur simule la présence d'un serveur. Les clients communiquent avec le répartiteur comme si il s'agissait d'un serveur. Celui-ci répartit les demandes provenant des clients, les transmets aux différents serveurs. Lorsqu'un serveur réponds à une demande, celle-ci est transmise au répartiteur; puis le répartiteur la transmet la réponse au client en modifiant l'adresse IP de l'expéditeur pour faire comme si cette réponse provient du répartiteur.
Outre les serveurs, la répartition de charge peut être utilisée avec les points d'accès VPN, les proxy ou les pare-feu. [166]
Bug (informatique) - dysfonctionnements rares
[modifier | modifier le code]Plus le code est complexe, plus il est difficile de localiser un bug. Des bugs qui dépendent d'une combinaison de conditions imprévues et improbables sont particulièrement difficiles à localiser. Dans le folklore hacker il existe des catégories de bugs bizarres dont les noms comiques sont dérivés de ceux d'éminents scientifiques en physique quantite et en philosophie. [169]
- Heisenbug : (du principe d'incertitude de Heisenberg) un bug qui disparait ou se modifie quand on essaye de l'isoler.
- Mandelbug : (des ensembles de Mandelbrot) un bug dont les causes sont si obscures et complexes que le résultat est un comportent chaotique et non déterministe.
- Schrödinbug : ( du chat de Schrödinger) un bug qui ne se manifeste pas jusqu'à ce que quelqu'un lit le code source, utilise le programme d'une façon pas usuelle et constate qu'il n'aurait jamais dû fonctionner.
- Bohr bug : Un bug répétable, qui se reproduit lorsqu'un ensemble - même inconnu - de conditions sont remplies.
L'exécution pas-à-pas d'un logiciel à l'aide d'un débogueur peut provoquer des Heisenbug du simple fait que le logiciel se déroule moins rapidement. [170] Et les situations de compétition peuvent entraîner des Mandelbug, où le comportent du programme est différent à chaque fois que celui-ci est exécuté.[171]
Le mot NoSQL est la combinaison de non est de SQL, ce qui laisse penser que cette technologie s'oppose à SQL. Selon Shashank Tiwari dans son livre Professional NoSQL, « Les auteurs de ce néologisme ont probablement voulu signifier non-relationnel, mais ont préféré le mot NoSQL parce qu'il sonne mieux ». Le mot est aujourd'hui utilisé comme terme générique pour tout les SGBD et les logiciels de stockage de données qui ne suivent les principes classiques des SGBD relationnels. Les SGBD non-relationnels sont plus anciens que les SGBD relationnels et sont répandus sur les mainframes et les logiciels d'annuaire. Ces SGBD ont connu une nouvelle jeunesse avec le NoSQL dans le domaine des grands services Internet. La plupart des logiciels NoSQL sont destinés à être utilisés dans les dispositifs en répartition de charge des grands services Internet.
La conférence du 1er juillet 2009 à San-Francisco est considéré comme l'inauguration de la communauté des développeurs de logiciels NoSQL. Des développeurs qui, selon le magazine Computerworld, « racontent comment ils ont renversé la tyranie des coûteux et lents SGBD relationnels par des moyens plus simples et plus rapide de manipuler des données ». Selon Jon Travis, un des présentateurs de la conférence, « les SGBD relationnels offrent trop, alors que les produits NoSQL offrent exactement ce dont vous avez besoin ».
Les leaders de cette communauté sont des start-up de développeurs qui n'ont pas les moyens d'acheter les SGBD de Oracle et qui ont développé leurs propres SGBD en imitant les produits de Google et Amazon.com. Les produits qu'ils ont créés sont capables de manipuler les très grandes quantités de données (qui se mesurent en centaines de Téraoctets) et offrent une scalabilité bien adaptée au besoins des applications Web 2.0 ce qui les rends attractifs sur le marché des SGBD. Les auteurs décrivent leurs produits comme n'étant pas des SGBD, mais plutôt des logiciels de stockage de données.
Un buzzword pour désigner une catégorie de logiciels de gestion de base de données (abr. SGBD) destinés à manipuler des bases de données géantes pour des sites web de très grande audience tels que Google, Amazon, Facebook ou EBay et offrir une solution aux problèmes de performance, de scalabilité et de coût posé par la majorité des produits du marché, qui sont des SGBD relationnels.
[175]
Les produits NoSQL sont destinés à outrepasser les limitations techniques des SGBD relationnels, tels que les limites de scalabilité, ou lorsque les données peuvent difficilement être adaptées au modèle relationnel.
Le nom NoSQL regroupe une large gamme de logiciels de base de données, chacun ayant ses forces et ses faiblesses et chacun étant destiné à une utilisation différente. Il y a des logiciels de base de données clé/valeur, des logiciels hautement distribués et des logiciels orientés documents:
- clé/valeur
- hautement distribué. Ce type de produit est destiné à être installé sur un groupe d'ordinateurs qui travaillent parallèle. L'ajout d'un ordinateur au groupe provoque une augmentation de la puissance de calcul, tandis que la panne d'un ordinateur entraine une diminution. Le propriétaire a la possibilité de faire des raccourcis sur les contrôles de cohérence et augmenter ainsi la puissance de calcul, la tolérance de faute et la disponibilité.
- orienté document
Les SGBD relationnels sont une des technologies les plus répandues dans les entreprises. Ces produits visent la quantité d'informations et le nombre d'utilisateurs d'une entreprise et sont destinés principalement au traitement de transactions. De tels produits montrent leurs limites lorsqu'ils sont utilisés dans un périmètre plus large, tel qu'un large ensemble en répartition de charge (load balancing) d'un site web fréquenté par des millions de visiteurs dans le monde entier; Les SGBD relationnels nécessitent alors des logiciels et des ordinateurs coûteux ainsi que des connaissances pointues. C'est dans ce secteur que s'utilisent les logiciels NoSQL: Ils ont une scalabilité élevée, ils sont concus dans l'optique d'être utilisés sur Internet. Ddans de telles utilisations la scalabilité prime sur la consistence et la cohérence typiquement offerte par les logiciels de base de données relationnelles.[177] La complexité de mise en oeuvre du traitement des transactions est alors réduite dans le but d'obtenir des services plus simples et plus spécialisés. [178]
Le stockage d'information à l'aide de tableau associatifs (dit clé/valeur) existe depuis le début de l'histoire des bases de données. Il est plus simple à mettre en oeuvre que le langage SQL, mais requiert plus de travail de la part du programmeur d'application qui exploite le SGBD. Il permet également un contrôle plus fin sur le travail effectué par le SGBD. Dans les années 2005 sont apparues des nouvelles demandes pour de nouvelles applications, et la facilité de mise en oeuvre des tableaux associatifs sont à l'origine de la naissance de plusieurs solutions nouvelles basées sur ce principe. Ces solutions ont comme point commun qu'elles ne mettent pas en oeuvre le langage de commande SQL et cette nouvelle tendance a été baptisée NoSQL. Ce titre est cependant trompeur, parce qu'il est probable qu'à l'avenir certaines de ces solutions offriront le langage SQL en option. Ces produits sont concus en vue d'échanger la solidité et la facilité d'utilisation des SGBD traditionnels contre la flexibilité et la performance nécessaire en vue de répondre aux nouveaux problèmes rencontrés par l'industrie informatique. [180]
Les produits NoSQL sont un développement récent. S'ils sont encore rare dans le marché des entreprises, ils ont prouvé leur utilité pour les services Internet de grande audience tels que les sites de e-commerce, les moteurs de recherche et les réseaux sociaux. Il existe de nombreux logiciels auto-proclamés NoSQL, qui ont chacun leur forces et leur faiblesses. Le compromis fondamental qui a été fait à ces produits et d'abandonner certaines fonctionalités classiques des SGBD relationnels tels que le stockage sous forme de matrice et le langage SQL, au profit de la simplicité, la performance et une scalabilité élevée. [181]
Dans le marché des SGBD NoSQL se trouvent Cassandra, MongoDB, Voldermort, CouchDB et SimpleDB. Selon Oracle le "tappage" (sic) autour de ces produits vient du fait qu'ils sont impliqués dans des grands sites Internet tels que Facebook, LinkedIn ou Amazon.com. C'est un marché jeune, ou il n'y a pas encore de leader (en 2011). Le marché est en évolution rapide, et les comparatifs de produits de ce marché se trouvent rapidement dépassés. [184]
mot créé en 1998 [185]
Lors d'un sondage réalisé en 2010 auprès des professionels de l'informatique, 44% des sondés répondent qu'ils n'ont jamais entendu parler de NoSQL. [186]
En informatique un système de gestion de bases de données (abr. SGBD; En anglais DBMS pour database management system) est un logiciel destiné à permettre l'organisation, et la manipulation des magasins d'informations que sont les bases de données.
Un SGBD permet d'inscrire, de retrouver, de modifier les informations de la base de données. Il permet d'effectuer des compte-rendus des informations enregistrées et comporte des mécanismes pour assurer la cohérence des informations, éviter des pertes d'informations due à des pannes, assurer la confidentialité et permettre son utilisation par d'autres logiciels. Les outils incorporés au SGBD permettent également de rechercher, de trier, de transformer ou d'imprimer les informations. Selon les modèles de SGBD, ces outils vont d'une simple interface graphique jusqu'à des langages de programmation sophistiqués.
Les systèmes de gestion de base de données sont utilisés pour de nombreuses applications informatiques, notamment les guichets automatique bancaires, les logiciels de réservation, les bibliothèques numériques ou les logiciels d'inventaire. IBM DB2, Microsoft SQL Server, Oracle Database et MySQL sont des systèmes de gestion de base de données. [188] [189]
Le but
[modifier | modifier le code][190] Les SGBD sont destinés à permettre le stockage d'informations d'une manière qui offre de nombreux avantages par rapport à un enregistrement conventionnel dans des fichiers. Ils permettent d'obtenir et de modifier rapidement des informations, de les partager entre plusieurs usagers tout en garantissant l'absence de redondance, l'intégrité, la confidentialité et la pérennité des informations. Les SGBD resolvent les éventuels conflits de modifications et cachent les détails du format de fichier des bases de données.
Les informations sont enregistrées sous forme de données: des suites de bits sans signification qui sont la représentation informatique de renseignements bruts (lettres, nombres, couleurs, formes,...). Le SGBD comporte différents mécanismes destinés à retrouver rapidement les données et les convertir en vue d'obtenir des informations qui ont un sens.
A l'aide du SGBD plusieurs usagers et plusieurs logiciels peuvent accéder simultanément aux informations. Le SGBD effectue les vérifications pour assurer qu'aucune personne non autorisée n'ait accès à des informations confidentielles contenues dans la base de données, il résout les conflits dus à des modifications simultanées de la même information et comporte des mécanismes en vue d'éviter des pertes d'informations suite à une panne.
La redondance est la présence de plusieurs copies de la même information - dont la modification peut amener à des incohérences, c'est-à-dire que les différentes copies ne correspondent plus. Le SGBD vérifie - voire refuse - la présence de redondances. Le SGBD effectue également sur demande des vérifications pour assurer que les informations qui sont introduites sont correctes: que les valeurs sont dans les limites admises, que leur format est correct et que les informations sont cohérences par rapport à ce qui se trouve déja dans la base de données.
Les informations sont typiquement manipulées par un logiciel applicatif qui fait appel aux services du SGBD pour manipuler la base de données. Alors qu'un logiciel applicatif qui manipule un fichier tient compte du format de données de ce fichier, un logiciel qui manipule une base de données par l'intermédiaire d'un SGBD n'a pas connaissance du format de la base de données, les informations sont présentées par le SGBD sous une forme qui cache les détails du format des fichiers dans lesquels elles sont enregistrées.
Les fonctionalités
[modifier | modifier le code]Un SGBD permet d'enregistrer des informations, puis les rechercher, les modifier et créer automatiquement des compte-rendus (anglais report) du contenu de la base de données. Il permet de spécifier les types de données, la structure des informations contenues dans la base de données, ainsi que des règles de cohérence telles que l'absence de redondance.[191]
les renseignements concernant les caractéristiques des informations enregistrées dans la base de données, ainsi que les relations, les règles de cohérence et les listes de contrôle d'accès sont enregistrées dans un catalogue qui se trouve à l'intérieur de la base de données et qui est manipulé par le SGBD. [192]
Les opérations de recherche et de manipulation des informations, ainsi que la définition des caractéristiques des informations, des règles de cohérences et des autorisations d'accès peuvent être exprimés sous forme de requêtes (anglais query) dans un langage informatique reconnu par le SGBD[193].
Les bases de données peuvent être d'une taille de plusieurs téraoctets; une taille supérieure à la place disponible dans la mémoire centrale de l'ordinateur. Les bases de données sont enregistrées sur disque dur, ces derniers ont une capacité supérieure, mais sont moins rapides, et le SGBD est équipé de mécanismes visant à accélérer les opérations.[194]
Les SGBD sont équipés de mécanismes en vue d'assurer la réussite des transactions, éviter des problèmes dus à la concurrence et assurer la sécurité des données:
- transactions: Une transaction est une opération unitaire qui transforme le contenu de la base de données d'un état A vers un état B. La transformation peut nécessiter plusieurs modifications du contenu de la base de données. Le SGBD évite qu'il existe des états intermédiaires entre A et B en garantissant que les modifications sont effectuées complètement ou pas du tout. En cas de panne survenue durant des opérations de modification de la base de données, le SGBD remet la base de données dans l'état ou elle était avant l'interruption de la transaction.[195]
- concurrence: La base de données peut être manipulées simultanément par plusieurs personnes, et le contrôle de la concurrence vérifie que ces manipulations n'aboutissent à des incohérences. Par exemple dans un logiciel de réservation, le SGBD vérifie que chaque place est réservée au maximum par une personne, même si des réservation sont effectuées simultanément.[196]
- sécurité des données: Le choix de permettre ou d'interdire l'accès à des informations est donné par des listes de contrôle d'accès, et des mécanismes du SGBD empêchent des personnes non autorisées de lire / de modifier des informations pour lesquelles l'accès ne leur a pas été agréé. [197]
Indépendance des données - les 3 vues
[modifier | modifier le code]Dans un dispositif de base de données - qui comporte un logiciel applicatif, un SGBD et une base de données - la manière dont les informations sont présentées aux utilisateurs diffère de la manière dont sont organisées les informations, et celle-ci diffère de la manière dont les informations sont enregistrées dans des fichiers. Cette construction à 3 points de vue est basée sur le modèle de référence ANSI/SPARC.
Chacune des 3 vues peuvent être modifiées par exemple en formulant des requêtes dans le langage du SGBD. L'indépendance des données est la capacité d'un SGBD de permettre la modification de n'importe laquelle des trois vues sans que cela nécessite de modification des autres vues.
- Vue utilisateur: Les utilisateurs ne voient qu'une partie des informations contenues dans la base de données, ce que voit l'utilisateur sont des informations dérivées du contenu de la base de données et présentées d'une manière différente. Il existe différentes vues adaptées à chacun des rôles joués par les utilisateurs.
- schéma conceptuel: c'est le modèle de l'organisation logique des informations enregistrées dans la base de données, c'est une vue de la totalité des informations enregistrées. Le schéma est souvent organisé de la même manière que les objets du monde réel auquel les informations se rapportent et décrit en utilisant la notation entité-association.
- Schéma physique: Ce sont les caractéristiques des structures en place pour permettre le stockage permanent des informations sous forme d'enregistrements dans des fichiers. Ceci comprends l'espace réservé à chaque information, la manière dont les informations sont représentées sous forme de suite de bits, et la présence d'indexes destinés à accélérer les opérations de recherche.
Il y a indépendance des données si le schéma conceptuel peut être modifié sans nécessiter de modification du point de vue de l'utilisateur ni de la structure physique, et si la structure physique peut être modifiée sans que cela nécessite de modifications du schéma conceptuel ou du point de vue de l'utilisateur. [198],[199]
Typologie
[modifier | modifier le code]Selon leur construction et les possibilités qu'ils offrent les SGBD peuvent être dit relationnels, orienté objet, objet-relationnel. Ils peuvent être distribués ou centralisés et peuvent être spatials. En 2010 la majorité des SGBD sont de type relationnel: ils manipulent des bases de données conformément au modèle de données relationnel. Le volume des ventes de SGBD relationnels est estimé entre 6 et 10 millions de dollars par année en 2005[4]. [200]
- relationnel: Le modèle relationnel est destiné à assurer l'indépendance des données - que les données ne soient pas modifiées en cas de réorganisation des fichiers dans laquelle elles sont enregistrées. Il est également destiné à offrir les bases pour contrôler la cohérence et éviter la redondance. Il permet de manipuler les données comme des ensembles en effectuant des opérations de la théorie des ensembles. Selon ce modèle, les informations sont placées dans des tables avec lignes et colonnes et n'importe quelle information contenue dans la base de données peut être retrouvée à l'aide du nom de la table, du nom de la colonne et de la clé primaire. Le contenu des cellules des tables peut être nul, c'est-à-dire que l'information est absente. Les règles de cohérence qui s'appliquent aux bases de données relationnelles sont l'absence de redondance ou de nul des clés primaires, et l'intégrité référentielle[4]. [201]
- spatial: Les applications informatiques telles que les système d'information géographiques et les outils de conception assistée par ordinateur utilisent des SGBD spatial. Ce type de logiciel sert au stockage d'informations géométriques telles que des points, des lignes, des surfaces et des volumes. Ils comportent des fonctions permettant de retrouver une information sur la base de caractéristiques géométriques telles que les coordonées ou la dimension. Le langage de requête du SGBD permet la manipulation d'informations de géométrie tels que lignes, point ou polygones, le SGBD met en oeuvre les algorithmes et les structures de fichiers nécessaire[5].[202]
- centralisé ou distribué : Un SGBD est dit centralisé lorsque le logiciel contrôle l'accès à une base de données placée sur un ordinateur unique. Il est dit distribué lorsqu'il contrôle l'accès à des données qui sont dispersées entre plusieurs ordinateurs. Dans cette construction, un logiciel est placé sur chacun des ordinateurs, et les différents ordinateurs utilisent des moyens de communication pour coordoner les opérations. Le fait que les informations sont dispersées est caché à l'utilisateur, et celles-ci sont présentées comme si elles se trouvaient à une seule place[6].[203]
- orienté objet et objet-relationnel : Les SGBD orientés objet sont un sujet de recherche depuis 1980, lorsque sont apparus les premiers langage de programmation orientée objet. Ils sont destinés à offrir les fonctionalités des SGBD à des langages orientés objet et permettre le stockage persistent des objets. Les objets sont manipulés en utilisant les possibilités natives des langages orientés objet et une interface de programmation permet d'exploiter les fonctionalités du SGBD. Celui-ci est équipé des mécanismes nécessaires pour permettre l'utilisation des possibilités d'encapsulation, d'héritage et de polymorphisme des langages de programmation orientée objet[7],[8].[204],[205] Les SGBD objet-relationel offrent à la fois les possibilité des SGBD orientés objet et ceux des SGBD relationels[9]. [206]
Le marché
[modifier | modifier le code]En 2002 choisir un SBGD n'est plus aussi difficile qu'il ne l'était avant, le nombre d'éditeurs de SGBD a diminué du fait de fusions et de la domination de ce marché par un petit nombre d'acteurs majeurs.
Une entreprise de taille moyenne utilise couramment plusieurs SGBD simultanément, il n'est pas rare de voir une telle institution exécuter à la fois IBM DB2 sur un mainframe, Oracle Database ou Informix sur des serveurs Unix, SQL Server sur des ordinateurs équipés de Windows NT, ainsi que d'autres SGBD tels que Sybase, Ingres ou Adabas. La raison est que le choix du SGBD est rarement anticipé, souvent imposé par l'arrivée d'un logiciel applicatif, et difficilement reversible:
- Il arrive que la société acquiert un logiciel applicatif qui ne fonctionne sur aucun des SGBD qu'elle possède déja. Il arrive également qu'une société motive l'achat d'un nouveau SGBD par la volonté d'utiliser les technologies les plus récentes et les plus éminentes.
- Le replacement d'un ancien SGBD par un nouveau est souvent difficile en raison du manque de compatibilité entre les différents produits, ce qui rends nécessaire d'adapter les logiciels applicatifs au nouveau venu. Souvent les logiciels applicatifs ne sont jamais adaptés, et le vieux SGBD continue d'être utilisé en même temps que les nouveaux produits.
Le marché des SGBD est réparti en 3 segments:
- le premier segment est celui des grandes marques, largement implantées et reconnues. Les trois grands noms de ce segment sont IBM DB2, Oracle Database et Microsoft SQL Server. Ces produits sont très populaires, et peuvent être utilisés pour de nombreuses applications. DB2 et Oracle fonctionnent sur de nombreux types d'ordinateurs qui vont des mainframe jusqu'aux ordinateurs de poche.
- dans le deuxième segment se trouvent des produits un peu moins populaires tels que Sybase et Informix, ils sont un peu moins implantés, moins connus, et leurs éditeurs sont des sociétés un peu plus petites et avec moins de personnel.
- dans le troisième segment se trouvent tous les autres SGBD, dont certains sont notables dans les utilisations spécialisées ou les marchés de niche. Par exemple Teradata de NCR est un SGBD utilisé pour les bases de données géantes et les datawarehouse. Dans ce segment de marché se trouvent les SGBD open source tels que PostgreSQL et MySQL ainsi que les SGBD orientés objet tels que Versant ou ObjectDesign.
Les critères souvent cités lors de l'achat d'un SGBD sont qu'il s'intègre dans le système informatique existant, en particulier s'utilise avec les systèmes d'exploitation déja acquis, le nombre d'outils disponibles, le prix, et les contrats d'assistance disponibles. Le choix du SGBD est souvent une décision stratégique pour une institution. Le coût d'acquisition d'un SGBD qui supporte plusieurs milliers d'utilisateurs et une base de données de grande dimensions peut approcher les 1 million de dollars. En 1993 il existe différents SGBD relationnels, et ceux-ci sont considérés comme suffisamment matures pour être utilisés dans des applications stratégiques. Les produits sont complexes, les différences sont parfois subtiles, ce qui rends le choix difficile pour l'acheteur.
Dans le marché des système de base de données client-serveur de 1993, l'ordinateur client exécute un logiciel frontal qui présente une interface graphique, crée des requêtes et présente des compte-rendus. Tandis que l'ordinateur serveur exécute le SGBD qui s'occupe d'exécuter les recherches, vérifier la cohérence des informations et effectuer des sauvegardes. Entre la partie frontale et dorsale il y a un mélange complexe de produits et de standard en constante évolution, telle que divers dialectes du langage SQL, plusieurs interfaces de programmation et des outils de middleware.
Dans le haut de gamme des SGBD relationnels, se trouvent des produits destinés aux grands volumes de données et aux applications stratégiques. Ces produits sont destinés à remplacer ceux des mainframe par des systèmes distribués sur plusieurs ordinateurs plus petits et offrent la fiabilité, l'intégrité et la performance typique des logiciels pour mainframe. Ils fonctionnent sur une large palette de systèmes d'exploitation et avec la plupart des protocoles réseau. Ces produits offrent souvent des sévères contrôles de cohérence et de confidentialité, des possibilités de réplication et d'interconnexion avec d'autres SGBD plus anciens.
Une des différences technique qui concerne directement les SGBD est que certains systèmes d'exploitation sont plus à même que d'autres de manipuler de grandes quantités d'informations. D'après un sondage réalisé en 1993 auprès des éditeurs de DBMS, il en ressort que les client dont les bases de données pèsent moins de 15 Go utilisent plutôt Novell NetWare, ceux dont la base de données pèse jusqu'à 100 Go utilisent plutot Unix, alors qu'au dessus de cette limite c'est généralement un mainframe qui est utilisé.
Les questionnements fréquents des acheteurs concernent la performance, les caractéristiques du langage de commande, du contrôle de la concurrence ainsi que les type de données disponibles. La question de la performance apparait souvent en haut de la liste des acheteurs et en bas de la liste des vendeurs; raison pour laquelle les essais et les benchmarks sont une pratique courante. Les caractéristiques du langage de commande SQL renseignent sur la syntaxe à laquelle devront se conformer les requêtes envoyées au SGBD. Le standard SQL a été modifié à plusieurs reprises, il existe 3 niveaux de conformité, et le langage SQL reconnu par chaque SGBD du marché se rapproche d'un ou l'autre de ces différents standards.
D'après un sondage réalisé en 1993 par le magazine Network World, il en ressort que les critères de choix du SGBD les plus importants au yeux de l'acheteur sont la fiabilité, la performance, la conformance aux normes, la palette d'ordinateurs supportés, et la facilité d'utilisation. Le prix n'apparaît qu'en dixième position. Toujours d'après ce sondage, 70% des clients se disent prêts à débourser entre 2 000 et 25 000 dollars pour l'acquisition d'un SGBD.
Une base de données embarquée (anglais embedded) est un SGBD sous forme de composant logiciel qui peut être incorporé dans un logiciel applicatif. Contrairement à un SGBD client-serveur dans lesquel un processus traite les requêtes, un modèle embarqué se compose de bibliothèques logicielles liées par liaison dynamique avec le logiciel qui utilise le SGBD. Dans ce type de SGBD, la base de données est souvent composée d'un fichier unique dont le format est identique quel que soient les caractéristiques de l'ordinateur utilisé. Bien que le SGBD offre de nombreux avantages par rapport à un enregistrement sur fichier, ces derniers sont souvent préférés aux SGBD, qui ont la réputation d'être des logiciels lourds, encombrants et compliqués à installer.
SQLite, Berkeley DB, HSQLDB, Apache Derby ainsi que certaines éditions de Firebird et de MySQL sont des SGBD embarqués. [210]
La taille des bases de données
[modifier | modifier le code]Les différents SGBD sur le marché se différencient par le périmètre d'utilisation des bases de données: Le périmètre influence le nombre d'utilisateurs simultanés, la taille des bases de données, la ou les emplacements, et la puissance de calcul nécessaire. Certains SGBD supportent de très grandes bases de données, et nécessitent des ordinateurs puissants et très couteux. D'autres SGBD fonctionnent sur des ordinateurs personnels bon marché, avec des limites quand à la taille des bases de données et la puissance de calcul.
- SGBD personnels: Ces produits sont beaucoup plus simples que les modèles pour les entreprises du fait qu'ils sont concus pour servir un seul utilisateur à la fois; Lorsqu'un deuxième utilisateur essaye d'accéder à la base de données, il doit attendre que le premier a terminé. Ces SGBD sont parfois installés sur des ordinateurs personnels pour des bases de données dites de bureau (anglais desktop database). Les bases de données des applications personnelles sont plus petites.
- Les SGBD de groupe: Les SGBD de groupe et d'enteprise peuvent être utilisés par plusieurs usages simultanément. Ils sont dit de groupe lorsque le nombre d'usagers est relativement restreint (50 à 100). Aujourd'hui les modèles de groupe sont les plus populaires dans les petites et moyennes institutions.
- SGBD d'entreprise: Les premiers SGBD apparus en 1960. Les ordinateurs de cette époque était très grands et très cher. et les SGBD étaient tous de taille entreprise: puissants, robustes et gourmands en matériel. Avec l'amélioration technologique, les SGBD d'enteprise sont devenus plus puissants, sont capable de manipuler de grande quantités d'informations et peuvent être utilisées par des milliers d'utilisateurs simultanément.
Une des manières de catégoriser une application de base de données est le périmètre de la base de données - s'agit-il d'une base de données personnelles, de groupe, de département ou d'entreprise:
- Une base de données personnelles est utilisé par une personne unique et réside sur son ordinateur personnel. L'utilisateur s'occupe d'organiser la base de données et de manipuler les données.
- Une base de données de groupe est créée dans le but de permettre le partage d'information entre les membres d'un groupe de travail. Si les membres se trouvent au même emplacement géographique, alors une base de données unique, centralisée est placée sur un ordinateur unique. Plusieurs utilisateurs manipulent simultanément les informations de la base de données, et le SGBD comporte des mécanismes pour assurer que ces modifications ne remettent pas en cause la cohérence du contenu.
Histoire
[modifier | modifier le code]Jusqu'en 1960 les informations étaient enregistrées dans des fichiers manipulées par les logiciels applicatifs[5]. L'idée des bases de données a été lancée en 1960 dans le cadre du programme Apollo. Le but était de créer un dispositif informatique destiné à enregistrer les nombreuses informations en rapport avec le programme spatial, en vue de se poser sur la lune avant la fin de la décenie[4]. [220] C'est dans ce but que IBM, conjointement avec Rockwell met sur le marché le logiciel Information Management System (IMS). Avec ce SGBD, les informations sont enregistrées dans des bases de donn��es organisées de manière hiérarchique[5].
A la même époque General Electric, avec l'aide de Charles Bachman met sur le marché le logiciel Integrated Data Store. Avec ce SGBD les informations sont enregistrées dans des bases de données organisées selon un modèle réseau, ce qui permet d'enregister des informations ayant une organisation plus complexe que le modèle hiérarchique[5].
En 1967 le consortium CODASYL forme un groupe de travail, le database task group abr. DBTG, qui travaille à la normalisation de deux langages informatique en rapport avec les bases de données: le DML et le DDL[5].
Les organisations hiérarchiques et réseau des années 1960 manquaient d'indépendance vis-à-vis du format des fichiers, ils rendaient complexe la manipulation des données et il leur manquait une base théorique. En 1970 Edgar Frank Codd, employé de IBM publie le livre A relational model of data for large shared data banks, un ouvrage qui présente les fondations théoriques de l'organisation relationnelle[5].
Sur la base des travaux de E.F Codd, IBM développe le SGBD System R, qui sera mis sur le marché à la fin des années 1970. Il est destiné à démontrer la faisabilité d'un SGBD relationnel. Le langage informatique propre à ce SGBD est le Structured Query Language (abr. SQL), défini par IBM et destiné à la manipulation des bases de données relationnelles[4]. [221]
Charles Bachman reçoit le prix Turing en 1973 pour ces contributions à la technologie des bases de données et Edgar Frank Codd reçoit le prix Turing en 1981 pour les mêmes raisons[10]. [222]
En 1978 ANSI publie la description de l'architecture Ansi/Sparc qui sert de modèle de référence en rapport avec l'indépendance des données des SGBD[5].
Les deux SGBD ténor du marché de 2010 que sont IBM DB2 et Oracle Database ont été mis sur le marché en 1979 et sont tout deux basés sur le modèle relationnel. La même année le langage SQL est normalisé par ISO[5].
Les moteur de recherche et les datawarehouse sont des applications informatiques apparues dans les années 1990, qui ont influencé le marché des SGBD. Les moteurs de recherche ont nécessité le traitement d'informations non structurées et écrites en langage naturel. Et les datawarehouse ont nécessité la collecte et la consolidation de très grande quantités d'informations en vue de réaliser des tableaux de synthèse[10]. [223]
Les modèles d'organisation orienté objet et objet-relationnel sont apparus dans les années 1990[5]. Les premiers SGBD objet-relationnel ont été Postgres, Informix et Oracle Database en 1995. Le standard relatif au langage SQL a été modifié en 1999 pour pouvoir s'appliquer à ce type de SGBD[11]. [224]
Personnes qui travaillent avec les SGBD
[modifier | modifier le code]L'administrateur de bases de données (anglais database administrator abr. DBA) et la personne responsable de l'intégrité, de la sécurité et la disponibilité des informations contenues dans les bases de données. Il protège les informations contre les accidents dus à des mauvaises manipulation, des erreurs de programmation, des utilisations malveillantes, ou des pannes qui entraineraient des détérioration du contenu des bases de données.
Pour ce faire, l'administrateur de base de données autorise ou interdit l'accès aux informations, surveille l'activité du SGBD et aquiert le logiciel et le matériel nécessaire pour faire face aux problèmes. Il effectue régulièrement des copies de sauvegarde en vue de permettre la récupération de données qui ont été perdues ou déteriorées.
Le concepteur de base de données (anglais database designer) est la personne qui identifie les informations qui seront enregistrées dans la base de données, les relations entre ces informations, les contraintes qu'il existe - telles que la présence ou pas de redondance. Le concepteur de base de données a une connaissance approfondie de l'usage qui est fait de ces informations, et les règles qui en découlent. Il est reponsable d'organiser la base de données de manière appropriée en mettant en place les structures nécessaires au stockage des informations. [225]
Les programmeurs créent des logiciels applicatifs qui utilisent les possibilités du SGBD. Ces logiciels ciblent une activité en particulier - par exemple retrouver des livres dans une bibliothèque - et sont destinés à des usagers non experimentés. Des utilisateurs expérimentés peuvent également manipuler le contenu de la base de données sans passer par ce logiciel, et effectuer des opérations que le logiciel applicatif en question ne permet pas.
Il existe de nombreuses catégories d'utilisateurs des SGBD. Les plus importantes sont l'administrateur de base de données, le développeur et le responsable d'activités.
- les administrateurs de base de données sont les experts en SGBD qui s'occupent d'installer et de maintenir les SGBD ainsi que les outils annexes qui les accompagnent. Ils s'occupent de l'intégrité et la sécurité des informations, ainsi que de la performance du SGBD. Ils planifient les opérations de sauvegarde et de réorganisation de la base de données, effectuent des réglages de tuning et autorisent les utilisateurs à accéder aux informations. Ils utilisent l'outils d'administration de base de données ou le langage de commande du SGBD.
- Les développeurs créent des logiciels applicatifs, chacun en rapport avec une activité donnée. Le développeur travaille avec le responsable d'activité en vue de déterminer les besoins caractéristiques de cette activité, puis il détermine l'architecture du produit, et le met en oeuvre en rédigeant le code source.
- Le responsable d'activité compte sur le développeur et son logiciel applicatif.
- Le développeur accède au SGBD à l'aide de programmes écrits dans un langage de programmation de haut niveau.
- Les utilisateurs finaux peuvent manipuler directement le SGBD. Par exemple pour répondre à des demandes provenant de personnes non autorisées à manipuler la base de données, ou pour générer les compte-rendu occasionnels. De tels utilisateurs peuvent être autorisés à lire, voire à modifier le contenu de la base de données.
- les utilisateurs expérimentés ont les connaissances nécessaires pour utiliser le langage de commande du SGBD et accédent aux données à partir de leur ordinateur personnel. Ils ont été autorisés par l'administrateur de voir certaines informations et de les modifier. Les utilisateur expérimentés peuvent rechercher, ajouter, modifier, ou supprimer des données en utilisant le langage de commande du SGBD, alors que les utilisateurs inexpérimentés n'utilisent jamais le langage de commande mais accèdent aux informations à travers des logiciels applicatifs prévus à cet effet.
- Les utilisateurs inexpérimentés accèdent aux informations à travers un logiciel applicatif. Ils exécutent des commandes ou choisissent des menus et n'ont pas connaissance du langage de commande ni de l'organisation de la base de données. Les opérations effectuées par ces utilisateurs sont moins sophistiquées et limitées aux possibilités offertes par le logiciel applicatif.
- Les développeurs créent des batch et des programmes destinés aux autres usagers du SGBD. Les programmes sont écrit dans un des nombreux langages de programmation de haut niveau. Chaque programme qui accède aux informations de la base de données comporte des instructions qui font appel au SGBD pour effectuer des rechercher ou modifier les informations. Certains utilisateurs expérimentés, qui connaissent un ou l'autre langage de programmation, créent des programmes pour leur propre usage.
Microsoft Access : [230]
Composition
[modifier | modifier le code]Un SGBD se compose de plusieurs programmes qui s'occupent des transactions, surveillent les opérations et manipulent les fichiers en utilisant des mémoires tampon (anglais buffer).
- contrôle des transactions: lors d'une transaction plusieurs modifications sur la base de données correspondent à une seule opération; Le contrôleur de transactions assure la cohérence du contenu de la base de données, y compris en cas d'échec ou de panne. Il vérifie également que les modifications concurrentes des mêmes informations n'aboutissent pas à un résultat incohérent.
- contrôle des opérations: celui-ci vérifie qu'aucun utilisateur n'accède à des informations non autorisées, et qu'aucun utilisateur n'effectue des modifications qui seraient contraires aux règles de cohérence.
- accès aux fichiers: manipule l'espace réservé au stockage. Les informations sont groupées par nature, et chaque fichier stocke une collection d'informations de même nature. Le programme d'accès au fichier structure les différents fichiers conformément au schéma d'organisation de la base de données.
- mémoire tampon. Une mémoire tampon est un emplacement de mémoire centrale qui est utilisé pour stocker temporairement des informations en transit. Les informations sont récupérées en bloc depuis les fichiers, puis placés dans des mémoires tampon. Lors des lectures suivantes l'information est récupérée depuis la mémoire tampon existante. Les opérations de lecture des fichiers sont ainsi diminuées, et les opérations d'écriture sont décalées, ce qui accélère le SGBD.
Un SGBD est composé de nombreux programmes, parmi lesquels le moteur, le dictionnaire, le langage de commande et des outils.
- Le moteur est le coeur du SGBD, il manipule les fichiers de la base de données, transmet les données de et vers les autres programmes, et vérifie la cohérence et l'intégrité des données.
- Un programme manipule le catalogue: Le magasin qui contient la description de l'organisation de la base de données, les listes de contrôle d'accès, le nom des personnes autorisées à manipuler la base de données et la description des règles de cohérence (contraintes).
- La majorité des SGBD comportent au moins un langage de commande. Ce langage de requête permet de manipuler le contenu de la base de données. reconnu par la majorité des SGBD du marché, SQL est devenu le langage standard de facto.
- Les outils du SGBD servent à créer des compte-rendus (reports), des écrans pour la saisie des informations, importer et exporter les données de et vers la base de données, et manipuler le catalogue.
Le moteur de base de données est la partie centrale du SGBD qui effectue les opérations d'enregister et de retrouver les données. Selon le SGBD, La base de données peut être composées d'un ou de plusieurs fichiers; Le rôle du moteur est de manipuler ces fichiers. Les indexes sont des structures destinées à accélérer les opérations de recherche, elles sont entretenues par le moteur de base de données. Les vues sont des tables imaginaires crées à partir d'autres tables, et leur contenu est entretenu par le moteur de base de données. Celui-ci manipule également le catalogue, contrôle les transactions, vérifie la cohérence des informations et vérifie que les utilisateurs accèdent uniquement à des informations autorisées.
Le processeur de requête exécute les opérations demandées. Selon le modèles de SGBD, ces opérations peuvent être formulées dans un langage de commande tel que SQL, ou à l'aide d'une interface graphique du type QBE (query by example en français requête par l'exemple).
Un programme manipule le catalogue: Le magasin qui contient la description de l'organisation de la base de données, les listes de contrôle d'accès, le nom des personnes autorisées à manipuler la base de données et la description des règles de cohérence (contraintes). Selon les modèles de SGBD ces informations peuvent être modifiées en utilisant le langage de commande, ou alors à l'aide d'une interface graphique.
Les SGBD sont des logiciels complexes et stratégiques, utilisés dans de très nombreuses applications informatiques, parmi lesquelles le e-commerce, les dossiers médicaux, les paiements, les ressources humaines, la gestion de la relation client et la logistique ainsi que les blogs et les wikis, ils sont le résultat de dizaines d'années de recherche scientifique et industrielle. Les premiers SGBD de l'histoire ont fortement influencé ce secteur de marché, et les idées de ces pionniers sont encore largement copiées et réutilisées par les SGBD contemporains. Les bases de données ont été un des premiers usages populaires des serveurs et les expériences des serveurs de base de données ont influencé le marché des logiciels applicatifs, des systèmes d'exploitation et des services réseau. Le marché des SGBD est cependant très ténu, dominé par une poignée de produits concurrents de haut de gamme.
Dans un SGBD relationnel, les demandes formulées au SGBD sont typiquement traitées en 5 étapes:
- Les logiciel client communiquent avec le SGBD en utilisant son interface de programmation via un réseau. Un dispositif de communication du SGBD vérifie l'identité du client, puis transmet les requêtes du client vers le noyau du SGBD et transmet au client les informations extraites par le SGBD.
- Le SGBD crée ensuite un thread en vue de traiter la requête. Un programme contrôle l'ensemble des threads est décide lesquels sont exécutés immédiatement et lesquels seront exécutés plus tard, en fonction de la charge de travail de l'ordinateur.
- Lors de l'exécution du thread, un compilateur transforme le texte exprimé dans le langage de requête du SGBD vers un plan d'exécution dont la forme imite celle d'une expression algébrique utilisant l'algèbre relationnelle, puis un ensemble de programmes "opérateurs" calculent le résultat de l'expression en effectuant des opérations telles que la jointure, le produit cartésien, le tri et la sélection.
- Les opérateurs font appel au programme de manipulation de fichiers, celui-ci exécute les algorithmes nécessaires pour retrouver les informations et entretenir les structures des fichiers de la base de données - algorithmes appelés access method en anglais. Ce programme utilise des mémoires tampon en vue de diminuer le nombre d'opérations sur les fichiers et accélerer les opérations. Les opérations sont souvent inscrites dans un fichier journal, ce qui permet de les annuler en cas d'incident.
- Une fois les informations obtenues par le programme de manipulation de fichiers, celles-ci sont envoyées au thread d'exécution puis ensuite au dispositif de communication qui les transmet au client.
Les SGBD contemporains de haut de gamme comportent de nombreuses extensions qui offrent des fonctionalités auxiliaires, leur construction reste cependant similaire à la plupart des SGBD. [235]
l'outil d'administration est le logiciel utilisé par l'administrateur de bases de données. Il s'en sert pour effectuer des sauvegardes, des restauration de données, autoriser ou interdire l'accès à certaines informations, et effectuer des modifications du contenu de la base de données - création, lecture, modification et suppression d'informations, abrégé CRUD (anglais create, read, update, delete). Cet outil sert également à surveiller l'activité du moteur et effectuer des opérations de tuning. [236]
En informatique, et plus particulièrement en développement logiciel, un patron de conception (anglais design pattern) est un exemple éprouvé de solution pour répondre à un problème de conception d'un logiciel. Il décrit une solution reconnue, utilisable dans la conception de différents logiciels. [237]
Un patron de conception est issu de l'expérience des concepteurs de logiciels. [238] Il décrit sous forme de diagrammes une solution utilisée par les concepteurs et les programmeurs dans leur logiciels. D'une manière analogue à un patron en couture, le patron de conception décrit les grandes lignes d'une solution, qui peuvent ensuite être modifiées et adaptées en fonction des besoins. [239]
Les patrons de conception ne sont pas des patrons d'architecture (exemple: Modèle-Vue-Contrôleur ou Filtres et tubes), ni des styles de codage.[240]
Les types de patrons
[modifier | modifier le code]- Le patron d'architecture apporte des solutions sur la manière de concevoir l'organisation à grande échelle (architecture) d'un logiciel en faisant abstraction des détails. Il concerne la structure générale d'un logiciel, sa subdivision en unités plus petites, comporte des guides de bonne pratiques et des règles générales qui ne peuvent pas être traduites directement en code source.[241]
- Le patron de conception suggère un arrangement, une manière d'organiser des modules ou des classes. Il décrit une organisation de classes fréquemment utilisée pour résoudre un problème récurrent. Le patron de conception parle d'instances, de rôles et de collaboration.[242]
- l'idiotisme de programmation est une construction spécifique à un langage de programmation, qui décrit une manière fréquente de mettre en oeuvre une solution à un problème, dans le langage de programmation en question. Par exemple pour effectuer 100 fois une opération, un programmeur en langage C utilisera un code contenant la phrase
for (i=0;i<100;i++)
. L'utilisation d'un idiotisme par le programmeur lui évite d'avoir à remettre en question la structure détaillée du programme et améliore la qualité du produit.[243]
Définition et usage
[modifier | modifier le code]Les patrons servent à documenter des bonnes pratiques basées sur l'expérience et sont le résultat d'une synthèse de l'expérience acquise par les ingénieurs. [244]
Les patrons spécifient des solutions à des problèmes qui ne peuvent pas être résolus par un composant unique: La description de la plupart des patrons implique plusieurs rôles qui peuvent être joués par plusieurs composants d'un logiciel. Par exemple le patron Observer implique deux rôles qui sont le sujet et l'observateur.[245]
Les patrons apportent un vocabulaire commun entre l'architecte et le programmeur: Si le programmeur connait le patron de conception Observer, alors l'architecte n'aura pas besoin de lui donner de longues explications et le dialogue se limitera à « ici j'ai utilisé un Observer ». [246]
Une connaissance insuffisante d'un patron peut aboutir à une mise en oeuvre inadaptée. Un patron de conception ne remplace pas une solide connaissance en conception, et la simple connaissance des rôles et de l'arrangement d'un patron complexe est souvent insuffisante pour la réussite de la mise en oeuvre.[247]
Les développeurs sont parfois tentés de redéfinir toutes leurs activités et leur créations sous forme de patrons. En documentant les algorithmes et les structures de données en termes de patrons. Cette utilisation incorrecte est motivante pour son auteur mais pas productive: elle n'améliore pas la qualité des logiciels ni la communication entre le concepteur et le programmeur.[248]
Les développeurs sont aussi parfois tentés de considérer une conception nouvelle et astucieuse - souvent spécifique à un problème donné - comme étant un nouveau patron de conception. Cette utilisation incorrecte du mot patron fait croire qu'il s'agit d'une solution éprouvée par l'expérience, alors que ca n'est pas le cas. Ceci freine les remises en question ou la recherche d'alternatives par les développeurs et se relève contre-productif.[249]
En programmation informatique, les patrons de conception peuvent être utilisés avant, pendant, ou après le travail de programmation: Utilisé avant, le programmeur utilisera le patron comme guide lors de l'écriture du code source. Utilisé après il servira comme exemple pour relier différents modules de code source déjà écrits, ce qui implique d'écrire le code source nécessaire à leur liaison, et le code qui les fera correspondre au patron de conception. Utilisé pendant le travail de programmation, le programmeur constatera que le code qui vient d'être écrit a des points communs avec un patron existant et effectuera les modifications nécessaires pour que le code corresponde au patron.
Histoire
[modifier | modifier le code]Les patrons de conception sont basés sur les idées de Chris Alexander de 1977, et sont devenus une discipline de science informatique suite aux travaux de Cunnigham et Beck en 1995. [251]
En 1994 les 4 scientifiques Erich Gamma, Richard Helm, Ralph Johnson et John Vlissides publient leur livre Design Patterns, Elements of Reusable Object-Oriented Software, considéré comme la bible des patrons de conception. L'appellation GoF patterns, où GoF est l'abrégé de Gang of four - le gang des quatre, désigne les 23 patrons de conceptions décrit dans ce livre.[252]
Exemples
[modifier | modifier le code]Strategy | Créer un représentation informatique d'un sujet concret [253] |
Chain of responsibility | ? |
Decorator | ? |
Prototype | ? |
Factory et Abstract Factory | mettre en oeuvre une interface unique qui permet de créer des objets dont les caractéristiques sont différentes, sans que les différences soient connues à l'avance. C'estt utilisé par exemple pour créer des composant d'interface graphique. [254] |
Observer | ? |
Singleton | Objet unique, dont la conception rends impossible d'en créer deux copies (instances). Utilisé par exemple pour connecter une application avec une base de données.[255] |
Flyweight | ? |
Adapter | adapter une interface pour répondre à un nouveau problème en utilisant un code source existant [256] |
Facade | simplifier une interface: créer un objet unique dont l'interface simplifie celle d'une suite d'objets. Par exemple pour simplifier l'utilisation d'un toolkit ou d'une bibliothèque logicielle par un logiciel applicatif. [257] |
Bridge | détacher l'interface de sa mise en oeuvre, pour permettre d'utiliser plusieurs mises en oeuvre différentes, y compris utiliser des mises en oeuvres futures sans la nécessité d'utiliser un adapteur.[258] |
Template | ? |
Builder | ? |
Iterator | ? |
Composite | créer la représentation informatique d'un groupe d'entités. Typiquement utiliser pour les noeuds d'une structure de donnée en arbre [259] |
State | ? |
Proxy | utiliser un code externe (provenant d'une autre application / d'un autre ordinateur) au lieu du code interne [260] |
Command | ? |
Interpreter | ? |
Mediator | ? |
Memento | ? |
Visitor | ? |
En architecture informatique, le style à filtres et canaux est un patron de conception ou un programme est subdivisé en petites unités autonomes (les filtres), qui s'échangent des informations par des lignes de communication (les tubes).
Ce style d'architecture était déja utilisé avant d'avoir été formalisé par Meunier en 1995. L'idée est d'avoir une multitude de petits utilitaires (les filtres) et un mécanisme pour connecter les entrées et les sorties de ces filtres. La mise en oeuvre la plus connue est le système d'exploitation Unix, où des filtres tels que cat, grep, sed et awk sont interconnectés.
Le patron à filtre et canaux permet de relier entre eux un ensemble d'utilitaires de manipulation de messages (les filtres) via une suite de tubes. La mise en oeuvre de chaque étape de manipulation de message par un processus séparé permet plus de flexibilité dans l'ordre dans lequel les étapes sont réalisées. De nouvelles manipulations de messages peuvent être obtenues sans grandes modifications, par ajout d'un filtre.
Le style à filtres et canaux est bien adapté au traitement de flux de données, type d'utilisation pour lequel le style classique question-réponse est typiquement inapplicable. Le flux de données doit être concu de manière à pouvoir être lu, traité et écrit de manière incrémentale, plutôt qu'en une opération ou que séquentiellement, de manière à augmenter le débit.
L'opération à effectuer est divisée en plusieurs traitements réalisés par des unités autonomes connectés ensemble à un pipeline. Chaque filtre consomme et produit incrémentalement des informations, et le résultat produit par un filtre est consommé par le filtre suivant. Les filtres sont découplés par l'usage de mémoire tampon qui retiennent les informations échangées. [264]
Comparé à une architecture séquentielle, l'architecture à filtres et canaux, qui permet naturellement le parallélisme et le calcul distribué, est mieux approprié à un système qui traite en continu des flux d'informations. Dans le style à filtre et canaux chaque composant à des entrées et des sorties, les composants (appelés filtres) lisent un flux d'informations à l'entrée et produisent un flux à la sortie. Les canaux servent de conduites pour les flux et transmettent le flux sortant d'un filtre en direction de l'entrée d'un autre filtre.
Jitter est une bibliothèque logicielle en architecture à filtres et canaux qui traite des images matricielles, de l'audio, des images 3D. DirectShow est une bibliothèque de lecture de médias en architecture à filtres et canaux et Khoros est une bibliothèque de traitement numérique du signal également dans cette architecture.
L'architecture à filtre et canaux est facile à décrire, à comprendre, et à mettre en oeuvre. Il est possible de créer une interface graphique qui permet de manipuler de manière interactive les filtres et les canaux. Les systèmes basés sur les filtres sont faciles à maintenir et a améliorer: de nouveaux filtres peuvent être ajoutés, et des filtres améliorés peuvent remplacer les existants. Les filtres étant indépendant, cette architecture permet le parallélisme et le calcul distribué.
Les désavantages de cette architecture sont qu'il est difficile de mettre en oeuvre des itérations: les informations envoyées dans les canaux ne permettent pas de savoir le nombre de fois que l'opération a été effectuée. Et du fait que chaque information sortant doit être transmise à l'entrée d'un autre filtre, les copies fréquentes de grande quantité d'informations peuvent entraîner des pertes de temps. De plus les filtres sont concus en vue d'être des unités strictement indépendantes qui ne se partagent pas d'information d'état et l'architecture à filtres et canaux n'offre pas de mécanisme pour reconfigurer le flux durant les traitements.[265]
Dans de nombreux cas un événement déclenche une suite d'étapes, et à chaque étape il y a un traitement particulier à effectuer. Par exemple lors de la réception d'une commande: la commande arrive sous la forme d'un message, celui-ci peut être crypté, et contenir un certificat; il arrive souvent que les commandes soient envoyées en double. Un flux de commandes cryptées, contenant des doublons doit être transformée en une série de commandes lisibles et sans doublon. Dans les systèmes informatiques hétérogènes des entreprises, il arrive souvent que les différentes étapes soient exécutées par des machines différentes et que chaque étape ne peut être exécutée que par une machine spécifique.
Les compilateurs sont un exemple d'utilisation de l'architecture à filtres et tubes. Ils travaillent étape par étape et le résultat est envoyé à l'étape suivante. Des étapes typiques sont l'analyse lexicale, et l'analyse syntaxique. [268]
Le style à filtres et tubes fait analogie à une usine chimique. Dans laquelle des filtres provoquent des réactions chimiques sur des matières transportées par des tubes. Dans le style à filtres et tubes, un réseau de tubes transporte des informations qui sont traitées par des filtres. La mise en oeuvre la plus connue de ce style est dans le système d'exploitation Unix, en particulier son interpréteur de commandes. Un autre exemple est l'architecture standard d'un compilateur, typiquement celui-ci est composé de différents filtres et les tubes transportent un flux de lettres, de mots et de symboles.
Le réseau de filtres peut être linéaire (pipeline), il peut également comporter des boucles ou des embranchements. Les filtres travaillent de façon asynchrone et on peu ou pas d'informations partagées. Ce sont les échanges d'informations à travers les tubes qui synchronisent les opérations. Les informations peuvent être poussées dans les tubes ou aspirées: dans le premier cas le filtre source dépose une information et ceci provoque un traitement pas le filtre collecteur; dans le second cas le filtre collecteur demande l'information et ceci provoque le traitement par le filtre source.
Les avantages de cette construction du point de vue des performances est qu'elle permet facilement d'effectuer les traitements de façon parallèle, ce qui améliore généralement la performance. Les tubes seuls assurent les communications entre les filtres, les dépendances entre les filtres sont ainsi réduites, ce qui diminue le nombre d'opérations de synchronisation. La subdivision par des filtres peut cependant être un désavantage: si les traitements des filtres sont effectués sur des petites quantitées de données, ceci augmente le nombre de commutation de contexte, ce qui a un impact négatif sur la performance.
Du point de vue de la maintenabilité il y a également des avantages et des inconvénients: La reconfiguration du réseau de filtres et de tubes est aisée et il est possible de modifier ce réseau durant les traitements. De nouvelles fonctionalités peuvent être apportées en ajoutant de nouveaux filtres et en modifiant le réseau. Cependant un changement nécessite souvent la modification de plusieurs filtres. En pratique les systèmes s'échangent typiquement des objets qui représentent des entités du monde réel, et la prise en charge d'une modification de l'objet nécessite la modification de plusieurs filtres travaillant sur cet objet.
La fiabilité d'une construction à filtres et tubes dépends de la topologie du réseau de tubes. La réussite d'une opération dépends de la réussite des tous les filtres impliqués dans cette opération. Contrairement à d'autres constructions ou le composant primaire peut donner un résultat même si les composants secondaires ont échoués.
Chaque composant filtre comporte des entrées et des sorties. Le filtre lit les informations en entrée, effectue une tranformation, puis envoie le résultat en sortie. Le traitement est effectué petit-à-petit, et le filtre produit des résultats en sortie avant d'avoir consommé toutes les informations en entrée. Les filtres communiquent entre eux uniquement à travers les tubes, et aucun filtre ne connait l'identité du filtre qui est branché à l'autre bout du tube. L'ordre dans lequel les opérations ont été effectuées par les filtres n'influence pas le résultat produit par le réseau de filtres et de tubes.
L'interpréteur de commandes Unix (Unix shell) comporte une notation qui permet de relier plusieurs commandes sous forme d'un réseau de filtres et de tubes. La construction à filtre et tubes est également utilisée pour les compilateurs, traitement numérique du signal, et le calcul parallèle. [270]
Liens externes: [271]
Banyan VINES (abrégé de Virtual Networking Systems) est un système d'exploitation et une suite de logiciels de communication pour les réseaux informatique lancé par la société Banyan Systems Inc en 1985. VINES comporte un service de partage de fichiers, de partage d'imprimantes, un service d'annuaire. Il permet d'interconnecter des ordinateurs personnels, avec des mainframe[12].
Le système d'exploitation VINES est basé sur le noyau Unix System V. [272] modifié par Banyan Inc en vue de lui ajouter les capacités d'un système temps réel nécessaire aux outils de communication. [273]
En 2001 Banyan Vines est avec Novell Netware, IBM LAN Server et Microsoft LAN Manager un des environnements réseaux les plus connus.
[274]
Banyan VINES (abrégé de Virtual Networking Systems) est une suite de logiciels de communication pour les réseaux informatique lancé par la société Banyan Systems Inc en 1985. VINES comporte un système d'exploitation basé sur Unix System V[275], des services de partage de fichiers, de partage d'imprimantes, et un service d'annuaire. Il permet d'interconnecter des ordinateurs personnels, avec des mainframe. [276]
Le Virtual Networking System est mis sur le marché en 1985. Il est présenté comme une solution tout en un destinée à fédérer les ressources d'un réseau informatique, dans des réseaux ou chaque ressource est mise à disposition par un produit différent utilisant une technologie différente. VINES offre un manière uniforme d'accéder à toutes les ressources, qui sont inscrites automatiquement dans un annuaire, ce qui les rends plus facile à repérer. Le produit vendu par Banyan comprends le matériel et le logiciel nécessaire accéder à des services via des réseaux utilisant différentes technologies (X.25, Ethernet ou modem), une suite de services réseaux tels que partage de fichiers, partage d'imprimantes, courrier électronique et annuaire, ainsi que le matériel et le logiciel nécessaire pour permettre l'accès à des services offerts par différents ordinateurs, notamment les mainframe IBM. [277]
Banyan VINES a été le premier système d'exploitation réseau pour les ordinateurs x86 jusqu'à la sortie de Novell NetWare. [278]
En 1994 Banyan Systems décide de vendre séparément sa suite de logiciels pour serveurs et son système d'exploitation VINES. Le constat de Steven Wong de la société Gottlieb Steen & Hamilton est que « VINES est un système d'exploitation propriétaire et fermé, qui fonctionne uniquement avec les ordinateurs pour lesquels il a été certifié par Banyan, ce qui limite l'offre de logiciels tiers, notamment de sauvegarde ». Diverses moutures de la suite de logiciels de communication sont mises en vente, destinées aux systèmes d'exploitation Unix AIX, Solaris, SCO Unix et HP/UX. L'objectif est d'obtenir la même image, c'est-à-dire la même suite de services, les mêmes commandes et les mêmes icônes quel que soit le système d'exploitation sous-jacent. [279]
Les version Vines/DTS et Vines/286, sorties en 1986, fonctionnent sur un micro-ordinateur x86 ou m68k. Le produit offre des services de partage de fichiers et d'imprimantes et serveur 3270 pour environ 30 utilisateurs localisés sur 3 réseaux différents.
La version 2.0 est sortie en octobre 1986. [280]
La version 7.0, sortie en 1996, fonctionne avec les systèmes d'exploitation Windows, Mac OS et OS/2. Cette version comporte un service d'annuaire. Un logiciel client permet d'explorer l'annuaire à partir d'un ordinateur exécutant Microsoft Windows. Cette version supporte des disques durs de 16 Go de capacité (contre 2 Go précédemment). Une suite de services Internet (web, FTP, DNS et DHCP) est disponible en option. [282]
Le serveur Vines fonctionnne avec les systèmes d'exploitation équipés du noyau de Unix System V 3.2 (IBM AIX, HP/UX, Solaris), ce qui limite le choix de matériel avec lequel il peut être utilisé. Le logiciel peut être utilisé uniquement avec les services de Banyan. L'auteur promet en 1994 que la prochaine version sera équipée d'une interface graphique.
Le protocole de VINES (abrégé de Virtual Integrated Network System) est dérivé du protocole XNS créé par Xerox et est reconnu par les produits réseau de Cisco, ceci suite à un accord de coopération entre Cisco et Banyan. [284]
En 1997, suite au manque de logiciels applicatifs pour ce système d'exploitation, de nombreux utilisateurs de Bayan Vines recherchent à s'en éloigner. Des sociétés concurrentes comme Microsoft et Novell mettent sur le marché des produits visant à faciliter les opérations.[285]
En 1997, des clients - parfois de longue date - de Banyan, frustrés par le manque de logiciels applicatifs pour VINES et soucieux concernant l'avenir de la société, recherchent à se passer de VINES. Parmi ces clients il y a des grandes entreprises et des agences du service public, qui possèdent des dizaines de serveurs VINES, et pour lesquels le remplacement de ceux-ci demande beaucoup de temps et d'argent. Les constructeurs concurrents tels que Microsoft et Novell mettent sur le marché des outils informatiques destinés à faciliter le remplacement de serveurs VINES par un autre produit, et les clients font appel à des sociétés de services en informatique pour les aider dans les opérations. Durant l'année 1997 la société Trellis Network Services effectue simultanément entre 40 et 50 missions au services de clients qui recherchent à se passer de Banyan VINES. 95% des clients optent pour le remplacement graduel des serveurs VINES. Les outils fournis par Microsoft et Novell permettent de récupérer les inscription qui se trouvent dans l'annuaire de VINES, et de les transférer dans un autre annuaire ou une base de données; d'autres outils permettent également de récupérer les boîtes au lettres de courrier électronique des serveurs VINES et les transférer vers un autre serveur de courrier. Certains clients, décus des résultats, et du coût - sous-estimé - des opérations, installent alors les services de Banyan sur leurs serveurs Windows NT. [286]
En 1987, le magazine InfoWorld décrit VINES comme « un des secrets les mieux gardés de l'industrie informatique ». [287]
En 1987 Banyan Systems vends également des serveurs pré-équipés avec le système d'exploitation VINES. [288]
Depuis 1989 Oracle Database fonctionne sur le système d'exploitation VINES, suite à une alliance entre les deux producteurs. [289]
En 1999 la société Banyan est devenue ePresence, un fournisseur d'accès Internet et déclarait que les produits VINES sont dépassés. [290]
Les protocoles
[modifier | modifier le code]La suite de logiciels de VINES est basée sur le principe du client-serveur et utilise une pile de protocoles réseaux propriétaires, définis par Banyan Inc et dérivés de la pile de protocoles XNS de Xerox. Les différents protocoles de VINES se placent entre les niveaux 3 et 7 du modèle OSI, qui comporte 7 niveaux. Il y a deux protocoles propriétaires équivalents du ARP et du RIP.
Le protocole VIP (VINES Internetworking Protocol) sert à interconnecter des réseaux, il est basé sur des adresses de 48 bits: 32 bits sont utilisés pour le numéro du réseau et 16 bits pour le numéro de l'ordinateur sur son réseau. Quand au protocole ICP (Internetworking Control Protocol), il est utilisé pour effectuer du routage, et signaler des erreurs de transmission. Lorsqu'un client se connecte à un réseau VINES, il envoie une demande à tout les serveurs (broadcast), et s'associe automatiquement au réseau du premier serveur qui répond à la demande, une technique également utilisée avec le protocole AppleTalk.
VINES comporte 3 protocoles de niveau 4 sur le modèle OSI, qui permettent d'envoyer des paquets isolés, des messages composés au maximum de 4 paquets, ou des flux composés d'un nombre illimité de paquets. Les protocoles de niveau 5 à 7 sont basés sur le modèle des remote procedure call et le protocole NetRPC et sont destinés au partage de fichiers, d'imprimantes, ainsi qu'au service d'annuaire StreetTalk de VINES.
En informatique et en télécommunications, un serveur est un dispositif informatique matériel et/ou logiciel qui offre des services. Les plus courants sont l'utilisation en commun de moyens informatique (imprimantes, disque durs, bases de données), la communication par courrier électronique, messagerie instantanée (anglais chat) ou téléphonie, l'échange de fichiers, la publication de documents sur le world wide web et la mise à disposition de logiciels applicatifs (optique software as a service).
Un serveur fonctionne en permanence, répondant automatiquement à des requêtes provenant d'autres dispositifs informatiques (les clients), selon le principe dit client-serveur. Le format des requêtes et des résultats sont normalisés et se conforment à des protocoles réseaux.
Les serveurs sont utilisés par les entreprises, les institutions et les opérateurs de télécommunication. Ils sont courants dans les centres de traitement de données et le réseau Internet.
D'après le cabinet Netcraft, il y a en mars 2009 plus de 220 millions de serveurs web dans le monde, et leur nombre est en augmentation constante depuis l'invention du World Wide Web en 1995[13].
Histoire
[modifier | modifier le code]Les systèmes informatique distribuées, dans lesquels plusieurs ordinateurs co-opèrent, sont devenu réalisables au milieu des années 1970, suite à la baisse de prix et l'augmentation de la puissance des ordinateurs. Les prix en baisse des petits mini-ordinateur ou des micro-ordinateurs permettait alors à une institution d'en acquérir plusieurs. La recherche s'oriente alors vers deux axes différents, qui sont l'utilisation de ressources communes telles que les imprimante et les disque durs, et l'utilisation de la puissance de calcul des différentes machines par répartition des tâches. [292]
En 1976 le US Postal Service, la poste des États-Unis, étudie les technologies qui permettraient d'envoyer des messages, et qui - contrairement au fax et au télégramme - n'utilisent pas de papier. Ils constatent alors que les services de poste du Canada, de l'Allemagne de l'Ouest, et du Royaume Uni ont déja des moyens d'envoyer du courrier électronique. [293]
Les réseaux locaux
[modifier | modifier le code]En 1980, Xerox met sur le marché un ensemble destiné à « créer, modifier, enregistrer, imprimer et distribuer » des données dans un réseau local Ethernet. L'ensemble est un kit logiciel et matériel qui comporte 4 serveurs. Ils permettent aux ordinateurs connectés au réseau local d'imprimer des documents, d'enregistrer des fichiers. Ils permettent également d'échanger des fichiers et du courrier électronique avec une installation similaire ailleurs dans le monde. [294]
A la même période, ou le réseau local est un sujet d'actualité, Nestar met sur le marché une solution qui offre les mêmes possibilités que les serveurs de Xerox. Cette solution ClusterOne est basée sur des ordinateurs personnels Apple II, tous identiques. Un des ordinateurs est utilisé comme serveur de fichier et un autre comme serveur d'impression.[295]
En 1984, sur le marché naissant des stations de travail, Sun Microsystems met sur le marché le Network file system (abr. NFS), un service qui permet l'accès aux fichiers de différents ordinateurs d'un réseau local (abr. LAN). La documentation du protocole réseau est immédiatement rendue publique, en vue de permettre aux autres constructeurs de créer les logiciels nécessaires pour offrir ou exploiter ce service avec leurs propres ordinateurs. Quatre ans plus tard il existe plus de 100 produits qui fournissent / exploitent le service NFS. [296]
En 1987 AT&T publie la troisième édition de ses livres de spécification techniques System V relatifs au système d'exploitation Unix. Le livre numéro 3 comporte désormais un chapitre concernant les serveurs. Le livre décrit une série de dispositifs informatiques destinés à l'utilisation partagée des imprimantes et des fichiers. Il décrit également une suite de composants destinés à mettre en oeuvre des services réseau qui soient indépendants des moyens de télécommunication utilisés. [297]
En 1989 70% des serveurs sont utilisés pour du partage de fichiers, 34% comme serveur de bases de données et 10% pour du courrier électronique. Apparu quelques années avant, le service de bases de données se place comme concurrent du partage de fichiers, offrant un service de stockage d'informations plus efficace, plus sûr, et plus rapide.
Les services en ligne
[modifier | modifier le code]En juin 1979, The Source Telecomputing Corporation met à disposition une suite de services informatiques destinés aux petits groupes d'utilisateurs. Les services mis à disposition sont des banques de données, du courrier électronique, des nouvelles, les horaires des vols, du commerce électronique, des prévisions météo ainsi que d'autres services. Par la suite, d'autres société ont fait de même, par exemple Telenet, Compuserve ainsi que les services de Dow Jones et de Lockheed. [299]
Au début des années 1980, les premiers serveurs de bulletin board system (abr. BBS) peuvent être exploités par les utilisateurs à l'aide d'un micro-ordinateur (TRS-80, Apple II, ...), ainsi qu'un téléphone et un émulateur de terminal. De tels serveurs permettent non seulement à l'appelant d'accéder à différents services avec peu de moyens, mais également aux différents usagers de s'envoyer des messages, poster des annonces, dialoguer entre eux et s'échanger des fichiers. [300]
L'Internet
[modifier | modifier le code]En 1978 Le Defence advanced research projects agency (abr. DARPA), bureau de recherche du département de la défense des États-Unis étudie la possibilité d´internetworking: relier différents réseaux locaux dans un réseau de réseaux. Le DARPA relie entre eux les universités et les instituts de recherche des États-Unis. Cinq ans plus tard le réseau relie de nombreuses universités des États-Unis, la majorité des ordinateurs connectés utilisent le système d'exploitation Unix, le réseau est alors principalement exploité par des étudiants qui l'ont appelé Internet. Le département de la défense abandonne alors ce projet devenu trop public. [301]
Au début des années 1990 apparaissent les premiers fournisseur d'accès Internet [302], des serveurs fournissent sur l'Internet des services tels que Gopher, World wide web, le courrier électronique ou le transfert de fichiers FTP et [303] et en 1994 plus de 5000 réseaux sont interconnectés, reliant entre eux plus d'un million d'ordinateurs (serveurs et clients) [304].
Depuis 1989, [305] les technologies apportées à l'Internet passent pas un procédé démocratique d'acceptation mutuelle organisé par l'Internet Engineering Task Force (abr. IETF) - un consortium d'industriels. Pour qu'un service soit reconnu officiellement comme service Internet, son protocole doit avoir été publié sous la forme d'un RFC et être accepté par les membres de l´IETF. [306] Ce procédé de standardization aide à obtenir une large audience des technologies ajoutées à l'Internet. [307]
Le client-serveur et le downsizing
[modifier | modifier le code]Le principe du client-serveur consiste à diviser une application informatique en deux processus exécutés par deux appareils différents reliés à un réseau. La communication entre les deux processus s'effectue selon un schéma demande/réponse - un processus demande, l'autre réponds. Techniquement les deux processus peuvent être exécutés par le même appareil, l'intérêt réside cependant dans la possibilité de les faire exécuter par des appareils différents. Le principe de client-serveur était une nouveauté à la mode dans les années 1990, ou il était parfois considéré comme un buzzword. [308]
Le principe de la relation client-serveur était déja connu en 1987: le serveur étant le fournisseur d'un service tandis que le client est celui qui exploite. Tout ordinateur peut être à la fois serveur et client. [309] Ce principe intéresse les fournisseurs de logiciels pour les bases de données. Ashton-Tate, Microsoft et Sybase travaillent en collaboration au développement d'un système de gestion de base de données selon le principe du client-serveur. En même temps que IBM et Oracle Corporation mettent sur le marché de tels produits. [310]
Les systèmes informatique client-serveur ont connu une croissance explosive au début des années 1990. Contrairement aux systèmes informatiques précédents qui étaient alors équipés d'un mainframe - ordinateur central de grande puissance - manipulé depuis des terminaux, un système informatique en client-serveur demandait un matériel moins spécifique et moins couteux: un serveur ayant une puissance de calcul réduite, et des ordinateurs personnels ordinaires. De plus l'émergence de produits ouverts, basés sur des standards industriels évitait à l'acheteur de devoir acquérir la totalité de son système informatique auprès du même fabricant. Ces avantages sont à l'origine du downsizing dans les années 1990: le replacement progressif des mainframes couteux et volumineux par des serveurs plus petits, meilleur marché et qui travaillent de concert avec des micro-ordinateurs.[311] [312] [313]
Les utilisations
[modifier | modifier le code]Serveur d'applications
[modifier | modifier le code]HTML, le format des documents du world wide web permet facilement d'imiter l'interface graphique d'un logiciel.[314] Dès 1995 apparaissent les premières technologies pour réaliser des sites web interactifs - des sites dans lequels le contenu des documents HTML diffère en fonction des opérations effectuées à l'aide du navigateur web. Dans les technologies Server Side Includes et Common Gateway Interface (abr. CGI) un programme est exécuté à chaque fois qu'un document est envoyé au client. [315] Ces technologies se révèlent cependant insuffisantes pour réaliser des logiciels en architecture trois tiers - dans lesquels la puissance de calcul d'un serveur d'avant-plan (tiers du milieu) est utilisée pour réaliser des traitements complexes.[316]
Le but de la construction en trois tiers est de retirer du logiciel client des traitements complexes et spécifiques à un domaine d'activité, pour les faire exécuter par un serveur dédié, ou ils seront plus facile d'accès et pourront plus facilement être maintenus et améliorés. Les serveurs d'application sont des outils de développement (frameworks) spécialement concus pour faciliter la programmation de sites web interactifs qui réalisent des traitements complexes et imitent l'interface graphique d'un logiciel applicatif.[317] Ils comportent généralement un kit permettant de connecter le logiciel avec un serveur de base de données, et un outil pour créer des interfaces graphiques sous forme de documents au format HTML. [318] L'utilisation du navigateur web comme logiciel client évite à l'utilisateur de devoir acquérir et installer un logiciel client spécifique, et permet la disponibilité immédiate du serveur à une large audience.[319] En 1998 il existe plus de 40 produits de ce type.[320]
Un logiciel de serveur d'application est un framework intermédiaire entre les clients et la source de données, qui exécute des applications selon le principe du trois tiers. La fonctionalité principale d'un serveur d'application est d'assurer que les applications sont accessibles depuis les clients, fiables et scalables. En connectant des applications à un logiciel serveur en protocole HTTP (le protocole du world wide web), un serveur peut être utilisé pour contrôler des application web. En 1998 il existe plus de 40 produits de ce type.
[321]
Un serveur d'application ne fait ni du partage de fichier ni du partage d'imprimante. [322]
1991 - Un serveur d'application est un dispositif réseau dédié, qui fournit un service spécifique en utilisant la puissance de calcul et la capacité de stockage d'un ordinateur dédié, et en exploitant les services offerts par d'autres serveurs. [323]
1998 - Les produits de type serveur d'application sont des outils de développement d'application web: les utilisateurs clients n'ont pas besoin d'un logiciel client ou d'un plugin particulier pour manipuler l'application. Ils comportent généralement un kit qui permet de connecter les applications avec des serveurs de base de données ainsi qu'un outil pour créer des interfaces graphiques utilisant le format HTML - le format des documents du world wide web. [324]
L'idée de créer des applications web apparait en 1993, et est mentionnée comme une solution adaptée au commerce électronique. [325]
1995 - Un site web est dit interactif quand les manipulations effectuées par l'utilisateur influencent le contenu des documents envoyés par le serveur web. Les premières technologies qui permettent de réaliser des sites interatifs sont Server Side Includes et Common Gateway Interface (abr. CGI). [326]
Spider 1.0 est un produit mis sur le marché en 1995, qui permet d'accéder aux informations stockées par un serveur de base de données à l'aide d'un navigateur web. Avec ce produit, quelques opérations de programmation suffisent pour réaliser une application d'avant-plan (front-end) pour manipuler le contenu d'une base de données. Spider crée automatiquement des documents au format HTML à partir du contenu de la base de données, puis les envoie au client à la manière d'un serveur web. [327]
1999 - HTML, le format des documents du web permet assez facilement d'imiter l'interface graphique d'un logiciel applicatif. [328]
1999 - Dans une application informatique en architecture trois tiers, le tiers du milieu exécute des traitements au service du client. Le but de cette construction est de sortir les traitement complexes du client, pour les faire exécuter par un serveur sur lesquels ils peuvent plus facilement être maintenus et améliorés. Les premières technologies pour les serveurs web interactifs tels que CGI étaient inadéquats pour les traitements d'une certaine complexité et c'est à ce créneau que sont destinés les serveurs d'applications web, des outils de programmation spécialement concu pour faciliter le développement de sites interactifs complexes, qui imitent l'interface graphique d'une application. [329]
Divers
[modifier | modifier le code]Le X Window System est un environnement graphique client-serveur lancé par le MIT en 1986. Il sert à afficher sur un même écran les interfaces graphiques de différentes applications, qui peuvent ensuite être manipulées à l'aide d'une souris. L'application du principe du client-serveur dans ce produit est atypique: selon le sens usuel un utilisateur manipule le client pour exploiter le serveur, tandis que sur le X Window System l'utilisateur manipule le serveur pour exploiter les clients.[330]
Le partage de fichiers consiste à enregistrer des fichiers dans un emplacement central - tel les disque durs d'un serveur - et permettre l'utilisation commune de ces fichiers par plusieurs personnes à partir de plusieurs clients. Network File System (abr. NFS) est un service de partage de fichier lancé par Sun Microsystems, et Server Message Block (abr. SMB) est un service lancé par Microsoft, ces deux services permettent de manipuler des fichiers présents sur des serveurs exactement comme si ils se trouvaient sur l'ordinateur client. File Transfer Protocol (abr. FTP) est un service Internet qui permet de parcourir les fichiers enregistrés sur un serveur, de les télécharger ou d'envoyer des fichiers au serveur. Le partage de fichiers était le service le plus courant - 70% des serveurs - en 1990. [331] [332]
Le partage de fichiers en pair à pair est une application de partage de fichier décentralisé, ou chaque client peut utiliser des fichiers qui sont enregistrés sur d'autres clients, et aussi mettre ses propres fichiers à disposition des autres clients. Napster et BitTorrent sont des services de partage pair-à-pair. [333]
Dans les enterprises, il y a souvent plusieurs ordinateurs, qui utilisent en même temps une imprimante branchée à un des ordinateurs du réseau. Le partage d'imprimantes était déjà pratiqué en 1985. [334] Ceci permet d'économiser l'achat d'un matériel onéreux, et qui est souvent inutilisé pendant de longues périodes. [335] Certaines imprimantes sont équipées d'un serveur incorporé et se branchent directement au réseau. [336] Le service de partage de fichier Server Message Block (abr. SMB) permet également le partage des imprimantes. Common Unix Printing System (abr. CUPS) est un service de partage d'imprimantes. D'autres services utilisent le protocole Internet Printing Protocol (abr. IPP) ou Line Printer Daemon protocol (abr. LPD). [337]
Le stockage d'information dans des bases de données est un service d'arrière-plan (backend) offert par différents serveurs. Le client émet une demande formulée dans le langage normalisé Structured Query Language (abr. SQL), puis la transmet au serveur.[338] Les serveurs de base de données s'utilisent avec un logiciel d'avant-plan (frontend) qui fait office de client, d'interface graphique, ou offre un autre service. [339] Il n'existe pas de technologie normalisée pour exploiter les services d'un serveur de base de données, et chaque firme fournit un kit pour connecter un logiciel d'avant-plan avec les serveur de base de données produit par la firme, [340] un kit qui s'utilise avec des middleware comme ODBC ou JDBC. En architecture trois tiers un service (e-commerce, médias, forums, ...) est fourni par un serveur d'avant-plan qui lui-même exploite les services d'un serveur de base de données en arrière plan. [341]
Le courrier électronique est un service d'envoi de courriers rapides dérivé du télégramme et du télex, mis en place par les services de poste en 1975.[342] Depuis 1980 les réseaux Usenet, Fidonet, Bitnet et Internet sont utilisés pour transporter du courrier électronique. Dans ces réseaux, chaque serveur appelle à intervale régulier un autre serveur à l'aide d'un modem, pour qu'ils s'échangent du courrier. [343] Simple Mail Transfer Protocol (abr. SMTP) est un protocole utilisé par les serveurs de poste pour s'échanger du courrier électronique, et Post Office Protocol (abr. POP) est un protocole utilisé par les clients pour récupérer les messages en attente dans les serveurs de courrier. [344] et X.400 est un standard déposé par ISO en 1984, concernant le format de données du courrier électronique.[345]
Le world wide web (abr. WWW ou Web) est un dispositif informatique créé en 1990 dans le but de faciliter l'accès à l'information. Il offre à l'informateur le moyen de mettre à disposition ses informations, et offre aux usagers les moyens de la retrouver facilement [346]. Le service utilise le protocole HTTP, et un logiciel client, le navigateur web, offre une manière uniforme d'accéder aux informations mis à disposition par différents services selon les protocoles HTTP ainsi que Gopher, WAIS, FTP ou NNTP. [347] Les informations souvent mises à disposition par les serveurs web concernent l'économie, la finance, la formation, la santé, la culture, la musique, l'actualité, le sport, la vente, les voyages, la politique et la pornographie. [348]
En 1998 le world wide web est le service dominant de l'Internet, à l'origine de 75% de l'activité du réseau, au coté du transfert de fichiers FTP et du courrier électronique.[349], dix ans plus tard il est suivi de près par le partage de fichiers en pair à pair. [14][350] Initialement utilisé passivement pour rechercher et consulter de la documentation, le world wide web a évolué en 2005 vers Web 2.0, ou il est devenu un moyen technique de réaliser des services où le lecteur devient acteur et peut non seulement lire le contenu, mais également le modifier ou en ajouter - Facebook, YouTube ou Wikipédia sont des exemples de tels services. [351] [352]
Depuis 1995, le world wide web est utilisé pour faire du commerce. des sociétés comme Amazon.com mettent leurs produits en vente sur un serveur, le consommateur y recherche ce qui l'intéresse, puis commande, envoie le numéro de sa carte de crédit, et receoit la marchandise quelques jours plus tard. Cette utilisation business to consumer vient compléter l'échange de données informatisé déjà effectué depuis plusieurs années entre les sociétés commerciales (détaillants, producteurs, revendeurs,...). Le commerce électronique permet de diminuer les coûts de la vente, mais pose un problème de sécurité: la nécessité pour le consommateur d'envoyer des informations confidentielles sur un réseau public. [353] En 2000 80% des ventes effectuées en commerce électronique concernent des produits informatiques, du divertissement, des voyages et des produits discount. [354]
- forums
- messagerie instantanée
- échange de fichiers
- game server
La sécurité informatique
[modifier | modifier le code]Les serveurs web, les serveurs de fichiers et de base de données stockent de grandes quantités d'informations. Ils sont équipés de moyens de protection visant à assurer la confidentialité, la disponibilité et l´authenticité des informations: Que les informations sont accessibles uniquement aux personnes concernées, qu'elles soient accessibles à tout moment, et dépourvues de falsifications.
Les informations étant numérisées et stockées dans du matériel informatique à l'aide de logiciel, la sécurité vise à protéger les informations des attaques, et vise également à protéger le matériel et le logiciel qui les manipulent.
Le vol d'informations est souvent cité comme le premier but visé par la sécurité informatique. Il concerne en particulier les défenses contre le vol d'informations personnelles telles que les numéros de carte de crédit.
Une attaque déni de service vise à utiliser la totalité des ressources matérielles d'un serveur et l'empêcher de répondre aux demandes. Spoofing Attaque de l'homme du milieu
Firewall serveur proxy Honeypot [355]
Les possibilités d'accès aux informations contenues dans le serveur sont réduites au strict minimum nécessaire à chaque usager, en vue de donner le moins possible d'opportunités de compromettre la confidentialité et l'authenticité des informations. Les mesures de protections sont limitées par le confort d'utilisation du serveur: si les mesures sont trop lourdes et encombrantes, ceci diminue l'utilisabilité du serveur et les usagers ont tendance à les contourner.
La sécurité peut être assurée par une cascade de barrières de protection : réseau, système d'exploitation et logiciel serveur. Si une des barrières tombe, alors la suivante prends le relais. Les moyens de défense n'assurent jamais une protection absolue des informations, cependant l'effort nécessaire pour arriver à faire tomber les défenses est supérieur à la plus-value d'une attaque réussie.
Les mesures de sécurités prises dépendent du niveau de confidentialité requis, des services offerts par le serveur, de sa localisation (réseau Internet ou entreprise), et des risque encourus. La protection est souvent assurée par un dispositif médiateur, qui arbitre l'accès aux informations. Le firewall et le proxy sont des dispositifs médiateurs courants. Les ordinateurs serveurs peuvent fournir un service unique, dans le but de diminuer les possibilités d'attaque et leur impact sur le système informatique.
Les administrateurs systèmes, ou les administrateurs réseau sont les personnes responsables de la préparation, l'installation et la maintenance des serveurs, et une de leurs activités quotidienne est la lutte contre les attaques et le maintien d'un niveau de sécurité élevé des serveurs. Ils travaillent notamment à l'application régulière de patches visant à corriger les failles de sécurité des logiciels présents sur les serveurs. Ils surveillent l'état de santé et l'activité du serveur, à la recherche d'éventuelles anomalies, et effectuent sur demande des tests des mécanismes de défense. [356]
Les attaques
[modifier | modifier le code]Une attaque par déni de service (anglais denial-of-service abr. DoS) vise à empêcher un serveur de répondre aux demandes des clients. Ce type d'attaque se fait en empoisonnant les communications, en surchargeant le serveur, qui n'est alors plus à même de répondre aux demandes, en provoquant un encombrement du réseau ou un crash du serveur. [357]
L'usurpation d'adresse (anglais spoofing) vise à obtenir l'accès à des informations confidentielles en usurpant l'identité d'un ordinateur client. L'attaque se fait pas falsification des tables de correspondance propre aux protocoles ARP et DNS.[358]
Les défenses
[modifier | modifier le code]Le mécanisme de protection le plus courant est le contrôle d'accès. C'est un mécanisme qui identifie l'utilisateur, sur la base de mots de passe, des cartes à puce, de cryptogrammes ou de biométrie. L'utilisation des mots de passe est le moyen le plus courant d'obtenir une protection minimale, sans aucun équipement particulier. [359]
client - serveur
[modifier | modifier le code]client-serveur est un modèle de construction d'un système informatique. Dans ce modèle les calculs sont effectués par deux processus autonomes: le client et le serveur. Le client est le processus qui demande des services au serveur, et ce dernier est le processus qui fournit les services demandés. Les processus client et serveurs peuvent résider sur le même ordinateur, ou sur deux ordinateurs différent reliés par un réseau informatique. Quand plusieurs clients et plusieurs serveurs résident dans un réseau, alors chaque client peut faire des demandes à plusieurs serveurs et chaque serveur peut répondre à des demandes provenant de plusieurs clients.
Dans un modèle à client lourd, la majeure partie des fonctionalités est prise en charge par le client. Un réseau comportant un grand nombre de clients lourds peut devenir un casse-tête pour lors des opérations de maintenance.
Dans le modèle à client léger (ou serveur lourd) les fonctionalités majeures sont prises en charge par le serveur. Les services fournis par le serveur sont moins techniques et plus orientés vers une utilisation en particulier. C'est la tendance actuelle. Le client est souvent qu'un navigateur web ordinaire. L'avantage de cette construction est que les modifications de l'application sont plus faciles parce que la plupart du temps seul le serveur est amélioré. [360]
caractéristiques techniques
[modifier | modifier le code]Dans les ordinateurs du marché des serveurs, l'accent est mis sur le débit (nombre de réponses données par unité de temps), la disponibilité et la scalabilité - capacité d'adaptation à une augmentation de la demande. Les serveurs s'occupent de plusieurs utilisateurs simultanément, et ont besoin d'une puissance de calcul supérieure à celle des ordinateurs personnels.[361]. Les serveurs jouent un rôle clé dans de nombreux réseaux et sont souvent logés dans des locaux ventilés et sécurisés.[362]
L'objectif visé est la disponibilité continue du service, 24 heures sur 24. Les constructeurs de matériel affirment souvent que l'ordinateur peut assurer une disponibilité de 99.999% (soit moins de 30 secondes d'interruption par année). La disponibilité effective est cependant moins élevée. Les pannes dues au logiciel sont plus fréquentes que celles dues au matériel, et leur nombre a tendance à augmenter avec l'évolution technologique: la quantité de logiciel augmente et sa qualité moyenne stagne. La qualité du matériel, la qualité du logiciel, autant que la qualité des procédures de manipulation du serveur ont un impact sur la disponibilité des services.[363]
Les composants du matériel dont les caractéristiques ont un effet sur le débit du serveur sont l'interface réseau, les disques durs, les bus, la mémoire, ainsi que la puissance de calcul du ou des processeurs. Le débit du serveur ne sera jamais plus élevé que celui du plus faible des composants.[364] Le débit est souvent limité par la connexion au réseau. Les serveurs peuvent être équipés de plusieurs processeurs, ce qui leur permet de servir plus de client, accélère le traitement des requêtes, et augmente le débit.[365] Des journaux d'activité permettent de déceler des erreurs, dues à un débit trop bas ou des temps de réponse trop longs.[366]
La scalabilité du matériel d'un serveur permet d'augmenter le débit du serveur en ajoutant des pièces, en cas de manque de scalabilité, une demande accrue posera des problèmes technique et il sera alors nécessaire de remplacer le serveur. Le coût de remplacement sera le coût d'acquisition du matériel, auquel s'ajoute le coût des travaux de bascule du serveur, et le manque à gagner du à l'indisponibilité du service.[367]
Matériel
[modifier | modifier le code]Un serveur peut être de la taille d'une petite boîte ou d'un microordinateur alors qu'un autre est de la taille d'un mini-ordinateur, voire d'un mainframe. Le mot serveur ne désigne pas la taille, mais le rôle joué par un appareil sur un réseau. La taille de l'appareil sera choisie en fonction de la charge de travail, qui dépends du nombre d'utilisateurs servis au même instant. Un micro-ordinateur peut être suffisant pour offrir des services de partage de fichiers et d'imprimantes sur un réseau qui comporte une dizaine de clients, alors qu'un mainframe peut être nécessaire pour mettre à disposition une volumineuse base de données à plusieurs milliers de clients. [368] Par exemple le serveur central de Whirlpool est un mainframe qui s'occupe de 73'000 employés répartis dans 70 sites dans le monde entier.[369]
En 2009 le coût d'acquisition d'un ordinateur pour serveur peut aller de 1000 dollars (micro-ordinateur) à 500'000 dollars (mainframe). [370] La scalabilité verticale des ordinateurs du marché des serveurs permet d'y ajouter des composants en vue d'augmenter après coup leur capacité, ce qui leur permet de s'occuper de plus de clients, stocker plus d'information et traiter plus de demandes en moins de temps. [371]
Outre les ordinateurs, les serveurs existent également sous forme d'appareils prêts à l'emploi et offrant un service unique. Ces appareils peu couteux, dont les plus petits tiennent au creu de la main, mettent en oeuvre des services tels que le partage d'imprimante ou de fichier. Ils possèdent souvent un serveur web incorporé, permettant de manipuler l'appareil. Ils sont destinés aux particuliers et petites entreprises et sont vendus en grande distribution. [372] Les server appliance quand à eux comportent un boitier unique qui met en oeuvre plusieurs services tels que partage de fichiers, courrier électronique, world wide web, ainsi que des fonctions réseau tel que le pare-feu et le réseau privé virtuel et peuvent servir jusqu'à 50 clients. Les serveurs blade sont des serveurs composés d'un circuit imprimé unique, qui s'installe dans un chassis. Le boitier chassis comporte plusieurs emplacement, permettant d'y placer plusieurs serveurs blade. [373]
Un network attached storage (abr. NAS) est un dispositif qui sert uniquement au partage de fichiers. Il peut être sous la forme d'un boitier à fonction unique, d'un server appliance ou d'un ordinateur. Il n'a souvent pas de prise pour brancher écran et clavier, et comporte un server web incorporé, qui sert à manipuler l'appareil. [374]
La popularisation de l'Internet a permis de mettre des services à disposition d'un très grand nombre d'usagers. En raison de la taille sans précédent du réseau Internet, les services les plus populaires ont du pour la première fois être construit en vue de supporter plus d'un million de requêtes simultanées. Ces besoins ont posé un véritable challenge en nécessitant une puissance de calcul et un débit de réseau sans précédent et les applications Internet sont devenues un des moteurs de la recherche et de l'industrie informatique. [375]
les sites web de grande dimension sont souvent mis en oeuvre par un cluster - un groupe de serveurs. Par exemple le moteur de recherche de Google est composé de 6000 micro-ordinateurs x86, ce qui permet de traiter un millier de demande par seconde et parcourir un million de pages du catalogue. [376]
La construction client-serveur est courante sur Internet. Un serveur peut s'occuper de centaines voire de milliers de clients. Pour les services de grande dimension, qui servent des milliers de clients, le travail du serveur est répartis dans un arrangement comme les ferme de serveurs. [377]
La capacité des serveurs est choisie en fonction de leur charge de travail. La charge peut changer à tout moment et les serveurs peuvent être surdimensionés de manière à supporter momentanément 50% de travail en plus. Des projections et des prévisions permettent d'estimer une augmentation ou une diminution de la charge de travail à moyen terme. [378]
Les facteurs qui peuvent entraîner une variation de la charge de travail d'un serveur sont la popularité, la maturité et les modifications techniques. L'augmentation de la popularité d'un serveur, et de la charge de travail des usagers entraine une augmentation de travail du serveur. Dans une application installée depuis un certain temps, les journaux d'activité se remplissent, de même que les bases de données - initialement vides, tandis que les utilisateurs se familiarisent avec l'application et leur manipulations deviennent plus rapides et plus complexes. Ces modifications entrainent une augmentation de la charge de travail. Les changements techniques tels que l'installation d'un logiciel applicatif ou un middleware, qui apportent des nouvelles fonctionalités et des améliorations aux fonctionalités existantes, peut provoquer une augmentation ou une diminution de la charge de travail. [379]
Système d'exploitation
[modifier | modifier le code]Les premiers systèmes d'exploitation pour serveurs ont été Banyan Vines et Novell NetWare, ils ont été développés spécialement dans le but de fournir des services de partage de fichiers et d'imprimante, ainsi que les fonctions de contrôle d'accès, qui n'existaient pas dans les produits concurrents. Il y a aujourd'hui très peu de différence entre un système d'exploitation pour serveur et un pour les clients. [380]
Dans les systèmes d'exploitation de la famille Unix les seules différences entre les modèles pour serveur et ceux destinés aux clients sont que les modèles pour serveurs sont adaptés à la puissance de calcul de ces ordinateurs, et que les contrôles d'accès y sont plus sévères.[381] Dans la famille Windows les modèles pour serveurs sont équipés du même noyau et du même environnement de bureau que les modèles pour les ordinateurs personnels; les modèles pour serveurs comportent en plus des fonctions et des utilitaires en rapport avec les réseaux informatique et les serveurs.[382]
Tandis qu'un système d'exploitation pour ordinateur personnel est prévu pour offrir la meilleure performance au logiciel qui est actuellement manipulé par l'utilisateur, un système d'exploitation pour serveur est prévu pour répartir la puissance de calcul entre les différents utilisateurs qui exploitent le serveur.[383] Les fonctionalités caractéristiques des systèmes d'exploitation pour les serveurs sont la prise en charge de la connexion au réseau (pile de protocoles), différents services tels que le partage de fichiers, d'imprimantes et le service DNS. Ces systèmes d'exploitation offrent également des fonctions fréquemment utilisées avec les serveurs tels que le contrôle d'identité, le contrôle d'accès, la fonction de proxy, de firewall, le protocoles DHCP ainsi que et les mécanismes de sauvegarde et de tolérance de faute.
Les systèmes d'exploitation populaires sur les serveurs sont la série Windows NT de Microsoft (Windows NT, Windows 2000, Windows 2003 et Windows 2008), Novell NetWare et la famille Unix, parmi lesquels il y a Linux et Mac OS X de Apple. [384][385]
Brut
[modifier | modifier le code]- scalabilité
- débit (throughput)
- sécurité
- disponibilité
- web server is disk-intensive
- turn off GUI [386]
scalability [387]
server need to be more powerful than clients, because servers must be able to handle many clients at same time. Network connection is more likely than hardware to be the limiting factor. Server tuning is the subject of many books.[388]
processor, motherboard, memory, hard drive, and interface card are important components. Servers play key role in networks, they are located in well-ventilated and secured rooms. Several processor allow the server to handle many clients at the same time, result lower response time and increased throughput. [390]
database server need fast disk, reliable, RAID, plenty of RAM and fast CPU, UPS [391]
on-line hardware replacement of PCI cards on HP-UX machines [392]
virtualisation. for application that do not hog resources [393]
common cause of crashes is software: application, web server and database. [394]
focus on availability and disaster recovery [395]
fault tolerant [396]
important considerations are memory, network card, hard drive space, speed and number of CPUs. Server will be as fast as the slowest component. Daily check on server logs may help to determine if a more powerful server is needed or will be needed in the future. [397]
What matter is total availability (100%). Hardware vendors claim a 99.999% availability. But software failure are more frequent than hardware failure: The amount of software in a system is increasing while quality remain the same. All hardware quality, standard software quality, in-house software quality, and operating procedures quality impact availability.
Scalability matters. When a server does not have good scalability, the practical result is when new needs arise, the server can not adapt and need to be replaced. Replacement have an additional cost: someone have to pay for unavailability of the service.
Criterias of choice for a server are application software availability, system availability, integrity, security, performance, scalability and price. [398]
La sécurité
[modifier | modifier le code]le marché
[modifier | modifier le code]En 1990 Apple se lance sur le marché, encore immature, des serveurs et des clients, en proposant son service LocalTalk. Doug McLean, directeur des ventes de Apple, reconnait que la facilité d'utilisation du Macintosh en fait un excellent client, mais que « les qualités requises pour un bon serveur sont très différentes ». [399]
En 1994 les trois fabricants d'ordinateurs compatible PC que sont Compaq, Hewlett-Packard et IBM occupent 78% du marché des serveurs. [400]
Jusqu'en 2000 la majorité des serveurs étaient équipés du système d'exploitation Unix, mais de plus en plus de serveur sont vendus avec le système d'exploitation Windows NT, et les parts de marché de ce dernier finissent par dépasser celles des Unix.
En informatique le spooling est une technique qui consiste à mettre des informations dans une file d'attente (spool) avant de les envoyer à un périphérique. Les informations sont mises en attente par un premier processus en même temps qu'un deuxième les lit et les envoye au périphérique. Cette technique est utilisée depuis 1960 pour exploiter des périphériques lents tels que imprimantes, lecteurs de carte perforée, modems,...[15]
Le mot spool est à l'origine l'acronyme de simultaneous processing operations on line. Il a été introduit par IBM en 1960, puis est devenu un mot du vocabulaire informatique. La technique du spooling a été mise en oeuvre la première fois dans l'ordinateur IBM 7070. En 2011 de nombreux systèmes d'exploitation comportent un spooler pour les imprimantes[16].
La technique
[modifier | modifier le code]La technique du spooling date de la fin des années 1950: un processus crée des fichiers, et les met dans une file d'attente (le spool) en même temps qu'un autre processus - le spooler - les envoie au périphérique. Plusieurs processus peuvent créer des fichier simultanément. Les processus qui créent les fichiers peuvent ainsi effectuer d'autres calculs pendant que les fichiers sont envoyés, ce qui diminue les temps de latence et accélère les opérations[15].
Les ordinateurs étant beaucoup plus rapide que les périphériques tels que les imprimantes, le fait que les fichiers sont enregistrés temporairement sur le disque dur ou dans une mémoire tampon (anglais buffer) évite que le processus qui crée les fichiers connaisse de longues periodes d'inactivité durant lesquelles il attends sur le périphérique. En 2011 les imprimantes contemporaines comportent souvent une mémoire tampon dans laquelle sera retenu le document à imprimer, cette mémoire peut cependant être insuffisante pour retenir la totalité du document et le reste sera alors retenu dans le spool[17].
Le spool d'impression est une file d'attente des documents, généralement enregistrés sur disque dur. Les documents sont envoyés à l'imprimante dans l'ordre de leur arrivée premier entré - premier sorti (anglais first in-first out abr. FIFO), et cet ordre peut être modifié si nécessaire, par exemple un document peut être retenu en vue d'être imprimé en dehors des heures de travail[17]. EMF et Postscript sont des formats de données utilisés pour les documents en attente dans les spool. Les documents peuvent également être enregistrés dans des formats de données propres aux imprimantes tels que PCL ou HPGL des imprimantes Hewlett-Packard[18].
Utilisations
[modifier | modifier le code]Les premières utilisations du spooling avec les imprimantes remonte à 1960. Les différents utilisateurs travaillaient simultanément sur les terminaux d'un même mainframe qui ne comportait qu'une seule imprimante. Plusieurs utilisateur pouvaient demander d'imprimer en même temps, sans que les pages soient mélangées[19].
Le spooling est mis en oeuvre dans tout les systèmes d'exploitation multitâches pour manipuler les imprimantes. Le spooling permet l'utilisation simultanée de l'imprimante par plusieurs processus en même temps - diverses applications émettent des documents à imprimer, qu'un processus unique, le spooler transmet un après l'autre à l'imprimante. LPR et CUPS sont des logiciels de spooler pour les systèmes d'exploitation Unix[20].
Le spooling est un des services offerts par les serveurs d'impression. Ces serveurs comportent souvent plusieurs files d'attentes relatives à différentes imprimantes. Les usagers envoient les documents à imprimer via le réseau puis ceux-ci sont placés dans les files d'attentes du serveur. Le serveur d'impression fait ainsi l'intermédiaire unique entre les usagers et les imprimantes[17].
Le spooling était utilisé avec les lecteurs de carte perforées. Le spooler lisait en continu les cartes et enregistrait le contenu de chaque carte dans le spool avant que celles-ci soient utilisées par un programme. Le programme lisait alors le contenu de chaque carte depuis le spool. Le spooler et le programme consommateur de cartes étaient exécutés simultanément, ce qui réduisait les temps de latence dus à la lecture des cartes[15].
Le spooling est également utilisé pour le courrier électronique, ou le courrier à traiter sont enregistrés dans le spool avant d'être distribués aux destinataires et l'usager n'a pas besoin d'être connecté au réseau pour écrire des mails[19].
En informatique et en télécommunications, l'extensibilité (anglais scalability) est la capacité d'un produit à s'adapter à un acroissement de la demande (montée en charge). En particulier sa capacité à maintenir ses fonctionalités et ses performances en cas de forte demande[21].
C'est une caractéristique cruciale de tout les services réseau, sans laquelle le service peut se retrouver victime de son succès. La popularité élevée d'un service peut apporter des difficultés techniques qui entraînent un coût élevé de maintenance et une baisse de la rentabilité[22]. [412]
Traduction
[modifier | modifier le code]le mot anglais scalability, dérivé du verbe to scale, n'a pas d'équivalent communément admis en français[23], les traductions utilisées sont extension graduelle[24], évolutivité[25], facteur d'échelle[26] ou extensibilité[27]. Les textes en français parlent également de montée en charge, de disponibilité et de tolérance de panne[28]. Le calque en français scalabilité est également utilisé ou alors le mot anglais scalability est conservé tel quel[29].
Matériel
[modifier | modifier le code]un dispositif informatique est extensible s'il est possible de faire face à une augmentation de la demande par des modifications après coup du matériel informatique.
Le processeur est une des pièces les plus chères d'un serveur informatique, et un ordinateur peut souvent en contenir qu'un nombre limité - typiquement moins de quatre processeurs. Il en va de même pour d'autres pièces de matériel informatique.
L'extensibilité horizontale consiste à ajouter des ordinateurs pour faire face à une demande accrue d'un service. La méthode la plus courante d'extensibilité horizontale est la répartition de charge (load balancing) par utilisation d'une grappes de serveurs (cluster) . C'est une technique couramment utilisée pour les serveurs web[30].
L'extensibilité verticale consiste à utiliser un ordinateur qui offre de nombreuses possibilité d'ajout de pièces, sur lequel il est possible de mettre une grande quantité de mémoire, de nombreux processeurs, plusieurs cartes mère, et de nombreux disque durs. Par exemple un ordinateur Sun Enterprise peut contenir jusqu'à 64 processeurs, 16 cartes mères, 64 Go de mémoire et des baies de stockage (disk array). L'ensemble tout équipé peut coûter jusqu'à 1 million de dollars[31].
Logiciels
[modifier | modifier le code]Quelle que soit la taille et la complexité d'un logiciel, ses fonctionalités, ses performances son l'extensibilité et son coût doivent correspondre aux besoins de l'utilisateur final. Dans le domaine des bases de données, les applications de traitement transactionnel en ligne (abr. OLTP) sont particulièrement concernées[32].
Les mesures d'extensibilité font ressortir la variation de la performance du logiciel en fonction de l'augmentation de la demande. Il est généralement attendu par le consommateur que la performance (temps de réponses) ne varie pas tant que la charge (nombre d'opérations par secondes) n'atteint pas la valeur nominale que le produit est sensé supporter.
Les mesures d'extensibilité s'intéressent au seuil à partir duquel la performance commence à se dégrader ainsi que la vitesse de la dégradation par rapport à l'augmentation de la demande[33].
Il y a un défaut d'extensibilité de type 1 lorsque la performance se détériore rapidement avec l'augmentation de la demande avant avoir atteint le niveau nominal et que le défaut peut être corrigé par des opérations de tuning et d'optimisation.
Il y a défaut d'extensibilité de niveau 2 lorsque la performance se détériore jusqu'à devenir inacceptable, et qu'aucune amélioration ne peut être apportée, pas même le remplacement du matériel informatique. Le seul moyen de corriger un tel défaut sont alors de coûteuses remises en question de l'architecture du produit. Un produit présentant ce type de défaut est considéré comme non extensible[34].
L'utilisation de files d'attente, l'architecture orientée services (SOA), l'utilisation de services Web et de systèmes de gestion de base de données (DBMS) influencent l'extensibilité d'un logiciel[30].
Parallélisme et goulots
[modifier | modifier le code]Théorie
[modifier | modifier le code]La scalabilité est la capacité d'un dispositif informatique à s'adapter au rythme de la demande. La capacité du matériel étant fixe, en particulier le débit binaire des réseaux et des disques durs, il existe une limite dans le nombre de demandes qui peuvent être traitées dans un temps donné. Au dessus de cette limite les demandes sont multiplexées et la concurrence entre les demandes traitées simultanément provoque des délais d'attente supplémentaires qui font effet de goulot d'étranglement (anglais bottleneck)[35].
La scalabilité est une capacité recherchée pour tout les systèmes qui travaillent à la demande, tels les applications de base de données, les moniteurs de transactions et les systèmes d'exploitation. Le système d'exploitation étant l'intermédiaire obligé entre les applications et le matériel, la scalabilité de ce dernier est d'une importance critique - mais largement ignorée - pour la scalabilité de l'ensemble du système informatique[36].
De nombreuses applications client-serveur sont construites en mode de communication synchrone: la partie client envoie une demande à la partie serveur, puis attends jusqu'à recevoir le résultat. Ce mode est plus simple à mettre en oeuvre, mais provoque des temps de latence qui sont perçus par l'utilisateur comme un manque de scalabilité. Le mode asynchrone permet d'effectuer des opérations durant les temps de latence et de multiplexer le traitement des demandes; ce mode est utilisé dans les applications multithread, les services Web et la programmation événementielle[35].
Une technique en vue d'augmenter la résistance à une forte demande d'un logiciel consiste à pré-réserver un groupe de ressources qui sont continuellement disponibles pour multiplexer les demandes en cas de besoin et ainsi économiser le temps qui aurait été nécessaire pour des réservations au besoin, cette technique de pooling est utilisée notamment pour la connexion aux bases de données[35].
Équipement de réseau
[modifier | modifier le code]L'industrie des télécommunications est particulièrement concernée par l'évolutivité et la fiabilité des réseaux qui sont amenés à servir un très grand nombre de clients. Une dorsale (anglais backbone) doit pouvoir supporter le traffic provenant de plusieurs services et destiné à de très nombreux clients sans qu'il soit nécessaire d'ajouter des équipements[37].
L'évolutivité est une caractéristique cruciale de tout les services réseau, sans laquelle le service peut se retrouver victime de son succès. La popularité élevée d'un service peut apporter des difficultés techniques qui entraînent un coût élevé de maintenance. Sous l'effet de l'arrivée de nouveaux clients, le fournisseur peut se retrouver en difficulté économique voire dans l'impossibilité technique de servir à la fois les nouveaux et les anciens clients[38]
Les lignes de télécommunication servent typiquement à la fois la téléphonie, le réseau Internet et les réseaux informatiques privés. Les fournisseurs de télécommunication recherchent à diminuer les coûts de maintenance du réseau tout en offrant tous les services demandés par les consommateurs[37]. L'évolutivité d'un réseau concerne autant la résistance au changement d'ordre de grandeur du débit binaire du réseau que du nombre d'abonnés[39].
Dans les réseaux publics, avec de très nombreux abonnés (téléphonie, Internet), il est attendu que le remplacement du terminal soit une mesure suffisante pour adapter le réseau à la demande. Vu que tout les clients ne remplacent pas leur terminal en même temps, le réseau doit pouvoir exploiter simultanément différentes générations de terminaux[39].
Les routeurs et autres appareils de réseau disponibles dans le commerce peuvent être équipés de circuits intégrés spécialisés application-specific integrated circuit (abr. ASIC) ou alors d'un processeur et un micrologiciel. Les appareils équipés d'un ASIC sont plus rapides mais demandent plus de temps de développement, ils sont par conséquent souvent plus coûteux et mis plus tard sur le marché.
Les appareils équipés d'un processeur n'offrent souvent pas autant de possibilités de réacheminement du traffic réseau (packet forwarding) que les ASIC. La distinction entre le réacheminement et le routage assure l'extensibilité du réseau.
L'ordinateur Xerox Alto est un prototype dévelopé en 1977 par le Palo Alto Research Center. Il offrait une interface graphique basée sur des icônes dont la présentation simule le dessus d'un bureau. Dans cet ordinateur toutes les possibilités offertes sont visibles à l'écran, et l'utilisation se limite à faire usage de sa coordination motrice, sans avoir à apprendre un langage de commande. Cette machine était destinée à être utilisée pour de la publication assistée par ordinateur et les résultats étaient immédiatement visibles à l'écran selon le principe WYSIWYG - what you see is what you get - traduction: Ce que vous voyez c'est ce que vous allez obtenir.[40]
Look and feel - aspect et comportement
[modifier | modifier le code]Le look and feel sont un ensemble de règles qui régissent la présentation visuelle ainsi que le comportement des interfaces graphiques. Les règles de présentation concernent en particulier l'usage des couleurs, la typographie, la présentation et la signification des logos et des icônes, la présentation des fenêtres - emplacement, forme et comportement des widgets - et les formes du curseur. Les règles de comportement régissent la manière dont les éléments visuels - notamment les widgets - répondent aux actions de l'utilisateurs - mouvements de la souris, pression sur les boutons de la souris et du clavier. L'application de ces règles visent à faciliter l'apprentissage, améliorer la satisfaction utilisateur, apporter une signature visuelle aux produits et réduire leurs coûts de développement[41].
accident de Fukushima et l'Iran
[modifier | modifier le code]La centrale nucléaire de Bouchehr, dont la construction a été lancée en 1974, et retardée par la révolution iranienne de 1979, devrait être mise en service en 2011. L'Iran est une région sujette aux tremblements de terre et la centrale atomique est située dans une région au climat très chaud et poussiéreux proche de la frontière avec le Koweït, Bahrein et l'Arabie Saoudite.[42],[43]
L'accident nucléaire de Fukushima a initié parmi les citoyens iraniens un long débat concernant la sécurité du programme nucléaire civil iranien. Hassan Yousefi Eshkevari est un intellectuel iranien en exil en Allemagne, initiateur du débat. Selon lui le débat politique au sujet du nucléaire en Iran, autant dans le pays qu'au niveau international, était plus tourné autour du traité de non prolifération nucléaire et de la bombe atomique, et très peu tourné sur la sécurité des installations pour la population locale. Toujours selon lui, le climat de répression et de censure à l'intérieur du pays ne permet pas de tenir tel débat, et celui-ci doit avoir lieu à l'extérieur, ou les intellectuels ont droit à la liberté de presse[44]. Depuis l'accident de Fukushima, un nombre grandissant de lettres de lecteurs, d'interviews et de blogs affirment que le programme nucléaire iranien met en danger la santé, le bien-être et l'économie locale[43].
Les pays voisins ont fait savoir leurs craintes des retombées d'un accident à Bouchehr, le Koweit a pris des mesures pour se préparer en cas d'accident nucléaire[42]. Le président Mahmoud Ahmadinejad affirme que le programme nucléaire est un « train sans freins », que la centrale de Bouchehr est conforme à « toutes les normes de sécurité et les standards les plus élevés », et remet en cause la « technologie dépassée » (sic) de la centrale japonaise[43].
- Christian Piguet - Heinz Hügli, Du zéro à l'ordinateur: Une brève histoire du calcul, PPUR presses polytechniques - 2004, (ISBN 978-2-88074-469-4)
- National Research Council (U.S.). Committee on the Fundamentals of Computer Science: Challenges and Opportunities, Computer science: reflections on the field - reflections from the field, National Academies Press - 2004, (ISBN 978-0-309-09301-9)
- les caractéristiques de l'eau de mer sont à peu près les mêmes partout dans le monde
- (en)Thomas M. Connolly - Carolyn E. Begg,Database systems: a practical approach to design, implementation, and management,Pearson Education - 2005, (ISBN 9780321210258)
- Erreur de référence : Balise
<ref>
incorrecte : aucun texte n’a été fourni pour les références nomméesfundamentals
- (en)Saeed K. Rahimi - Frank S. Haug,Distributed Database Management Systems: A Practical Approach,John Wiley and Sons - 2010, (ISBN 9780470407455)
- (en)Philip J. Pratt - Joseph J. Adamski,Concepts of Database Management,Cengage Learning - 2007, (ISBN 9781423901471)
- (en)Aditya Kumar Gupta,Taxonomy of Database Management System,Firewall Media - 2007, (ISBN 9788131800065)
- (en)S. K. Singh,Database Systems: Concepts, Design and Applications,Pearson Education India - 2009, (ISBN 9788177585674)
- (en)THE HISTORY AND HERITAGE OF SCIENTIFIC AND TECHNOLOGICAL iNFORMATION SYSTEMS,Information Today Inc.
- (en)Patrick O'Neil - Elizabeth O'Neil,Database--principles, programming, and performance,Morgan Kaufmann - 2001, (ISBN 9781558604384)
- (en)Computerworld,14 janv. 1985,Vol. 19 - N° 2, (ISSN 0010-4841)
- (en)« Netcraft March 2009 Web Server Survey »
- web: 35% d'usagers pour 20% du traffic; pair à pair: 5% d'usagers pour 35% du traffic
- (en)Michael Wells,Computing systems hardware Volume 6 de Cambridge computer science texts,CUP Archive - 1976, (ISBN 9780521290340)
- (en)Saul Rosen,Lectures on the Measurement and Evaluation of the Performance of Computing Systems,SIAM - 1987, (ISBN 9780898710205)
- (en)BICSI,Network Design Basics for Cabling Professionals,McGraw-Hill Professional - 2002, (ISBN 9780071399166)
- (en)Feng Yuan,Windows graphics programming: Win32 GDI and DirectDraw,Prentice Hall Professional - 2001, (ISBN 9780130869852)
- (en)Computerworld,3 sept. 2001,Vol. 35 - N° 36, (ISSN 0010-4841)
- (en)Achyut S Godbole,Operating systems,Tata McGraw-Hill Education - 2005, (ISBN 9780070591134)
- « extensibilité », Grand Dictionnaire terminologique, Office québécois de la langue française
- (en)Ina Minei et Julian Lucek,MPLS-Enabled Applications: Emerging Developments and New Technologies,John Wiley and Sons - 2011, (ISBN 9780470665459)
- Serveurs Multiprocesseurs Et Sgbd Parallelises,Ed. Techniques Ingénieur, page 4
- Édouard Rivier,Communication audiovisuelle,Springer - 2003, (ISBN 9782287597688),page 180
- Luigi Zaffalon,Programmation concurrente et temps réel avec Java,PPUR presses polytechniques - 2007, (ISBN 9782880746988), page 47
- Integration IP et ATM, Ed. Techniques Ingénieur, page 5
- Serveurs Video et Media,Ed. Techniques Ingénieur, page 18
- Benjamin Aumaille,Servlets: programmation d'applications Web avec Java (J2EE),Editions ENI - 2004, (ISBN 9782746023611), page 10
- Djillali Seba,CISCO: interconnexion des réseaux à l'aide des routeurs et commutateurs,Editions ENI - 2003, (ISBN 9782746021440),page 274
- (en)Cal Henderson,Building scalable web sites,O'Reilly Media Inc. - 2006, (ISBN 9780596102357)
- (en)Jeff Horwitz,Unix system management: primer plus,Sams Publishing - 2002, (ISBN 9780672323720)
- (en)Cal Henderson,Building scalable web sites,O'Reilly Media Inc. - 2006, (ISBN 9780596102357)
- (en)Jack Y. B. Lee,Scalable continuous media streaming systems: architecture, design, analysis and implementation,John Wiley and Sons - 2005, (ISBN 9780470857540)
- (en)Henry H. Liu,Software performance and scalability: a quantitative approach,John Wiley and Sons - 2009, (ISBN 9780470462539)
- (en)Shoshana Loeb - Benjamin Falchuk - Euthimios Panagos - Thimios Panagos,The fabric of mobile services: software paradigms and business demands,Wiley-Interscience - 2009, (ISBN 9780470277997)
- (en)Seif Haridi - 1995 EURO-PAR 1 - Stockholm,Parallel processing - Volume 966 de Lecture notes in computer science,Springer - 1995, (ISBN 9783540602477)
- (en)Monique Morrow et Kateel Vijayananda,Developing IP-based services: solutions for service providers and vendors,Morgan Kaufmann - 2003, (ISBN 9781558607798)
- (en)Ina Minei et Julian Lucek,MPLS-Enabled Applications: Emerging Developments and New Technologies,John Wiley and Sons - 2011, (ISBN 9780470665459)
- (en)Biswanath Mukherjee,Optical WDM networks,Birkhäuser - 2006, (ISBN 9780387290553)
- (en)Maurice M. de Ruiter,Advances in computer graphics, Volume 3,Springer - 1988, (ISBN 9783540187882)
- (en)Jakob Nielsen,Coordinating user interfaces for consistency,Morgan Kaufmann - 1989, (ISBN 9781558608214)
- (en)http://www.iiss.org/publications/strategic-comments/past-issues/volume-17-2011/april/iran-dismisses-post-fukushima-nuclear-rethink/
- (en)http://www.theatlantic.com/international/archive/2011/04/will-fukushima-force-iran-to-reconsider-nuclear-program/73293/
- (en)http://www.rferl.org/content/interview_exiled_iran_religious_scholar_debate_nuclear_safety/3542999.html
Amiga est une famille d'ordinateurs personnels et de consoles de jeu créée par Amiga Corporation et vendus par Commodore entre 1985 et 1994.
Présentation
[modifier | modifier le code]Le système d'exploitation de l'Amiga comporte une interface graphique similaire à celle du Macintosh et une interface en ligne de commande. Les premiers usagers ont remarqué son aisance à exécuter de nombreuses tâches en même temps - plus de 50, ceci est du au fait que les opérations d'affichage sont entièrement réalisées par les circuits intégrés et que le processeur 68000 est alors entièrement disponible pour les calculs. Le client cible de l'Amiga est l'utilisateur domestique, ainsi que le domaine de l'infographie, le magazine InfoWorld se questionne concernant la plus-value apportée par l'Amiga sur le marché des entreprises et de l'informatique de gestion. [1],[2]
L'offre en logiciels pour Amiga a posé un problème à Commodore: la machine n'était pas compatible avec ses concurrents, ni même avec le C64 de Commodore, et aucun des logiciels sur le marché ne fonctionnait sur cette machine. Divers éditeurs de logiciels annoncent des adaptations de leurs produits à l'Amiga, mais l'offre reste modeste. Parmi les logiciels annoncés cette machine, il y a le langage de programmation BASIC de Microsoft, et quelques dizaines de logiciels qui vont du traitement de texte, la comptabilité à la musique assistée par ordinateur et la création de dessins animés[3]. L'offre en logiciels s'est élargie en 1986 avec l'arrivée de Deluxe Paint, Deluxe Music, et Deluxe Video, créés par Electronic Arts[4]. L'achat en option, d'un émulateur, pour un coût de 200$ permet d'exploiter les logiciels existant sur le marché, et prévus pour IBM PC, tels que Wordstar, DBase III ou Lotus 1-2-3[5].
En 1996 les versions de AmigaOS sont le 1.3, le 2.04, le 3.0 et le 3.1. Les machines sur le marché sont le A2000, le A500 (v1.3 - 1897), le A500+, le A600 (68000 7 Mhz), le A1500 (CPU ?), le A3000 (v2.04, 68030 25 Mhz - 1990), le A1200 (68020 - AGA - 1992) et le A4000 (v3.0) (68030 et 68040 - AGA - 1992). Le système d'exploitation est placé dans une mémoire morte (ROM) et le changement de version s'effectue par remplacement de la puce de mémoire morte. [418]
Nom | Année | forme du boîtier | marché | Processeur | AmigaOS | Chipset[6] |
---|---|---|---|---|---|---|
Amiga 1000[7] | 1985 | ordinateur de bureau | domestique | 68000 7 Mhz | 1.0 | OCS |
Amiga 500[8] | 1987 | machine à écrire | domestique | 68000 7 Mhz | 1.3 | OCS |
Amiga 500+[8] | ? | machine à écrire | domestique | 68000 7 Mhz | 1.3 | ECS(?) |
Amiga 2000[8] | 1987 (?) | ordinateur de bureau | professionels | 68000 7 Mhz | 1.3 | OCS |
Amiga 1500[9] | 1990 | ordinateur de bureau | professionels | 68000 7 Mhz | 1.3 et 2.04 | ECS |
Amiga 3000[8] | 1990 | ordinateur de bureau | professionels | 68030 25 Mhz | 2.04 ou Unix[réf. nécessaire] | ECS |
Amiga CDTV[10] | 1991 | set-top box | domestique | 68000 7 Mhz | 1.3 | OCS(?) |
Amiga 600[11] | 1992(?) | machine à écrire | domestique | 68000 7 Mhz | 2.05 | ECS |
Amiga 1200[8] | 1992 | machine à écrire | domestique | 68020 14 Mhz(?) | 3.0 | AGA |
Amiga 4000[8] | 1992 | ordinateur de bureau | professionels | 68030 ou 68040 25 Mhz | 3.0 | AGA |
Amiga CD32[12] | 1993 | console de jeu | domestique | 68020 14 Mhz | 3.1 | AGA |
Histoire
[modifier | modifier le code]1984: Le prototype de Amiga Corporation
[modifier | modifier le code]Amiga Corporation est une société fondée en 1982, basée à Santa Clara en Californie, qui fabrique des joysticks. En 1984 Amiga Corp. se lance sur le marché des ordinateurs personnels, en présentant son propre ordinateur au Consumer Electronics Show de Chicago. Le prix de vente de départ cet ordinateur anonyme est de 1500$, il comporte un processeur Motorola 68000, le même que sur son concurrent le Macintosh, est équipé de 128 Ko de mémoire vive et d'un lecteur de disquettes de 5.25 pouces. Le système d'exploitation a été créé par Amiga Corp, qui promet d'y inclure également d'autres systèmes d'exploitation du commerce tels que CP/M, MS-DOS et Unix.[13][14]
Les capacités d'affichage couleur de cet ordinateur sont semblable à ceux des produits concurrents, cependant leur mise en oeuvre est bien différente: l'ordinateur de Amiga Corp. n'a pas besoin de carte graphique, il comporte trois circuits intégrés nommés Agnus, Daphne et Portia servant de processeur graphique ainsi que pour le son et pour manipuler les périphériques. Les circuits intégrés de cet ordinateur sont prévus pour permettre de réaliser des effets vidéo aussi fluides que le cinéma et les afficher un écran de télévision ordinaire, sans utiliser le processeur 68000. Les trois circuits intégrés sont l'oeuvre de Jay Miner, vice-président de Amiga Corp, qui est également l'auteur des circuits intégrés de la console de jeu Atari 2600.[13][14]
Des rumeurs circulent alors (en 1984) que la société Atari est intéressée à acheter cette machine pour la vendre sous un autre nom, Dave Morse, directeur de Amiga Corp. affirme que cette machine sera vendue uniquement sous le nom Amiga. En septembre 1984 la machine est vendue à Commodore Business Machines, qui fait alors son entrée sur le marché des ordinateurs 32 bits et prévoit de faire l'ordinateur Commodore Amiga un produit de masse.[13][14]
1985: Commodore
[modifier | modifier le code]En Septembre 1984, Commodore, qui vient de perdre 20.8 millions de dollars, est en difficultés économique. La société rachète l'ordinateur de Amiga Corp, et compte sur cet achat pour la relance de ses activités, sur un marché des micro-ordinateurs alors dominé par Apple et IBM.[15]
L'Amiga 1000 a été mis sur le marché en 1985 au prix de 1300$. Il est équipé d'un processeur Motorola 68000 cadencé à 7 Mhz, de 256 Ko de mémoire vive dite Chip RAM, utilisée à la fois par le processeur ainsi que les circuits intégrés d'affichage, de son et d'entrée/sortie nommés Agnus, Paula, et Denise, ainsi qu'un lecteur de disquettes 3.5 pouces et un second module interne de 256 Ko de mémoire. Il peut afficher des images de 4096 couleurs et est équipé d'un circuit audio 4 canaux et de synthèse vocale. Il peut être équipé pour exécuter les programmes prévus pour le IBM PC, tels que Lotus 1-2-3.[16][17]
Le démarrage de l'Amiga 1000 consiste à insérer la disquette dite de kickstart dans le lecteur avant d'allumer la machine. En effet, l'amorce du système d'exploitation devait être enregistré sur une puce de mémoire morte soudée sur la machine, mais cette amorçe n'était pas disponible au début de la production de cette machine et son contenu a été livré sur une disquette. Le contenu de la disquette est copiée dans un module interne de mémoire au démarrage de l'ordinateur. La place pour la puce d'amorce existait sur la carte mère et certains bricoleurs y ont soudé la puce d'amorce eux-même.[16][17] Par la suite des machines Amiga ont toutes été équipées de série d'une puce de mémoire pour l'amorçe.
Suite à un contrat signé entre Commodore et Atari, le premier Amiga est mis sur le marché en même temps que le Atari ST, qui deviendra alors sont principal rival. Les deux machines sont similaires, l'Amiga était meilleur, mais il était également deux fois plus cher.[18]
Populaire en 1990
[modifier | modifier le code]Dans les années 1990, l'Amiga 500 était la deuxième machine la plus populaire sur la scène démo, après le Commodore 64. Mais l'arrivée en 1992 du Amiga 1200, avec ces nouveaux circuits intégrés AGA a provoqué une fragmentation de ce marché.[19]
L'Amiga, tout comme l'Atari et le Macintosh n'avaient que peu de part de marché dans le secteur de l'informatique de gestion. Dans les entreprises l'Amiga était utilisé dans l'industrie de la télévision et du cinéma, en raison notamment de sa possibilité d'être branché à des appareils vidéo. Il a été utilisé notamment pour monter les séries télé Max Headroom et Babylon 5.[20]
l'Amiga était une machine couramment utilisée pour répandre des virus informatique. En plus d'être populaire, sa construction permettait de cacher un virus dans une disquette, virus qui sera lu et exécuté à chaque fois que la disquette est placée dans le lecteur. Les utilisateurs avaient de plus l'habitude de s'échanger des disquettes, notamment des jeux vidéo.[21]
En 1990, alors que Commodore a déjà vendu plus de 1.8 million de machines Amiga, le magazine InfoWorld compare les systèmes d'exploitation AmigaOS, OS/2, Microsoft Windows, et Mac OS avec MultiFinder, et affirme que l'AmigaDOS est le meilleur. Il est multitâche préemptif, alors que MultiFinder ne l'est pas, et se contente de 512 Ko de mémoire vive alors que OS/2 et Windows nécessitent 3 Mo. L'interface graphique Intuition de l'Amiga a des temps de réponse plus courts et l'affichage est plus fluide, et ce même sur l'ordinateur d'entrée de gamme qu'est l'Amiga 500.[22]
1990: échec commercial de la CDTV
[modifier | modifier le code]Le CDTV est un set-top box et lecteur de CD-i sorti en 1990. Commodore espère que de nombreux titres paraitront en CD-I, la machine n'obtient cependant pas le succès escompté, et les ventes sont rapidement abandonnées.[23] Selon Andy Slaven du magazine Video Game Bible, « La machine a un coeur d'ordinateur, mais dans la pratique il s'agit d'une console de jeu ratée. » Le CDTV a un boitier noir, de la dimension d'un magnétoscope, il est équipé d'une télécommande. Le clavier et le lecteur de disquettes sont en option. Il existe quelques bon jeux vidéo pour le CDTV, cependant la plupart sont également disponibles pour d'autres consoles de jeu meilleur marché. La plupart des jeux pour le CDTV fonctionnent également sur les ordinateurs personnels Amiga ainsi que la console de jeu CD32. Ces deux consoles étaient populaires en Europe, mais ont été très peu vendues aux États-Unis. L'intention de Commodore était d'en faire le magnétoscope du futur. Les acheteurs de magnétoscope trouvaient que le CDTV ressemblait trop à un ordinateur alors que les acheteurs d'ordinateur trouvaient qu'il ne ressemblait pas assez (sic).[24]
1994: La faillite de Commodore
[modifier | modifier le code]La console de jeu Amiga CD32 est présentée en 1993, les logiciels pour cette console sont sur CD-ROM, la CD32 peut également lire des CD audio ordinaires, le prix de vente est fixé à 400$. Au même moment Commodore annonce une liquidation partielle dans le but de se restructurer suite à une perte de 8.3 millions de dollars.[25] Les logiciels pour le CDTV fonctionnement également sur la CD32 et celui-ci peut être mis sur le marché avec une abondante offre de logiciels. le CD32 connait un franc succès en Europe et très peu aux États-Unis. Succès est cependant coupé court: Commodore, en cours de restructuration, n'arrive pas à répondre à la demande par manque de pièces de rechange. Commodore déclare faillite en 1994, et la production de la CD32 est arrêtée. [26]
Sept ans plus tard, en 2001, c'est la société Amiga Inc. basée en Australie, qui continue de faire évoluer l'AmigaOS. La société publie des spécification techniques et fait appel à des constructeurs dans le but de sortir un nouvel ordinateur Amiga dans les six années qui viennent. Une machine attendue avec impatience par les utilisateurs et fan-clubs de l'Amiga[27].
L'Amiga et Internet
[modifier | modifier le code]En 1996 Karl Jeacle publie un livre de 120 pages consacrés à l'utilisation de l'Amiga pour accéder à Internet. Opération possible sur les modèles récents ainsi que le haut de la gamme: L'AmigaOS 2.04, Un disque dur de 5 Mo de capacité et un processeur Motorola 68020 ou plus rapide est nécessaire, le chipset AGA ou une carte graphique sont également recommandés, notamment pour naviguer sur le Web. Ce livre cite une liste de plus de 15 logiciels tels que lecteur d'e-mail, navigateurs Web, client FTP, logiciels de messagerie instantanée, lecteur de nouvelles, logiciels de visioconférence et des pile de protocoles, tous destinés à Internet. Tout ces logiciels sont gratuits, disponibles dans des distributions sur CD-ROM ou dans des magazines et proviennent notamment de la collection Aminet.[28]
Rétro-informatique
[modifier | modifier le code]Dans les années 2000 l'Amiga 500 est devenu une machine populaire auprès des amateurs de rétro-informatique. [419]
Le matériel
[modifier | modifier le code]Contrairement au Macintosh ou la plupart des opérations sont réalisées par le processeur 68000, sur l'Amiga ce sont des puces spécialisées qui s'occupent du son, de l'affichage et l'animation, d'ou une puissance supérieure en particulier en multimédia[29].
L'Amiga est équipé d'un lecteur de disquettes 3.5 pouces de 880 Ko de capacité. Il se branche à un moniteur télévision PAL ou NTSC et affiche dans des résolutions de 640x400, 640x200 ou 320x200 points. Il affiche en 16 couleurs ou plus, alors que ces concurrents affichent en 4 couleurs. Ce sont les trois puces spécialisées qui lui apportent flexibilité et vitesse, ils permettent en particulier d'afficher 16 sprites sur lesquels il est possible de fixer la priorité et déceler des collisions[29].
Paula est le nom de la puce audio de l'Amiga. Cette puce comporte 4 canaux audio 8 bits, capables de produire des formes d'ondes complexes sur une plage de 9 octaves (de 20 Hz à 29 kHz) à partir échantillons. Les sons peuvent être synthétisés à la volée et joués en stéréo. Le volume peut être contrôlé séparément pour chacun des 4 canaux, ce qui permet de réaliser des effets tels que trémolo ou le vibrato. Contrairement au reste du matériel de l'Amiga, la puce Paula est à peu près la même sur tout les modèles[30].
La connectique de l'Amiga comprends un port vidéo RGB, un port vidéo composite, et deux ports contrôleur sur lesquels peuvent être branchés une souris ou un joystick, un connecteur série, un connecteur parallèle centronics, un connecteur d'extension qui permet d'y brancher une carte d'extension, et deux prises audio RCA. Un connecteur à l'intérieur du boîtier permet d'ajouter de la mémoire. Commodore affirme que le système d'exploitation supporte 8 Mo de mémoire[29].
Le logiciel
[modifier | modifier le code]La construction de l'Amiga en fait un ordinateur complètement multitâches. D'autres micro-ordinateurs pouvaient - en 1985 - être utilisés en multitâches; l'Amiga donnait cependant de meilleurs résultats. L'utilisateur pouvait théoriquement faire travailler un tableur tout en manipulant une image ou en utilisant un traitement de texte; en théorie seulement parce que de telles applications n'étaient pas disponibles pour l'Amiga en 1985[31].
AmigaDOS est le système d'exploitation des disques de l'Amiga. Il peut être exploité depuis une interface en ligne de commande (CLI), d'une manière similaire à MS-DOS tout en étant adapté à la nature multitâche de l'Amiga. Les disques sont manipulés en indiquant le nom du média ou du lecteur où ils se trouvent[31].
La seconde partie du système d'exploitation est une bibliothèque logicielle nommée Intuition, qui manipule les fenêtres, les icônes, la souris et fournit un environnement graphique dans lesquel les programmes vont être exécutés. Un de ces programmes est le Workbench, qui fournit une interface avec des icônes, similaire au GEM ou à l'interface du Macintosh[31].
A partir du Workbench il est possible d'ouvrir une ou plusieurs fenêtres de CLI et d'exécuter des commandes ou d'autres programmes. Il est également possible avec un peu de connaissance technique de créer une disquette de démarrage qui ne démarre pas le Workbench[31].
Parmi les fonctionalité du Workbench: une barre de couleur verticale indique l'état de remplissage du disque dur, une barre horizontale située en haut de l'écran, qui indique la quantité de mémoire actuellement disponible. Ces deux barres peuvent être déplacées à la souris (glisser-déposer). AmigaDOS 1.1 comporte un logiciel éditeur d'icônes, qui permet par exemple, de retoucher la forme de la corbeille[31].
Selon le magazine InfoWorld de 1985: « L'Amiga est une machine qui a du potentiel, cependant le système d'exploitation de l'Amiga a un sérieux bug: Lorsqu'un programme dépasse la quantité de mémoire disponible, la machine plante et doit être redémarrée. Les vendeurs affirment que ce problème sera résolu avec les prochaines versions »[31].
Paru en 2009, la version 4.1 du Workbench a apporté des améliorations visuelles par rapport aux versions précédentes, telles que des menus contextuels et des icônes en aspect 3D. Il est courant que des utilisateurs font usage d'outils concurrents du Workbench ou installent des kits de widgets et d'icônes. Ces kits apportent de nouveaux types de widgets, des boutons animés et des icônes colorés, avec transparence et ombres, ainsi que des fonds d'écran, ce qui modifie complètement le look and feel - la signature visuelle et fonctionnelle - de l'interface graphique[32].
En informatique, une machine virtuelle est une illusion d'un appareil informatique créée par un logiciel d'émulation. Le logiciel d'émulation simule la présence de ressources matérielles et logicielles telles que la mémoire, le processeur, le disque dur, voire le système d'exploitation et les pilotes, permettant d'exécuter des programmes commme si ceux-ci s'exécutaient sur la machine simulée.[33]
Histoire
[modifier | modifier le code]le produit VM/370, créé par IBM dans les années 1970, permettait à plusieurs usagers d'utiliser en temps partagé un ordinateur qui exécute le système d'exploitation IBM DOS. IBM DOS tout seul n'offrait pas la possibilité d'utilisation en temps partagé.[34]
En 1989, les logiciels Desqview, Omniview, VM/386 et Windows/386 permettent de simuler des machines virtuelles qui exécutent le système d'exploitation MS-DOS. Les logiciels Desqview et Windows/386 offrent en plus une interface graphique permettant de voir sur un même écran les différentes machines virtuelles en fonctionnement.[35]
La machine virtuelle Java a été créée en 1995 par Sun Microsystems. Elle était destinée à exécuter des logiciels téléchargés depuis un serveur Web, ceci quelles que soient les caractéristiques techniques de l'appareil qui télécharge le logiciel. Le produit est accompagné du langage de programmation Java, inspiré de C++, et promis à devenir un standard de facto.[36]
Créé en 1999, VMware est un logiciel qui permet d'exécuter simultanément plusieurs systèmes d'exploitation sur une même machine. (voir plus loin: virtualisation)[37]
Techniques
[modifier | modifier le code]L'émulation est le fait de mettre en oeuvre les fonctionalités d'un appareil en utilisant un autre appareil offrant des fonctionalités différentes. Une des utilisations consiste à mettre en oeuvre le jeu d'instructions d'un processeur en utilisant un autre processeur. Ceci permet par exemple d'utiliser un ordinateur récent pour exécuter des programmes destinés à un ordinateur ou une console de jeu qui n'existent plus dans le commerce. La simulation s'accompagne d'une baisse significative de la puissance de calcul: la puissance du processeur simulé sera une fraction de celle du processeur simulateur.[38][39]
La compilation juste-à-temps (anglais just-in-time - JIT) est une technique utilisée pour simuler un processeur. Le code machine prévu pour le processeur à simuler est traduit en vue de devenir du code machine pour le processeur qui simule. L'opération de traduction est réalisée par un logiciel semblable à un compilateur immédiatement avant que le code traduit soit exécuté.
L'hyperviseur est le logiciel qui contrôle l'utilisation, par les différentes machines virtuelles, du matériel de l'appareil simulateur. Un hyperviseur de Type 2 utilise le système d'exploitation de l'ordinateur simulateur, tandis qu'un hyperviseur de Type 1 n'a pas besoin de ce système d'exploitation sur l'appareil simulateur.[40]
Une des fonctionalités courante des logiciels hyperviseurs ainsi que des systèmes d'exploitation est de simuler la présence de mémoire centrale par de la mémoire virtuelle. Le mécanisme permet également de simuler la présence de 4 Go de mémoire dans une machine réélement équipée de 1 Go, l´overbooking est mis en oeuvre en copiant le contenu inutilisé de la mémoire vers le disque dur.[41]
Utilisations
[modifier | modifier le code]Multitâches
[modifier | modifier le code]Les machines virtuelles sont utilisées depuis les années 1970 pour mettre en oeuvre du multitâches: permettre à l'ordinateur de réaliser plusieurs opérations simultanément au service de plusieurs utilisateurs. Une machine virtuelle est affectée à chaque utilisateur, lui donnant l'illusion qu'il est le seul à utiliser l'ordinateur. Cette fonctionalité est maintenant inclue dans tout les systèmes d'exploitation.[42]
Machine virtuelle de haut niveau
[modifier | modifier le code]Dans la technique de la machine virtuelle de haut niveau, le code source des programmes est traduit par un compilateur en un code objet intermédiaire, avant d'être ensuite traduit en un code machine utilisant le jeu d'instructions spécifique du processeur qui va exécuter le programme. Le code intermédiaire - bytecode - utilise un jeu d'instruction d'une machine fictive, qui n'existe pas dans le commerce, et dont les caractéristiques permettent de faire abstraction du jeu d'instruction final qui sera utilisé pour exécuter le programme. Cette technique a été utilisée la première fois pour le langage de programmation Pascal en 1980.
Dans cette technique, les programmes sont distribués sur le marché sous forme de bytecode - le code machine de la machine virtuelle - et peuvent être exécutés par tout appareil informatique qui possède le logiciel nécessaire pour simuler la machine en question.[43]
Machine virtuelle Java
[modifier | modifier le code]La machine virtuelle Java est une machine virtuelle de haut niveau. Sa spécification technique, définie par la société Sun Microsystems, mentionne le jeu d'instructions du processeur, le format des fichier exécutables et l'interface de programmation système. La machine virtuelle Java est simulée par un logiciel tel que le Java Runtime Environment. Le slogan de cette technologie est write once, run anywhere (traduction: écrire une fois, utiliser n'importe où): que le logiciel écrit une seule fois peut être utilisé sur une large palette de machines (qui va du téléphone portable jusqu'au superordinateur).[44]
Virtualisation
[modifier | modifier le code]Au sens large, la virtualisation consiste à simuler l'existence de plusieurs machines informatiques en en utilisant une seule. Ceci permet en particulier de diminuer les coûts d'achat de matériel informatique et de rentabiliser leur utilisation: Les technologies de 2008 sont si puissantes qu'en condition ordinaire un serveur n'utilise que 10% des capacités du matériel. La virtualisation permet également de gagner du temps: une courte procédure de modification de la configuration de l'émulateur remplace une longue procédure d'acquisition de matériel informatique.[45]
- développement des systèmes embarqués (téléphones, décodeurs TV)
- développement en électronique
Microsoft - stratégies commerciales
[modifier | modifier le code]Bien plus que la qualité de ses produits, ce sont les stratégies commerciales controversées de la marque qui sont à l'origine de son succès, ainsi que des critiques et des actions en justice à son encontre.
En 1989, la montée phénoménale de Microsoft et son produit MS-DOS sur le marché des systèmes d'exploitation intéresse la Federal Trade Commission - la commission à la concurrence des États-Unis, qui ouvre alors une enquête concernant les pratiques commerciales de la firme. Cette enquête est suivie en 1994 par une deuxième enquête réalisée par le département de la justice des États-Unis (abr. DOJ). Six mois plus tard, le département de la justice décrète interdire à Microsoft les CPU License, les contrats à long terme avec les constructeurs d'ordinateurs ainsi que les clauses de non-concurrence avec les sociétés partenaires. Ce décret n'est toutefois jamais mis en application parce qu'ayant qu'un impact limité sur le marché. [423]
Depuis lors Microsoft est en permanence sous l'oeil de la justice. Notamment accusé d'abus de position dominante.
CPU License
[modifier | modifier le code]A partir de 1983, Microsoft conclut avec plusieurs constructeurs d'ordinateur des contrats dit CPU license. Selon les termes de ce type de contrat, le constructeur s'engage pendant une période de deux ans à verser à Microsoft un montant fixe pour chaque ordinateurs qu'il vends, en l'échange du droit d'y installer gratuitement le système d'exploitation MS-DOS. Le montant est inférieur à celui de l'achat unitaire de MS-DOS, et le constructeur paye le montant même si il n'installe pas MS-DOS sur l'ordinateur vendu. Le contract comporte un forfait de N * le montant fixe, ou N est le nombre d'ordinateurs que le constructeur prévoit de vendre. Si le nombre d'ordinateurs vendu par le constructeur est supérieur à N, celui-ci doit alors payer de manière unitaire le montant fixe pour chaque ordinateur vendu en plus. Dans le cas contraire, les invendus ne sont pas remboursés par Microsoft, ils peuvent cependant être reportés sur l'année suivante en cas de renouvellement du contrat.
Les constructeurs ayant conclu ce type de contrat répercutent les redevances payées à Microsoft sur le prix de vente de l'ordinateur. Un acheteur qui voudrait installer sur son ordinateur un système d'exploitation concurrent comme DR-DOS ou PC-DOS paye alors indirectement le prix de deux systèmes d'exploitation, un surcoût acceptable uniquement dans le cas ou le système d'exploitation concurrent est largement supérieur à MS-DOS.
La vente sous CPU license représente 20% du chiffre d'affaires de Microsoft en 1989, et 50% en 1992. Pour la seule année 1992, Microsoft a vendu plus de 18 millions de copies de MS-DOS en CPU license, pour un montant total de 400 millions de dollars.
Compatibilité et interfaces de programmation
[modifier | modifier le code]Un système d'exploitation (abr. OS pour operating system) fournis une suite de services normalisés et documentés, qui sont exploités par les logiciels applicatifs. Les caractéristiques des mécanismes utilisés pour exploiter ses services forment l'interface de programmation. Celle-ci prends typiquement la forme d'une suite de fonctions de facade, utilisées par les logiciels applicatifs pour exploiter les services offerts par le système d'exploitation.
Le fait que différents OS sur le marché fournissent la même interface de programmation assure que les logiciels applicatifs pourront fonctionner de manière identique avec chacun de ces OS - compatibilité. L'alternative est de donner au logiciel applicatif la capacité de fonctionner avec plus d'une interface de programmation. Cette capacité nécessite un long et couteux travail de développement et la plupart des logiciels applicatifs n'offrent pas cette possibilité.
Microsoft est à la fois éditeur d'OS et de logiciels applicatifs. Certaines fonctions de l'interface de programmation de MS-DOS ne sont pas documentés, et ont été utilisés en 1990 en vue de favoriser l'utilisation conjointe de logiciels édités par Microsoft plutôt que ceux de la concurrence. La modification - sans préavis - de telles fonctions a pour effet de saboter tout logiciel qui les utiliserait. De telles fonctions ont été utilisées notamment dans certaines éditions de Windows 3.11, qui affichait un avertissement de risque de problème au cas ou était utilisé conjointement avec un OS autre que MS-DOS - des problèmes en réalité inexistants.
Depuis 1996 Sun Microsystems distribue la technologie Java, composée d'un langage de programmation, une interface de programmation et une machine virtuelle. Par cette technologie, tout logiciel qui exploite l´interface de programmation Java pourra alors fonctionner sur n'importe quel ordinateur pour lequel il existe une machine virtuelle Java (abr. JVM), quel que soit le système d'exploitation sous-jacent. Cette universalité « write once - run anywhere » représente une menace pour le marché des systèmes d'exploitation dominé par Microsoft.
Par contrat de licence, Sun octroie les droits à différents fournisseurs (Microsoft, IBM, Apple) d'effectuer les adaptations nécessaires à la machine virtuelle Java en vue de respecter le cahier des charges de l'interface de programmation (cahier des charges établi par Sun).
En 1998 Sun Microsystems intente une action en justice contre Microsoft, l'accuse d'avoir sciemment pas respecté le cahier des charges - qui garantis la compatibilité, et l'accuse de vouloir provoquer une cassure du marché et inciter à fabriquer des logiciels utilisant Java qui fonctionneraient uniquement avec Windows, le système d'exploitation de Microsoft. Sun remporte le procès et Microsoft reçoit ordre d'arrêter de distribuer sa machine virtuelle Java, à moins que celle-ci soit mise en conformité avec le cahier des charges dans un délai de 3 mois.
Vente liée
[modifier | modifier le code]Dans le marché des logiciels applicatifs, les éditeurs produisent typiquement un seul logiciel majeur. Depuis 1990 Microsoft fait de la vente liée de plusieurs logiciels applicatifs. En 1993 les produits Word, Excel, PowerPoint et Access sont vendus ensemble pour un prix de groupe de 250$. Le prix de vente au détail de ces logiciels est de 300$ chacun.
Microsoft a également vendu lié Windows 95 avec Internet Explorer et MSN. Profitant de l'effet de levier de sa domination sur le marché des systèmes d'exploitation.
Pré-annonces
[modifier | modifier le code]En avril 1990 Digital Research mettait sur le marché DR-DOS 5.0, considéré par de nombreux experts comme supérieur à son concurrent MS-DOS de Microsoft. Moins d'un mois plus tard, Microsoft annonce l'arrivée prochaine de MS-DOS 5.0, arrivée annoncée comme imminente. MS-DOS 5.0 n'a été mis sur le marché que 15 mois plus tard, en juillet 1991, et sa sortie a été continuellement annoncée comme imminente.
- (en)InfoWorld,15 juil. 1985,Vol. 7 - N° 28, (ISSN 0199-6649)
- (en)Popular Science,oct. 1985,Vol. 227 - N° 4, (ISSN 0161-7370)
- (en)InfoWorld,5 août 1985,Vol. 7 - N° 31, (ISSN 0199-6649)
- (en)Popular Mechanics,mai 1986,Vol. 163 - N° 5, (ISSN 0032-4558)
- (en)New York Magazine,5 août 1985,Vol. 18 - N° 30, (ISSN 0028-7369)
- le modèle des circuits intégrés
- (en)http://oldcomputers.net/amiga1000.html
- (en)Karl Jeacle,Amiga surfin´,1996, (ISBN 9781855500075)
- (en)http://www.amigahistory.co.uk/a1500.html
- Andy Slaven, Video Game Bible, 1985-2002,Trafford Publishing - 2002, (ISBN 9781553697312)
- (en)http://www.amiga600.de/a600capab.htm
- (en)http://www.amiga-hardware.com/showhardware.cgi?HARDID=32
- InfoWorld,Vol. 6 - N° 28, (ISSN 0199-6649)
- InfoWorld,Vol. 6 - N° 13, (ISSN 0199-6649)
- New York Magazine,5 août 1985,Vol. 18 - N° 30, (ISSN 0028-7369)
- Popular Science,oct. 1985,Vol. 227,N° 4, (ISSN 0161-7370)
- Maximum PC,déc. 2007, (ISSN 1522-4279)
- Rodney P. Carlisle,Encyclopedia of Play in Today's Society, Volume 1,SAGE - 2009, (ISBN 9781412966702)
- (en)John Impagliazzo - Timo Järvi et Petri Paju,History of Nordic Computing 2,Springer, 2009, (ISBN 9783642037566)
- Rodney P. Carlisle,Encyclopedia of Play in Today's Society, Volume 1,SAGE - 2009, (ISBN 9781412966702)
- (en)David Salomon,Foundations of computer security,Birkhäuser - 2006, (ISBN 9781846281938)
- (en)InfoWorld,22 oct. 1990,Vol. 12 - N° 43, (ISSN 0199-6649)
- (en)A. E. Cawkell - Tony Cawkell,The Multimedia Handbook,Routledge - 2004, (ISBN 9780203398371)
- (en)Andy Slaven,Video Game Bible, 1985-2002,Trafford Publishing - 2002, (ISBN 9781553697312)
- (en)Billboard,28 mai 1994,Vol. 106 - N° 22, (ISSN 0006-2510)
- (en)Mark J. P. Wolf,The video game explosion: a history from PONG to Playstation and beyond,ABC-CLIO - 2008, (ISBN 9780313338687)
- (en)CIO,15 août 2001,Vol. 14 - N° 21
- (en)Karl Jeacle,Amiga surfin´,Karl Jeacle - 1996, (ISSN 9781855500075[à vérifier : ISSN invalide])
- (en)InfoWorld,16 déc. 1985,Vol. 7 - N° 50, (ISSN 0199-6649)
- (en)Karen Collins,Game sound: an introduction to the history, theory, and practice of video game music,MIT Press - 2008, (ISBN 9780262033787)
- (en)InfoWorld,16 déc. 1985,Vol. 7 - N° 50, (ISSN 0199-6649)
- (en)Dan Ryan,History of Computer Graphics: Dlr Associates Series,AuthorHouse - 2011, (ISBN 9781456751173)
- (en)Karen Hazzah,Writing Windows VxDs and device drivers,Focal Press - 1996, (ISBN 9780879304386)
- Computerworld,Vol. 9 - N° 33,août 1975, (ISSN 0010-4841)
- InfoWorld,Vol. 11 - N° 7,févr. 1989, (ISSN 0199-6649)
- Network World,Vol. 12 - N° 50, décembre 1995, (ISSN 0887-7661)
- InfoWorld,Vol. 21 - N° 16,avr. 1999, (ISSN 0199-6649)
- (en)Harry Henderson,Encyclopedia of computer science and technology,Infobase Publishing - 2009, (ISBN 9780816063826)
- (en)James Edward Smith et Ravi Nair,Titre Virtual machines: versatile platforms for systems and processes,Elsevier - 2005, (ISBN 9781558609105)
- (en)Maximum PC,déc. 2008, (ISSN 1522-4279)
- (en)Michael A. Davis - Sean Bodmer et Aaron LeMasters,Hacking exposed malware & rootkits: malware & rootkits security secrets & solutions,McGraw Hill Professional, 2009, (ISBN 9780071591188)
- (en)F. J. M. Laver,An introduction to the uses of computers,CUP Archive - 1976, (ISBN 9780521290357)
- (en)James Edward Smith et Ravi Nair,Virtual machines: versatile platforms for systems and processes,Elsevier - 2005, (ISBN 9781558609105)
- (en)Joshua Engel,Programming for the Java virtual machine,Addison-Wesley Professional - 1999, (ISBN 9780201309720)
- (en)Ivanka Menken et Gerard Blokdijk,Virtualization: The Complete Cornerstone Guide to Virtualization Best Practices,Lulu.com - 2008, (ISBN 9781921523915)