Les logiciels que nous utilisons tous les jours se caractérisent par une complexité croissante. Ceci est dû tant à l'évolution du contexte dans lequel ils s'exécutent qu'aux exigences des utilisateurs. À chacune de ces évolutions ont correspondu des réponses par le biais de la virtualisation. En effet, la création d'un environnement virtuel d'exécution permet la prise en charge, par cet environnement, d'une part de cette complexité. Parallèlement les processeurs ont vu leurs performances augmenter de façon à pouvoir absorber le surcoût de traitement induit par ces diverses couches logicielles de virtualisation. Cette évolution s'est faite, dans un premier temps, de façon transparente pour les programmeurs. Toutefois cette augmentation des performances atteint, depuis peu, ses limites théoriques et les constructeurs se sont naturellement tournés vers des solutions de type multiprocesseurs. Ce livre montre comment les plates-formes et les machines virtuelles constituent des réponses à la complexité dans le cadre de cette évolution en pouvant s'exécuter en parallèle des applications sur un ou plusieurs processeurs et prendre en charge une partie non négligeable de leur activité.