ebook img

Server architectures: multiprocessors, clusters, parallel systems, web servers, and storage solutions PDF

782 Pages·2004·8.13 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Server architectures: multiprocessors, clusters, parallel systems, web servers, and storage solutions

Server Architectures This Page Intentionally Left Blank Server Architectures Multiprocessors, Clusters, Parallel Systems, Web Servers, and Storage Solutions René J. Chevance Amsterdam • Boston • Heidelberg • London • New York • Oxford Paris • San Diego• San Francisco • Singapore • Sydney • Tokyo Elsevier Digital Press 30 Corporate Drive, Suite 400, Burlington, MA 01803, USA Linacre House, Jordan Hill, Oxford OX2 8DP, UK Copyright © 2005, Editions Eyrolles, excepting Chapter 6, Data Storage. Chapter 6, Data Storage, Copyright © 2005, René J. Chevance No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Permissions may be sought directly from Elsevier’s Science & Technology Rights Department in Oxford, UK: phone: (+44) 1865 843830, fax: (+44) 1865 853333, e-mail: [email protected]. You may also complete your request on-line via the Elsevier homepage (http://elsevier.com), by selecting “Customer Support” and then “Obtaining Permissions.” Recognizing the importance of preserving what has been written, Elsevier prints its books on acid-free paper whenever possible. Library of Congress Cataloging-in-Publication Data Application submitted. British Library Cataloguing-in-Publication Data A catalogue record for this book is available from the British Library. ISBN: 1-55558-333-4 For information on all Elsevier Digital Press publications visit our Web site at www.books.elsevier.com For this work which treats industrial products and technological projects, many sources of information were used. These sources of information are referred at the time of their use. It is obvious that all the inaccuracies or omissions are the fact of the author and do not engage the companies, organizations or people having produced information being used as source. The comments and opinions presented in this work engage only the author. Trademarks cited herein are the property of their respective owners. 04 05 06 07 08 09 10 9 8 7 6 5 4 3 2 1 Printed in the United States of America To Josiane, Cyrille and Maxime Acknowledgements Creating a book and preparing it for publication is, for its author, a rather private effort but one which is fed and nourished through many discussions and exchanges of opinion. I must therefore start by thanking my colleagues at Bull along with the industry repre- sentatives and researchers with all of whom I have had many fruit- ful exchanges and discussions. But I must go further and single out some colleagues for spe- cial thanks: Jean Papadopoulo, Jean-Jacques Pairault, Michel Pon- tacq and Pierre Roux of Bull for their comments and suggestions for the preliminary version; Lazzaro Pejsachowicz for his help with the section on security; my collegaues at CNAM—and in particu- lar Jean-Pierre Meinadier, a full professor and Systems Integration Chair there—for the many exchanges and discussions. I added a new chapter on storage for the English language ver- sion, which benefitted greatly from input from Jean Papadopoulo and Michel Pontaq (Bull) and Jacques Péping (StorageAcademy). Finally, the translation into English was done to my complete satisfaction by Pete Wilson (also ex-Bull), who brought an excel- lent spirit of cooperation to the task along with his understand- ing of the subject matter to allow us to bring the work to a successful conclusion. Thank you to Tim Donar who reviewed and performed the technical edits for the American printing. About the Author René Chevance has an engineering degree from Conservatoire National des Arts et Métiers (CNAM) and a Doctorat d'Etat Es- Sciences from Université Paris 6. He joined CII in 1968, a Company which later merged with Groupe Bull. In his role of system architect and later as Chief Scien- tist, he has initiated a large number of projects. He has also a wide teaching experience for 20 years at Université Paris 6 (Compiler Construction, Software Engineering) and for more than 10 years, as an Associate Professor, at CNAM (System Architecture and System Integration). He wrote several papers and a book on server architectures “Serveurs Multiprocesseurs, clusters et architectures parallèles” Eyrolles (Paris april 2000). He left Groupe Bull in 1999 to become an independent con- sultant. He can be reached at [email protected] or through his Web site www.chevance.com. Contents Preface xvii Objective of the Book xvii A Changing Industry Based on Changing Technology xvii Structure of the book xviii Origin of the Book xix Server FAQs xix Introduction xxix Transaction Processing and Decision Support xxix Web Servers xxxvi Selection Criteria xxxviii Endnotes xl Part 1: Architectural Options and Technology Evolution 1 P.1 Systems Architecture Basics 2 P.2 Historical Notes about System Architecture 8 P.3 Endnotes 12 1 Processors and Memory 13 1.1 Semiconductors and Microprocessors 13 1.2 Semiconductor Technology Projections 20 1.2.1 DRAM Memory 20 1.2.2 Microprocessors 21 1.3 Economic Aspects of Microprocessors 22 1.4 Embedded Systems 24 1.5 Memory Hierarchy 25 1.5.1 Characteristics of the Various Levels in a Memory System 26 vii viii Contents 1.5.2 Space-Time Locality Properties 29 1.5.3 Cache Design Parameters 32 1.6 The Problem of Memory Throughput 36 1.6.1 Memory Hierarchy Summary 38 1.7 Processor—Memory—I/O Interconnect 40 1.7.1 Bus and Crossbar Interconnect 41 1.7.2 Other Connections 44 1.8 Parallelism 44 1.8.1 Speedup and Scaleup 48 1.8.2 Problems Arising in Multiprocessor Architectures 53 1.8.3 Cache Coherence 53 1.8.4 Models of Memory Consistency 57 1.8.5 Synchronization Mechanisms 59 1.8.6 Examples of Implementing Traditional Synchronization Primitives with the Instruction Pair 60 1.9 Binary Compatibility Constraints—Java and Architecture Retargeting 62 1.10 Compilation and Interpretation 66 1.11 Java 68 1.12 Architecture Retargeting 69 1.12.1 Compiler Retargeting 71 1.12.2 Emulation 72 1.12.3 Example of Architecture Retargeting Through Emulation: Bull DPS7000 73 1.12.4 Example of Dynamic Object Code Translation: Transmeta 78 1.13 Microprocessor Evolution 79 1.13.1 Traditional Performance Improvement Techniques 79 1.13.2 Processor Structures: Pipelines and Superscalarity 82 1.13.3 Basic Pipelined Processor 84 1.13.4 Superscalar Processors 86 1.13.5 Comparison of the Superscalar and Deeply-Pipelined Structures 87 1.13.6 VLIW Processor 88 1.13.7 Speculative Execution 90 1.13.8 Out-of-Order Execution and Register Renaming 90 1.13.9 Branch Prediction 92 1.13.10 Dynamic Translation of Code 93 1.13.11 Architecture Evolution 95 1.13.12 Implementation Evolution 105 1.13.13 Trace cache 106 1.14 Economic Factors 107 Contents ix 1.15 Formal Verification 111 1.16 Memory 111 1.16.1 Intelligent Memory 112 1.17 Endnotes 114 2 I/O 117 2.1 PCI, SCSI, and Fibre Channel 119 2.2 SCSI and Fibre Channel 121 2.3 ATA 126 2.4 A New I/O Architecture: InfiniBand 128 2.5 Virtual Interface Architecture 137 2.6 Data Storage 141 2.6.1 Magnetic Disks 144 2.7 Networks and Communications Subsystems 151 2.7.1 Network Technologies 152 2.7.2 Server Support for Communications 154 2.7.3 Reducing the Number of Interrupts 157 2.8 Input Output Evolution 162 2.8.1 I/O 162 2.8.2 Disk Evolution 163 2.8.3 Intelligent Disks 166 2.8.4 Networks and Network Connections 167 2.9 Endnotes 169 3 Evolution of Software Technology 171 3.1 Virtual Memory and 64-Bit Architecture 171 3.1.1 Virtual Memory 171 3.1.2 Virtual Address Spaces 174 3.1.3 Virtual Address Translation Mechanisms 178 3.1.4 64-Bit Architecture 180 3.2 Operating Systems 182 3.2.1 Operating Systems Functionality 185 3.2.2 Operating Systems: a Conclusion 194 3.3 Client/Server Applications and Middleware 196 3.3.1 Client/Server Architecture Models and Middleware Components 196 3.3.2 Components of Client/Server Middleware 199 3.3.3 Web Servers 202 3.3.4 Transactional Monitors 203 3.3.5 RPC and Message-Oriented Middleware 213 Contents

Description:
The goal of this book is to present and compare various options one for systems architecture from two separate points of view. One, that of the information technology decision-maker who must choose a solution matching company business requirements, and secondly that of the systems architect who find
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.