Network RAM Based Process Migration for HPC Clusters

Total Page:16

File Type:pdf, Size:1020Kb

Network RAM Based Process Migration for HPC Clusters Journal of Information Systems and Telecommunication, Vol. 1, No. 1, Jan – March 2013 39 Network RAM Based Process Migration for HPC Clusters Hamid Sharifian* Department of Computer Engineering, Iran University of Science and Technology, Tehran, Iran [email protected] Mohsen Sharifi Department of Computer Engineering, Iran University of Science and Technology, Tehran, Iran [email protected] Received: 04/Dec/2012 Accepted: 09/Feb/2013 Abstract Process migration is critical to dynamic balancing of workloads on cluster nodes in any high performance computing cluster to achieve high overall throughput and performance. Most existing process migration mechanisms are however unsuccessful in achieving this goal proper because they either allow once-only migration of processes or have complex implementations of address space transfer that degrade process migration performance. We propose a new process migration mechanism for HPC clusters that allows multiple migrations of each process by using the network RAM feature of clusters to transfer the address spaces of processes upon their multiple migrations. We show experimentally that the superiority of our proposed mechanism in attaining higher performance compared to existing comparable mechanisms is due to effective management of residual data dependencies. Keywords: High Performance Computing (HPC) Clusters, Process Migration, Network RAM, Load Balancing, Address Space Transfer. 1. Introduction and data access locality in addition to an enhanced degree of dynamic load distribution [1]. A standard approach to reducing the runtime Upon migration of a process, the process of any high performance scientific computing must be suspended and its context information in application on a high performance computing the source node extracted and transferred to the (HPC) cluster is to partition the application into destination node. The process can only then several portions that can be run in parallel by resume executing from the point it was multiple cluster nodes simultaneously. suspended. Two critical challenges of process HPC clusters generally consist of three main migration are the transfer of the process address parts: a collection of off-the-shelf (COTS) space from the source node to the destination computing and storage nodes, a network node, and access to the opened files in the connecting the nodes, and a cluster manager destination node after process migration [2]. system software that manages all nodes and In this paper we only focus on resolving the presents a single system image to applications first challenge of process migration by while exploiting the parallel processing power of introducing a new process migration mechanism multiple nodes. by using the network RAM feature of HPC The cluster manager system software clusters, wherein the aggregate main memory of provides a set of global services that aim at all cluster nodes in a cluster represents the making resource distribution transparent to all network RAM of that cluster [3]. In addition to applications, managing resource sharing between achieve comparably higher performance than applications, deploying as much cluster resources existing process migration mechanisms, our as possible for demanding applications, and proposed mechanism is intended to allow for scheduling parallel processes on all cluster nodes. multiple-migration of each process that is a The services include global resource missing feature in existing process migration management, distributed scheduling, load mechanisms that is accounted as a source of sharing, process migration, and network RAM. inefficiency. Dynamic load sharing can be achieved by The rest of paper is organized as follows. moving processes from heavily-loaded nodes to Sections 2 and 3 introduce process migration and lightly-loaded nodes at runtime. This can lead to network RAM. Section 4 reviews related works fault resilience, ease of system administration, on process migration with respect to transfer of * Corresponding Author 40 Sharifian & Sharifi, Network RAM Based Process Migration 48 for HPC Clusters process address space. Sections 5 and 6 present The context of a process to be migrated our network RAM based mechanism and its includes the process’s running state; stack evaluation, and Section 7 concludes the paper. contents; processor registers; address space; heap data; and process’s communication state (like open files or message channels). The whole 2. Process Migration context must be transferred to the destination node before the process can continue its Process migration is the act of transferring an execution on the destination node. The process active process between two computers and address space is the largest part of the process restoring its execution in a destination node from context that might have hundreds of megabyte of the point it left off in the source node. The goals data [5] taking longest to be transferred to the of process migration are closely tied to destination node. This can adversely affect the applications that use migration. The primary performance of process migration. Therefore, the goals include resource locality, resource sharing, performance of any process migration dynamic load balancing, fault resilience, and mechanism largely depends on how long it takes ease of system administration [1]. Any process to transfer the context of migrant processes to migration mechanism can thus be benchmarked destination nodes. and evaluated with respect to the degree it Various data transfer techniques have been satisfies these goals. presented in the literature that try to reduce the Considering an HPC cluster, process high cost of address space transfer [6]. A well- migration has three main phases [4] (note that known technique is to transfer only parts of these phases are applicable to process migration process address space to allow resumption of in all types of networks of computers in general processes on destination nodes without waiting including HPC clusters that are the main focus of for the transfer of the whole process address this paper): space and context. Though very attractive on 1. Detaching Phase that involves the grounds of improving the performance of process suspension and the extraction of the migration, this technique leaves parts (pages) of context of a migrant process in its current process address space on different nodes when node. These activities must be done in a multiple migrations in the lifetime of process is way that none of the other processes allowed and occurs. In other words, the process running on the current node or in other address space is scattered on multiple nodes nodes of the cluster experience any resulting in residual dependencies. Management execution inconsistencies. At the start of of residual dependencies increases the this phase, the execution of the migrant implementation complexity of process migration process is frozen. that in turn results in performance degradation of 2. Transfer Phase that involves the transfer process migration. of the extracted context of the migrant Our proposed mechanism is particularly process to the destination node. useful to strong migrations wherein the entire 3. Attaching Phase that involves the process state (rather than code and some reconstruction of the migrant process on initialization data in weak code migration) must the destination node. The reconstruction in be transferred to destination. turn involves the allocation of resources on the target node to the migrant process, informing the beneficiaries and/or brokers 3. Network RAM of the migrant process about the current executing place of the migrant process, Large-memory high-performance applications and resuming the execution of the migrant such as scientific computing, weather prediction process on the destination node from the simulations, data warehousing and graphic point it left off on the source node. rendering applications need massive fast The time interval between freezing a migrant accessible address spaces [7] that are not provided process on a source node and resuming its by even high capacity DRAMs. The runtime execution on a destination node is called the performance of these applications degrades freeze time representing the status wherein the quickly when system encounters memory shortage migrant process is neither executing on the and starts swapping memory to local disks. source nor executing on the destination node. In today’s clusters with very low-latency The longer the freeze time the lower will be the networks, the idle memory of other nodes can be performance of the process migration. used as storage media faster than local disks, called network RAM. The goal of network RAM Journal of Information Systems and Telecommunication, Vol. 1, No. 1, Jan – March 2013 41 is to improve the performance of memory 4.3 DSM-based Techniques intensive workloads by paging to idle memory over the network rather than to disk [8]. Some HPC clusters have used the distributed Some common uses of network RAM are shared memory (DSM) mechanism to transfer remote memory paging [9], network memory file process address spaces between nodes upon systems, and swap block devices [10,11]. process migrations. Pages stored on DSM need Locating unused memory in every node requires not be transferred at all during process migration. that network RAM keeps up-to-date information Only pages accessed by the migrant after about all unused memories. migration are provided to the migrant process Since network RAM stores
Recommended publications
  • Dynamic Scheduling with Process Migration*
    Dynamic Scheduling with Process Migration* Cong Du, Xian-He Sun, and Ming Wu Department of Computer Science Illinois Institute of Technology Chicago, IL 60616, USA {ducong, sun, wuming}@iit.edu Abstract* computing resources. In addition, besides load balance, migration-based dynamic scheduling also benefits Process migration is essential for runtime load dynamic Grid management [19] in the cases of new balancing. In Grid and shared networked machines joining or leaving, resource cost variation, environments, load imbalance is not only caused by the and local task preemption. dynamic nature of underlying applications, but also by An appropriate rescheduling should consider the the fluctuation of resource availability. In a shared migration costs. This is especially true in distributed environment, tasks need to be rescheduled frequently and heterogeneous environments, where plenty of to adapt the variation of resources availability. Unlike computing resources are available at any given time conventional task scheduling, dynamic rescheduling but the associated migration costs may vary largely. An has to consider process migration costs in its effective and broadly applicable solution for modeling formulation. In this study, we first model the migration and estimating migration costs, however, has been cost and introduce an effective method to predict the elusive. Even if an estimate is available, integrating cost. We then introduce a dynamic scheduling migration cost into a dynamic scheduling system is still mechanism that considers migration cost as well as a challenging task. Based on our years of experience in other conventional influential factors for performance process migration [8] and task scheduling [24], we optimization in a shared, heterogeneous environment.
    [Show full text]
  • Architectural Review of Load Balancing Single System Image
    Journal of Computer Science 4 (9): 752-761, 2008 ISSN 1549-3636 © 2008 Science Publications Architectural Review of Load Balancing Single System Image Bestoun S. Ahmed, Khairulmizam Samsudin and Abdul Rahman Ramli Department of Computer and Communication Systems Engineering, University Putra Malaysia, 43400 Serdang, Selangor, Malaysia Abstract: Problem statement: With the growing popularity of clustering application combined with apparent usability, the single system image is in the limelight and actively studied as an alternative solution for computational intensive applications as well as the platform for next evolutionary grid computing era. Approach: Existing researches in this field concentrated on various features of Single System Images like file system and memory management. However, an important design consideration for this environment is load allocation and balancing that is usually handled by an automatic process migration daemon. Literature shows that the design concepts and factors that affect the load balancing feature in an SSI system are not clear. Result: This study will review some of the most popular architecture and algorithms used in load balancing single system image. Various implementations from the past to present will be presented while focusing on the factors that affect the performance of such system. Conclusion: The study showed that although there are some successful open source systems, the wide range of implemented systems investigated that research activity should concentrate on the systems that have already been proposed and proved effectiveness to achieve a high quality load balancing system. Key words: Single system image, NOWs (network of workstations), load balancing algorithm, distributed systems, openMosix, MOSIX INTRODUCTION resources transparently irrespective of where they are available[1].The load balancing single system image Cluster of computers has become an efficient clusters dominate research work in this environment.
    [Show full text]
  • Process Migration in Distributed Systems
    Process Migration in Distributed Systems Shek Lun Ho Computer Science Department University of Southern California Los Angeles, CA90007 [email protected] Process Migration is the ability of a system (operating system or user-space program) to transfer processes between different nodes in a network. The motivations behind process migration are to balance load, improve availability, enhance communication performance and ease system administration[13]. However, since a process involves and interacts with many different components of an operating system, migration of a process is technically complicated and demands a great deal of researches. This paper presents key concepts of process migration, design and implementation issues, and illustrates these concepts by several case studies on the typical implementations – MOSIX, Sprite, Condor and V. 1. Introduction Process Migration has been in the computer science literature for more than two decades. One of the earliest concept papers introduces programs that can span machine boundaries in search of free machine for executions as “worms”[3]. Subsequent papers refine the concept of process migration as a potential mean to share processing power and other resources among multiple processors. Numerous papers and implementations have been proposed to introduce process migration on different architectures such as symmetric multiprocessors, Non-Uniform Memory Access (NUMA) multiprocessor, Massively Parallel Processors (MPP) and Local Area Network (LAN) of computers. A process is an operating system (OS) entity of a program in execution. Associated with it are address space and other OS internal attributes such as home directory, open file descriptors, user id, program counter and so on. Process migration is defined as the transfer of a process between different nodes connected by a network.
    [Show full text]
  • An Introduction to Single System Image (SSI) Cluster Technique
    Volume III, Issue IV, April 2014 IJLTEMAS ISSN 2278 - 2540 An Introduction to Single System Image (SSI) Cluster Technique Tarun Kumawat [CSE] , JECRC UDML College of Engineering. Kukas, Jaipur, Rajasthan, India1 Sandeep Tomar [CSE] , Arya College of Engineering & I.T. Kukas, Jaipur, Rajasthan, India2 Mohit Gupta [CSE] , Arya College of Engineering & I.T. Kukas, Jaipur, Rajasthan, India3 [email protected] [email protected] 3 [email protected] beowulf.myinstitute.edu), although the cluster Abstract-Cluster computing is not a new area of computing. may have multiple physical host nodes to serve It is, however, evident that there is a growing interest in its the login session. The system transparently usage in all areas where applications have traditionally used distributes user’s connection requests to different parallel or distributed computing platforms. A Single System physical hosts to balance load. Image (SSI) is the property of a system that hides the Single user interface: The user should be able to heterogeneous and distributed nature of the available use the cluster through a single GUI. The resources and presents them to users and applications as a single unified computing resource. SSI can be enabled in interface must have the same look and feel than numerous ways, this range from those provided by extended the one available for workstations (e.g., Solaris hardware through to various software mechanisms. SSI OpenWin or Windows NT GUI). means that users have a globalised view of the resources Single process space: All user processes, no available to them irrespective of the node to which they are matter on which nodes they reside, have a unique physically associated.
    [Show full text]
  • Efficient Use of Execution Resources in Multicore Processor Architectures
    UNIVERSITY OF CALIFORNIA, SAN DIEGO Efficient Use of Execution Resources in Multicore Processor Architectures A dissertation submitted in partial satisfaction of the requirements for the degree Doctor of Philosophy in Computer Science (Computer Engineering) by Matthew David DeVuyst Committee in charge: Professor Dean Tullsen, Chair Professor Clark Guest Professor Chandra Krintz Professor Sorin Lerner Professor Steven Swanson 2011 Copyright Matthew David DeVuyst, 2011 All rights reserved. The dissertation of Matthew David DeVuyst is approved, and it is acceptable in quality and form for publication on microfilm and electronically: Chair University of California, San Diego 2011 iii DEDICATION Soli Deo Gloria iv EPIGRAPH For from Him and through Him and to Him are all things. To Him be the glory forever. Amen. |Romans 11:36 (NASB version) v TABLE OF CONTENTS Signature Page.................................. iii Dedication..................................... iv Epigraph.....................................v Table of Contents................................. vi List of Figures.................................. ix List of Tables................................... xi Acknowledgements................................ xii Vita and Publications.............................. xiv Abstract of the Dissertation........................... xv Chapter 1 Introduction............................1 1.1 Parallelizing Single-Threaded Code............4 1.2 Managing Heterogeneity..................5 1.2.1 Scheduling in a CMP of SMT Cores........5 1.2.2 Migrating Execution
    [Show full text]
  • Process Migration
    Process Migration DEJAN S. MILOJI´ CIˇ C´ HP Labs FRED DOUGLIS AT&T Labs–Research YVES PAINDAVEINE TOG Research Institute RICHARD WHEELER EMC AND SONGNIAN ZHOU University of Toronto and Platform Computing Process migration is the act of transferring a process between two machines. It enables dynamic load distribution, fault resilience, eased system administration, and data access locality. Despite these goals and ongoing research efforts, migration has not achieved widespread use. With the increasing deployment of distributed systems in general, and distributed operating systems in particular, process migration is again receiving more attention in both research and product development. As high-performance facilities shift from supercomputers to networks of workstations, and with the ever-increasing role of the World Wide Web, we expect migration to play a more important role and eventually to be widely adopted. This survey reviews the field of process migration by summarizing the key concepts and giving an overview of the most important implementations. Design and implementation issues of process migration are analyzed in general, and then revisited for each of the case studies described: MOSIX, Sprite, Mach, and Load Sharing Facility. The benefits and drawbacks of process migration depend on the details of implementation and, therefore, this paper focuses on practical matters. This survey will help in understanding the potentials of process migration and why it has not caught on. Categories and Subject Descriptors: C.2.4 [Computer-Communication
    [Show full text]
  • Single System Image in a Linux-Based Replicated Operating System Kernel
    Single System Image in a Linux-based Replicated Operating System Kernel Akshay Giridhar Ravichandran Thesis submitted to the Faculty of the Virginia Polytechnic Institute and State University in partial fulfillment of the requirements for the degree of Master of Science in Computer Engineering Binoy Ravindran, Chair Robert P. Broadwater Antonio Barbalace February 24, 2015 Blacksburg, Virginia Keywords: Linux, Multikernel, Thread synchronization, Signals, Process Management Copyright 2015, Akshay Giridhar Ravichandran Single System Image in a Linux-based Replicated Operating System Kernel Akshay Giridhar Ravichandran (ABSTRACT) Recent trends in the computer market suggest that emerging computing platforms will be increasingly parallel and heterogeneous, in order to satisfy the user demand for improved performance and superior energy savings. Heterogeneity is a promising technology to keep growing the number of cores per chip without breaking the power wall. However, existing system software is able to cope with homogeneous architectures, but it was not designed to run on heterogeneous architectures, therefore, new system software designs are necessary. One innovative design is the multikernel OS deployed by the Barrelfish operating system (OS) which partitions hardware resources to independent kernel instances that communi- cate exclusively by message passing, without exploiting the shared memory available amongst different CPUs in a multicore platform. Popcorn Linux implements an extension of the mul- tikernel OS design, called replicated-kernel OS, with the goal of providing a Linux-based single system image environment on top of multiple kernels, which can eventually run on dif- ferent ISA processors. A replicated-kernel OS replicates the state of various OS sub-systems amongst kernels that cooperate using message passing to distribute or access various services uniquely available on each kernel.
    [Show full text]
  • A Comparison of Two Distributed Systems: Amoeba and Sprite
    A Comparison of Two Distributed Systems: Amoeba and Sprite Fred Douglisx Matsushita Information TÞchnology Laboratory John K. Ousterhout University of California, Berkeley M. Frans Kaashoek Andrew S. Thnenbaum Vrije Universiteit Amsterdam, The Netherlands ABSTRACT This paper compares two distributed oper- ating systems, Amoeba and Sprite. Although the sys- tems share many goals, they diverged on two philo- sophical grounds: whether to emphasize a distributed computing model or traditional UNIX-style applica- tions, and whether to use a workstation-centered model of computation or a combination of terminals and a shared processor pool. Many of the most prominent features of the systems (both positive and negative) fol- low from the philosophical differences. For example, Amoeba provides a high-performance user-level IPC mechanism, while Sprite's RPC mechanism is only available for kernel use; Sprite's file access perfor- mance benefits from client-level caching, while Amoeba This work was supported in part by the Netherlands Organization for Scientific Research (N.W.O.) under grant NF 62-334. @ Computíng Systems, Vol. 4 . No. 4 . Fall 1991 353 caches files only on servers; and Sprite uses a process migration model to share compute power, while Amoeba uses a centralized server to allocate processors and distribute load automatically. I . Introduction The shift from time-sharing computers to collections of processors connected by a local-area network has motivated the development of numerous distributed operating systems [Abrossimov et al. 1989; Cheriton 1988; Mullender et al. l99O:' Ousterhout et al. 19881. This paper compares two distributed systems, Amoeba [Mullender et al. 1990; Thnenbaum et al.
    [Show full text]
  • Process Migration in a Parallel Environment
    Institut für Höchstleistungsrechnen FORSCHUNGS- UND ENTWICKLUNGSBERICHTE PROCESS MIGRATION IN A PARALLEL ENVIRONMENT Adrian Reber ISSN 0941 - 4665 May 2016 HLRS-16 Höchstleistungsrechenzentrum Universität Stuttgart Prof. Dr.-Ing. Dr. h.c. Dr. h.c. Prof. E.h. M. M. Resch Nobelstrasse 19 - 70569 Stuttgart Institut für Höchstleistungsrechnen PROCESS MIGRATION IN A PARALLEL ENVIRONMENT von der Fakultät Energie-, Verfahrens- und Biotechnik der Universität Stuttgart zur Erlangung der Würde eines Doktor-Ingenieurs (Dr.-Ing.) genehmigte Abhandlung vorgelegt von Adrian Reber aus Esslingen Hauptberichter: Prof. Dr.- Ing. Dr. h.c. Dr. h.c. Prof. E.h. Michael M. Resch Mitberichter: Prof. rer. nat. Peter Väterlein Prof. Dr.-Ing. Stefan Wesner Tag der mündlichen Prüfung: 03.12.2015 CR-Klassifikation: I.3.2, I.6.6 D93 ISSN 0941 - 4665 May 2016 HLRS-16 Contents 1 Introduction 21 1.1 Motivation . 21 1.2 Goals . 22 1.3 Structure of this work . 22 2 State of the Art 25 2.1 Hypervisor . 28 2.2 Para-Virtualization and Container Based . 29 2.3 I/O Accesses . 29 2.4 Process Migration . 30 3 Process Migration 33 3.1 The Process . 33 3.1.1 Process Management . 34 3.1.2 Memory Management . 35 3.1.3 File Management . 36 3.2 Memory Transfer Methods . 37 3.2.1 Memory Transfer During Migration . 38 3.2.2 Memory Transfer After Migration . 39 3.2.3 Memory Transfer Before Migration . 40 3.3 Preemptive Migration . 41 3.3.1 Single System Image . 43 3.4 Checkpoint/Restore Migration . 43 3.4.1 Berkeley Lab Checkpoint/Restart . 46 5 6 Contents 3.4.2 Distributed MultiThreaded Checkpointing .
    [Show full text]
  • Process Migration DEJAN S
    Process Migration DEJAN S. MILOJICIC†, FRED DOUGLIS‡, YVES PAINDAVEINE††, RICHARD WHEELER‡‡ and SONGNIAN ZHOU* † HP Labs, ‡ AT&T Labs–Research, †† TOG Research Institute, ‡‡ EMC, and *University of Toronto and Platform Computing Abstract Process migration is the act of transferring a process between two machines. It enables dynamic load distribution, fault re- silience, eased system administration, and data access locality. Despite these goals and ongoing research efforts, migration has not achieved widespread use. With the increasing deployment of distributed systems in general, and distributed operat- ing systems in particular, process migration is again receiving more attention in both research and product development. As high-performance facilities shift from supercomputers to networks of workstations, and with the ever-increasing role of the World Wide Web, we expect migration to play a more important role and eventually to be widely adopted. This survey reviews the field of process migration by summarizing the key concepts and giving an overview of the most important implementations. Design and implementation issues of process migration are analyzed in general, and then revis- ited for each of the case studies described: MOSIX, Sprite, Mach and Load Sharing Facility. The benefits and drawbacks of process migration depend on the details of implementation and therefore this paper focuses on practical matters. This survey will help in understanding the potentials of process migration and why it has not caught on. Categories and Subject Descriptors: C.2.4 [Computer-Communication Networks]: Distributed Systems - network oper- ating systems; D.4.7 [Operating Systems]: Organization and Design - distributed systems; D.4.8 [Operating Systems]: Performance: measurements; D.4.2 [Operating Systems]: Storage Management - distributed memories.
    [Show full text]
  • A Survey on Process Migration Vinita Sharma* Dr
    ISSN No. 0976-5697 Volume 3, No. 6, Nov. 2012 (Special Issue) International Journal of Advanced Research in Computer Science CASE STUDY AND REPORT Available Online at www.ijarcs.info A Survey on Process Migration Vinita Sharma* Dr. Vineet Sharma M.Tech Scholar, Dept of CSE, Associate Professor, Dept of CSE, KIET, Ghaziabad KIET, Ghaziabad Abstract: The days of supercomputers and mainframes dominating computing are over. With the cost benefits of the mass production of smaller machines, the majority of today’s computing power exists in the form of PCs or workstations, with more powerful machines performing more specialized tasks. Even with increased computer power and availability, some tasks require more resources. Load balancing and process migration allocates processes to interconnected workstations on a network to better take advantage of available resources. Process migration is the act of transferring a process between two machines during its execution. It enables dynamic load distribution, fault resilience, eased system administration, and data access locality. With the increasing deployment of distributed systems in general, and distributed operating systems in particular, process migration is receiving more attention in both research and product development. As high- performance facilities shift from supercomputers to networks of workstations, and with the ever-increasing role of the World Wide Web, we expect migration to play a more important role and eventually to be widely adopted. This paper reviews the field of process migration by summarizing the key concepts involved in it and by highlighting the benefits and challenges faced by the process migration. It also includes the experience of process migration in distributed operating system.
    [Show full text]
  • Experiences with the Amoeba Distributed Operating System
    Experiences with the Amoeba Distributed Operating System Andrew S. Tanenbaum Robbert van Renesse1 Hans van Staveren Gregory J. Sharp Dept. of Mathematics and Computer Science Vrije Universiteit De Boelelaan 1081 1081 HV Amsterdam, The Netherlands Internet: [email protected], [email protected], [email protected], [email protected] Sape J. Mullender2 Jack Jansen Guido van Rossum Centrum voor Wiskunde en Informatica Kruislaan 413 1098 SJ Amsterdam, The Netherlands Internet: [email protected], [email protected], [email protected] The Amoeba distributed operating system has been in development and use for over eight years now. In this paper we describe the present system and our experience with itÐwhat we did right, but also what we did wrong. Among the things done right were basing the system on objects, using a single uniform mechanism (capabilities) for naming and protecting them in a location independent way, and designing a completely new, and very fast file system. Among the things done wrong were having threads not be pre-emptable, ini- tially building our own homebrew window system, and not having a multicast facility at the outset. Computing Reviews categories: C.2.4, D.4 Keywords: Operating systems, Distributed systems, Distributed operating sys- tems, Computer networks, Experience Descriptors: Network operating systems, Distributed applications, Distributed systems, Measurements General terms: Design, Experimentation, Performance ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ ¡ 1. This research was supported in part by the Netherlands Organization for Scientific Research (N.W.O.) under grant 125-30-10. - 2 - INTRODUCTION The Amoeba project is a research effort aimed at understanding how to connect multiple com- puters together in a seamless way [15, 16, 26, 28, 32] The basic idea is to provide the users with the illusion of a single powerful timesharing system, when, in fact, the system is imple- mented on a collection of machines, potentially distributed among several countries.
    [Show full text]