1 / 21

Profiling and Modeling Resource Usage of Virtualized Applications

Profiling and Modeling Resource Usage of Virtualized Applications. Timothy Wood 1 , Lucy Cherkasova 2 , Kivanc Ozonat 2 , and Prashant Shenoy 1 1 University of Massachusetts, Amherst 2 HPLabs, Palo Alto. Virtualized Data Centers. Benefits

didina
Télécharger la présentation

Profiling and Modeling Resource Usage of Virtualized Applications

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Profiling and Modeling Resource Usage of Virtualized Applications Timothy Wood1, Lucy Cherkasova2, Kivanc Ozonat2, and Prashant Shenoy1 1University of Massachusetts, Amherst 2HPLabs, Palo Alto

  2. Virtualized Data Centers • Benefits • Lower hardware and energy costs through server consolidation • Capacity on demand, agile and dynamic IT • Challenges • Apps are characterized by a collection of resource usage traces in native environment • Virtualization overheads • Effects of consolidating multiple VMs to one host • Important for capacity planning and efficient server consolidation

  3. Application Virtualization Overhead • Many research papers measure virtualization overhead but do not predict it in a general way: • A particular hardware platform • A particular app/benchmark, e.g., netperf, Spec or SpecWeb, disk benchmarks • Max throughput/latency/performance is X% worse • Showing Y% increase in CPU resources • How do we translate these measurements in “what is a virtualization overhead for a given application”? New performance models are needed

  4. Predicting Resource Requirements • Most overhead caused by I/O • Network and Disk activity • Xen I/O Model • 2 components • Dom0 handles I/O • Must predict CPU needs of: 1. Virtual machine running the application 2. Domain 0 performing I/O on behalf of the app VM Domain0 Requires several prediction models based on multiple resources

  5. T1 T1 T1 T1 T1 Network CPU Disk Problem Definition Native Application Trace ? ? Dom0 CPU VM CPU Virtualized Application Trace

  6. Native Virtual + CPUUtil App 1 App 2 VM 2 Dom 0 VM 1 Why Bother? • More accurate cost/benefit analysis • Capacity planning and VM placement • Impossible to pre-test some critical services • Hypervisor comparisons • Different platforms or versions

  7. Virtual system usage profile Native system usage profile model ? Our Approach • Automatedrobust model generation • Run benchmark set on native and virtual platforms • Performs a range of I/O and CPU intensive tasks • Gather resource traces • Build model of Native --> Virtual relationship • Use linear regression techniques • Model is specific to platform, but not applications • Automate all the steps in the process Can apply this general model to any application’s traces to predict its requirements

  8. Microbenchmark Suite • Focus on CPU-intensive and different types of I/O-intensive client-server apps • Benchmark activities: • Network-intensive: download and upload files • Disk-intensive: read and write files • CPU-intensive • Need to break correlations between resources • High correlation between packets/sec and CPU time • Simplicity of implementation • based on httperf, Apache Jmeter, Apache Web Server and PHP Microbenchmarks are easy to run in a traditional data center environment

  9. … virtual native Model Generation model ? Set of equations to solve: Model VM: Set of equations to solve: Model Dom-0:

  10. Building Robust Models • Outliers can considerably impact regression models • Creates model that minimizes absolute error • Must use robust regression techniques to eliminate outliers • Not all metrics are equally significant • Starts with 11 metrics: 3 CPU, 4 Network, and 4 Disk • Use stepwise regression to find most significant metrics • Evaluate outcome of microbenchmark runs and eliminate erroneous and corrupted data Correct data set is a prerequisite for building an accurate model

  11. Performance Evaluation: Testbed Details • Two hardware platforms • HP ProLiant DL385, 2-way AMD Opteron, 2.6GHz, 64-bit • HP ProLiant DL580, 4-way Intel Xeon, 1.6GHz, 32-bit • Two applications: • RUBiS (auction site, modeled after e-Bay) • TPC-W (e-commerce site, modeled after Amazon.com) • Monitoring • Native: sysstat • Virtual: xenmon and xentop • Measurements: 30 sec intervals

  12. Questions • Why this set of metrics? • Why these benchmarks? • Why this process of model creation? • Model accuracy

  13. 65% 5% Importance of Modeling I/O • Is it necessary to look at resources other than just total CPU? • How accurate such a simplified model for predicting the CPU requirement of VM ? Definitely need multiple resources!

  14. Benchmark Coverage Why these benchmarks? Using a subset of benchmarks leads to a poor accuracy model

  15. Automated Benchmark Error Detection • Some benchmarks run incorrectly • Rates too high • Background activity • Remove benchmarkswith abnormally higherror rates Automatically remove bad benchmarkswithout eliminating useful data

  16. Model Accuracy • Intel hardware platform • Train the model using simple benchmarks • Apply to RUBiS web application 90% of Dom0 predictions within 4% error90% of VM predictions within 11% error

  17. Second Hardware Platform • AMD, 64bit dual CPU, 2.6Ghz Produces different model parametersPredictions are just as accurate

  18. 1.7 x nat_CPU 1.4 x nat_CPU Different Platform’s Virtualization Overhead To predict virtualization overhead for different hardware platforms require building their own models Different platforms exhibit different amount of CPU overhead

  19. Summary • Proposed approach builds a model for each hardware and virtualization platform. • It enables comparison of application resource requirements on different hardware platforms. • Interesting additional application: helps to assess and compare “performance” overhead of different virtualization software releases.

  20. Future Work • Refine a set of microbenchmarks and related measurements (what is a practical minimal set?) • Repeat the experiments for VMware platform • Linear models – are they enough? • Create multiple models for resources with different overheads at different rates • Evaluation of virtual device capacity • Define composition rules for estimating resource requirements of collocated virtualized applications

  21. Questions?

More Related