ebook img

Virtual Machine Live Migration in Cloud Computing PDF

123 Pages·2013·3 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 Virtual Machine Live Migration in Cloud Computing

Virtual Machine Live Migration in Cloud Computing Jie Zheng Abstract Cloud computing services have experienced rapid growth. Virtualization, a key technology for cloud computing, provides an abstraction to hide the complexity of underlying hard- ware or software. The management of a pool of virtualized resources requires the ability to flexibly map and move applications and their data across and within pools. Live migration, which enables such management capabilities, ushers in unprecedented flexibility for busi- nesses. To unleash the benefits, commercial products already enable the live migration of full virtual machines between distant cloud datacenters. Unfortunately, two problems exist. First, no live migration progress management sys- tem exists, leading to (1) guesswork over how long a migration might take and the inability to schedule dependent tasks accordingly; (2) inability to balance application performance and migration time – e.g. to finish migration later for less performance interference. Second, multi-tier application architectures are widely employed in today’s virtualized cloud computing environments. Although existing solutions are able to migrate a single VM efficiently, little attention has been devoted to migrating related VMs in multi-tier ap- plications. Application components could become split over distant cloud datacenters for an arbitrary period during migration and that causes unacceptable application degradations. Ignoring the relatedness of VMs during migration can lead to serious application perfor- mance degradation. In this thesis, the first contribution is Pacer – the first migration process management system capable of accurately predicting the migration time and managing the progress so that the actual migration finishing time is as close to a desired finish time as possible. Pacer’s techniques are based on robust and lightweight run-time measurements of system and workload characteristics, efficient and accurate analytic models for progress predic- tions, and online adaptation to maintain user-defined migration objectives for timely mi- grations. The second contribution is COMMA – the first coordinated live migration system of multi-tier applications. We formulate the multi-tier application migration problem, and present a new communication-cost-driven coordinated approach, as well as a fully imple- mented system on KVM that realizes this approach. COMMA is based on a two-stage scheduling algorithm for coordinating the migration of VMs that aims to minimize migra- tion’s impact on inter-component communications. COMMA focuses on the coordination of multiple VM’s migration where each VM’s migration progress is handled by Pacer. COMMA’s scheduling algorithm has low computational complexity; as a result, COMMA is highly efficient. Through extensive experiments including a real-world commercial cloud scenario with Amazon EC2, we show that Pacer is highly effective in predicting migration time and con- trolling migration progress and COMMA is highly effective in decreasing the performance degradation cost and minimizing migration’s impact on inter-component communications. We believe this thesis will have far reaching impact. COMMA and Pacer are applicable to all sorts of intra-data center and inter-data center VMmigration scenarios. Together, they solve some of the most vexing VMmigration management problems faced by operators to- day. The techniques underlying Pacer and COMMA are not specific to the KVM platform. The techniques can easily be ported to other virtualization platforms such as VMware, Xen and Hyper-V. iv Acknowledgments My foremost thank goes to my advisor Professor T. S. Eugene Ng. I thank him for all of his help, inspiration and guidance in my graduate study. He is the best advisor I can ever imagine. I thank him for his patience and encouragement that always carried me through difficult times, and for his insights and suggestions that helped to shape my research skills. His passion for science has influenced me a lot. His valuable feedback contributed greatly to this thesis. I wish to express my sincere gratitude to Dr. Kunwadee (Kay) Sripanidkulchai. I had the fortune to work with Kay during my summer internship at IBM. She helped me on every aspect of the research related to this thesis. She taught me a vast amount of knowledge in the areas of cloud computing and machine virtualization and introduced me to many advanced techniques. I really appreciate her sound advice, good company, interesting ideas and suggestions. Without the help from Eugene and Kay, this thesis would not have been possible. I am grateful to my team member Zhaolei (Fred) Liu for his help in setting up the test bed on Amazon EC2. The demonstration for our system on the commercial public cloud elevates our system to a new level. The discussion with Fred helped a lot in my research and thesis writing and made our collaboration the most productive part. I wish to thank Professor Alan L. Cox who helped me setup the experiment environment and suggested me to use VMmark to explore the I/O patterns. Before this thesis, I had the opportunity to work with Alan on another project. Alan is a very knowledgeable and friendly professor. I am often impressed by his logical thoughts and wise solutions to difficult research questions. I want to thank Professor Edward W. Knightly and Christopher Jermaine for serving on my Ph.D. thesis committee and asking many insightful questions that helped to shape this thesis. I also want to thank many friends in our research group. They are Bo Zhang, Guohui Wang, Zheng Cai, Florin Dinu, Yiting Xia and Xiaoye Sun. I enjoyed all the vivid discus- sions we had on various topics and had lots of fun being a member of this fantastic group. They always gave me instant help when I asked. Last but not the least, I would like to thank my parents and my best friends who have supported me spiritually throughout my life. Contents Abstract ii List of Illustrations ix List of Tables xi 1 Introduction 1 1.1 Live Migration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.2 Lack of migration progress management . . . . . . . . . . . . . . . . . . . 7 1.3 Lack of coordination for multi-tier application migration . . . . . . . . . . 9 1.4 Contributions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.5 Thesis Organization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 2 Background 18 2.1 Process Migration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 2.2 Live Migration of Virtual Machine . . . . . . . . . . . . . . . . . . . . . . 19 2.2.1 VM Memory/CPU Migration . . . . . . . . . . . . . . . . . . . . 20 2.2.2 Network Connection Migration . . . . . . . . . . . . . . . . . . . 20 2.2.3 Storage Migration . . . . . . . . . . . . . . . . . . . . . . . . . . 21 2.2.4 Full VM Migration . . . . . . . . . . . . . . . . . . . . . . . . . . 22 2.3 Optimization of Live Migration . . . . . . . . . . . . . . . . . . . . . . . . 24 2.3.1 Compression and Deduplication . . . . . . . . . . . . . . . . . . . 24 2.3.2 Reordering Migrated Block Sequence . . . . . . . . . . . . . . . . 25 3 Migration Time Prediction and Control 27 3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 vii 3.1.1 Predicting Migration Time . . . . . . . . . . . . . . . . . . . . . . 27 3.1.2 Controlling Migration Time . . . . . . . . . . . . . . . . . . . . . 28 3.2 Predicting Migration Time . . . . . . . . . . . . . . . . . . . . . . . . . . 29 3.2.1 Migration Time Model . . . . . . . . . . . . . . . . . . . . . . . . 29 3.2.2 Dirty Set and Dirty Rate Estimation . . . . . . . . . . . . . . . . . 33 3.2.3 Speed Measurement . . . . . . . . . . . . . . . . . . . . . . . . . 39 3.3 Controlling Migration Time . . . . . . . . . . . . . . . . . . . . . . . . . . 40 3.3.1 Solving for Speeds in Each Phase of Migration . . . . . . . . . . . 41 3.3.2 Maximal Feasible Speed Estimation and Speed Tuning . . . . . . . 46 3.4 Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 3.4.1 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 3.4.2 Experiment Setup . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 3.4.3 Prediction of migration time . . . . . . . . . . . . . . . . . . . . . 51 3.4.4 Best-effort migration time control . . . . . . . . . . . . . . . . . . 56 3.4.5 Overhead of Pacer . . . . . . . . . . . . . . . . . . . . . . . . . . 63 3.4.6 Potential robustness improvements . . . . . . . . . . . . . . . . . . 63 3.5 EC2 Demonstration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 3.5.1 Network and Disk Speed Measurements . . . . . . . . . . . . . . . 65 3.5.2 Use Case 1: Prediction of Migration Time . . . . . . . . . . . . . . 66 3.5.3 Use Case 2: Best-effort Migration Time Control . . . . . . . . . . 66 3.6 Related Work . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 3.6.1 Live Migration . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 3.6.2 I/O Interference in Virtualized Environment . . . . . . . . . . . . . 67 3.6.3 Data Migration Technologies . . . . . . . . . . . . . . . . . . . . . 68 3.6.4 Performance Modeling and Measurement . . . . . . . . . . . . . . 68 4 Coordinated Migration of Multi-tier Applications 70 4.1 Problem Formulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 viii 4.2 Quantitative Impact of Uncoordinated Multi-tier Application Migration . . 73 4.3 System Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 4.3.1 Subsystem: Pacer . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 4.3.2 Challenges and Solutions . . . . . . . . . . . . . . . . . . . . . . . 79 4.3.3 Scheduling Algorithm . . . . . . . . . . . . . . . . . . . . . . . . 80 4.3.4 Inter-group Scheduling . . . . . . . . . . . . . . . . . . . . . . . . 82 4.3.5 Intra-group Scheduling . . . . . . . . . . . . . . . . . . . . . . . . 85 4.3.6 Adapting to changing dirty rate and bandwidth . . . . . . . . . . . 89 4.3.7 Putting it all together . . . . . . . . . . . . . . . . . . . . . . . . . 89 4.4 Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 4.4.1 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 4.4.2 Experiment Setup . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 4.4.3 Migration of a 3-tier Application . . . . . . . . . . . . . . . . . . . 91 4.4.4 Manual Adjustment does not Work . . . . . . . . . . . . . . . . . 91 4.4.5 Algorithms in Inter-group Scheduling . . . . . . . . . . . . . . . . 93 4.5 EC2 demonstration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 4.6 Related work . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 5 Conclusion and Future Work 98 5.1 Migration Progress Management with Optimization Techniques . . . . . . 99 5.2 Migration Progress Management with Migration Planning . . . . . . . . . 100 5.3 Migration Progress Management with Task Prioritization . . . . . . . . . . 101 Bibliography 102 Illustrations 1.1 Beneficial usage scenarios of HCC. . . . . . . . . . . . . . . . . . . . . . . 4 1.2 The progress of live migration . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3 An example of multi-tier application migration . . . . . . . . . . . . . . . 10 3.1 Pacer design overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 3.2 An example of disk dirty set estimation. . . . . . . . . . . . . . . . . . . . 35 3.3 An example of sampling for memory dirty rate estimation . . . . . . . . . . 37 3.4 Trade-off of sampling interval . . . . . . . . . . . . . . . . . . . . . . . . 38 3.5 Each round of adaption for controlling migration time . . . . . . . . . . . . 41 3.6 An example of migration speeds in different phases. . . . . . . . . . . . . . 45 3.7 The prediction of a VM (file server-30clients) migration. Pacer achieves accurate prediction from the very beginning of the migration. . . . . . . . . 53 3.8 Migration with different desired finish times. Pacer almost matches the ideal case when the desired time is larger than 176s. The deviation is very small in [-2s,2s]. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 3.9 Migration with different degrees of workload intensity. Any point in the feasible region can be realized by Pacer. The lower bound for migration time is limited by I/O bottleneck. Default QEMU can only follow a narrow curve in the region. . . . . . . . . . . . . . . . . . . . . . . . . . . 59 3.10 VM migration from Rice campus to Amazon EC2. . . . . . . . . . . . . . 64 4.1 Sequential and parallel migration of a 3-tier web application across clouds. 71 x 4.2 An example about cost computation for 3 VMs . . . . . . . . . . . . . . . 73 4.3 Examples of multi-tier web services. . . . . . . . . . . . . . . . . . . . . . 77 4.4 An example of coordinating the migration with COMMA . . . . . . . . . . 77 4.5 An example of valid group. . . . . . . . . . . . . . . . . . . . . . . . . . . 81 4.6 An example for heuristic algorithm . . . . . . . . . . . . . . . . . . . . . . 84 4.7 Intra-group scheduling. (a) Start VM migrations at the same time, but finish at different times. Result in long performance degradation time. (b) Start VM migrations at the same time and finish at the same time. Result in long migration time due to the inefficient use of migration bandwidth. (c) Start VM migrations at different times and finish at the same time. No performance degradation and short migration time due to efficient use of migration bandwidth. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 4.8 An example of delaying the start of dirty iteration for the migration. . . . . 88 4.9 An example of scheduling algorithm (Put all together) . . . . . . . . . . . . 90 4.10 Computation time for brute-force algorithm and heuristic algorithm . . . . 95

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.