1/52 Distributed Systems Architecture Research Group Universidad Complutense de Madrid Deployment of Private and Hybrid Clouds Using OpenNebula/RESERVOIR.

Slides:



Advertisements
Similar presentations
134 Distributed Systems Architecture Research Group Universidad Complutense de Madrid Using the OGF OCCI Interface on OpenNebula/RESERVOIR Constantino.
Advertisements

Ed Duguid with subject: MACE Cloud
Virtual Machine Technology Dr. Gregor von Laszewski Dr. Lizhe Wang.
1 Applications Virtualization in VPC Nadya Williams UCSD.
1/16 Distributed Systems Architecture Research Group Universidad Complutense de Madrid An Introduction to Virtualization and Cloud Technologies to Support.
1 Week #1 Objectives Review clients, servers, and Windows network models Differentiate among the editions of Server 2008 Discuss the new Windows Server.
Virtual techdays INDIA │ 9-11 February 2011 Cross Hypervisor Management Using SCVMM 2008 R2 Vikas Madan │ Partner Consultant II, Microsoft Corporation.
FI-WARE – Future Internet Core Platform FI-WARE Cloud Hosting July 2011 High-level description.
DESIGN CONSIDERATIONS OF A GEOGRAPHICALLY DISTRIBUTED IAAS CLOUD ARCHITECTURE CS 595 LECTURE 10 3/20/2015.
Virtualization and the Cloud
Cloud Computing (101).
Virtualization for Cloud Computing
Clouds using Opennebula Gabor Kecskemeti This presentation is heavily based on multiple.
Getting Started with Oracle Compute Cloud
1/17 Distributed Systems Architecture Research Group Universidad Complutense de Madrid Execution of SGE Clusters on top of Hybrid Clouds using OpenNebula.
A Brief Overview by Aditya Dutt March 18 th ’ Aditya Inc.
Opensource for Cloud Deployments – Risk – Reward – Reality
INTRODUCTION TO CLOUD COMPUTING CS 595 LECTURE 7 2/23/2015.
 Cloud computing  Workflow  Workflow lifecycle  Workflow design  Workflow tools : xcp, eucalyptus, open nebula.
Customized cloud platform for computing on your terms !
Building service testbeds on FIRE D5.2.5 Virtual Cluster on Federated Cloud Demonstration Kit August 2012 Version 1.0 Copyright © 2012 CESGA. All rights.
Nimbus & OpenNebula Young Suk Moon. Nimbus - Intro Open source toolkit Provides virtual workspace service (Infrastructure as a Service) A client uses.
A Cloud is a type of parallel and distributed system consisting of a collection of inter- connected and virtualized computers that are dynamically provisioned.
Cloud Computing. What is Cloud Computing? Cloud computing is a model for enabling convenient, on-demand network access to a shared pool of configurable.
INSTALLING MICROSOFT EXCHANGE SERVER 2003 CLUSTERS AND FRONT-END AND BACK ‑ END SERVERS Chapter 4.
+ CS 325: CS Hardware and Software Organization and Architecture Cloud Architectures.
M.A.Doman Short video intro Model for enabling the delivery of computing as a SERVICE.
Cloud Computing & Amazon Web Services – EC2 Arpita Patel Software Engineer.
Presented by: Sanketh Beerabbi University of Central Florida COP Cloud Computing.
608D CloudStack 3.0 Omer Palo Readiness Specialist, WW Tech Support Readiness May 8, 2012.
Eucalyptus 3 (&3.1). Eucalyptus 3 Product Overview – Govind Rangasamy.
Week #3 Objectives Partition Disks in Windows® 7 Manage Disk Volumes Maintain Disks in Windows 7 Install and Configure Device Drivers.
Copyright © cs-tutorial.com. Overview Introduction Architecture Implementation Evaluation.
SC2012 Infrastructure Components Management Justin Cook (Data # 3) Principal Consultant, Systems Management Noel Fairclough (Data # 3) Consultant, Systems.
Windows Azure Virtual Machines Anton Boyko. A Continuous Offering From Private to Public Cloud.
VMware vSphere Configuration and Management v6
20409A 7: Installing and Configuring System Center 2012 R2 Virtual Machine Manager Module 7 Installing and Configuring System Center 2012 R2 Virtual.
Aneka Cloud ApplicationPlatform. Introduction Aneka consists of a scalable cloud middleware that can be deployed on top of heterogeneous computing resources.
Linux Operations and Administration
Cloud Computing Lecture 5-6 Muhammad Ahmad Jan.
Web Technologies Lecture 13 Introduction to cloud computing.
Vignesh Ravindran Sankarbala Manoharan. Infrastructure As A Service (IAAS) is a model that is used to deliver a platform virtualization environment with.
1/23 Distributed Systems Architecture Research Group Universidad Complutense de Madrid Nuevos modelos de provisión de recursos para infrestructuras GRID:
Cloud Computing – UNIT - II. VIRTUALIZATION Virtualization Hiding the reality The mantra of smart computing is to intelligently hide the reality Binary->
Launch Amazon Instance. Amazon EC2 Amazon Elastic Compute Cloud (Amazon EC2) provides resizable computing capacity in the Amazon Web Services (AWS) cloud.
Capacity Planning in a Virtual Environment Chris Chesley, Sr. Systems Engineer
Deploying Highly Available SQL Server in Windows Azure A Presentation and Demonstration by Microsoft Cluster MVP David Bermingham.
Unit 2 VIRTUALISATION. Unit 2 - Syllabus Basics of Virtualization Types of Virtualization Implementation Levels of Virtualization Virtualization Structures.
© 2012 Eucalyptus Systems, Inc. Cloud Computing Introduction Eucalyptus Education Services 2.
Information Initiative Center, Hokkaido University North 11, West 5, Sapporo , Japan Tel, Fax: General.
© 2015 MetricStream, Inc. All Rights Reserved. AWS server provisioning © 2015 MetricStream, Inc. All Rights Reserved. By, Srikanth K & Rohit.
Amazon Web Services. Amazon Web Services (AWS) - robust, scalable and affordable infrastructure for cloud computing. This session is about:
The StratusLab project is partially funded by the European Commission through Grant Agreement RI StratusLab Kick-off Meeting, 14 – 15 June 2010.
Unit 3 Virtualization.
New Paradigms: Clouds, Virtualization and Co.
Virtualization for Cloud Computing
Use of HLT farm and Clouds in ALICE
Blueprint of Persistent Infrastructure as a Service
StratusLab Final Periodic Review
StratusLab Final Periodic Review
Oracle Solaris Zones Study Purpose Only
Introduction to Cloud Computing
GGF15 – Grids and Network Virtualization
Management of Virtual Execution Environments 3 June 2008
Managing Clouds with VMM
20409A 7: Installing and Configuring System Center 2012 R2 Virtual Machine Manager Module 7 Installing and Configuring System Center 2012 R2 Virtual.
Outline Virtualization Cloud Computing Microsoft Azure Platform
HC Hyper-V Module GUI Portal VPS Templates Web Console
* Introduction to Cloud computing * Introduction to OpenStack * OpenStack Design & Architecture * Demonstration of OpenStack Cloud.
Azure Container Service
Presentation transcript:

1/52 Distributed Systems Architecture Research Group Universidad Complutense de Madrid Deployment of Private and Hybrid Clouds Using OpenNebula/RESERVOIR Constantino Vázquez Blanco Rubén Santiago Montero Open Grid Forum 28 March 15-18, 2010 Munich, Germany

2/52 Outline Cloud Computing in a Nutshell What is OpenNebula? Private Cloud :: Deploying OpenNebula Private Cloud :: Using OpenNebula Hybrid Cloud

3/52 Cloud Computing in a Nutshell

4/52 Software as a Service ᄎ Platform as a Service Infrastructure as a Service Physical Infrastructure What Who On-demand access to any application End-user (does not care about hw or sw) Platform for building and delivering web applications Developer (no managing of the underlying hw & swlayers) Delivery of a raw computer infrastructure System Administrator (complete management of the computer infrastructure) Cloud Computing in a Nutshell Overview

5/52 Cloud Computing in a Nutshell Simple Interface Raw Infrastructure Resources Total control of the resources Capacity leased in the form of VMs Complete Service-HW decoupling Pay-as-you-go A single user can not get all the resources Elastic & “infinite” Capacity The IaaS Clouds: A Four Point Check List

6/52 Cloud Computing in a Nutshell hypervisor OpenNebula (VIM) VM VMs are great!!...but something more is needed Where did/do I put my VM? (scheduling & monitoring) How do I provision a new cluster node? (clone & context) What MAC addresses are available? (networking) Provides a uniform view of the resource pool Life-cycle management and monitoring of VM The VIM integrates Image, Network and Virtualization Why a Virtual Infrastructure Manager?

7/52 What is OpenNebula?

8/52 What is OpenNebula? The OpenNebula Virtual Infrastructure Engine Dynamic deployment and re-placement of virtual machines on a pool of physical resources Transform a rigid distributed physical infrastructure into a flexible and agile virtual infrastructure Extending the Benefits of Virtualization to Clusters Backend of Public Cloud: Internal management of the infrastructure Private Cloud: Virtualization of cluster or data-center for internal users Cloud Interoperation: On-demand access to public clouds

9/52 What is OpenNebula? Virtual Machine Management Model Service structure Service components run in VMs Inter-connection relationship Placement constraints The VM Manager is service agnostic Provide infrastructure context Service as Management Entity Distributed VM Management Model

10/52 What is OpenNebula? Centralized management of VM workload and distributed infrastructures Support for VM placement policies: balance of workload, server consolidation… Dynamic resizing of the infrastructure Dynamic partition and isolation of clusters Dynamic scaling of private infrastructure to meet fluctuating demands Lower infrastructure expenses combining local and remote Cloud resources For the Infrastructure Manager For the Infrastructure User Faster delivery and scalability of services Support for heterogeneous execution environments Full control of the lifecycle of virtualized services management Benefits

11/52 What is OpenNebula? Fits into any existing data center, due to its open, flexible and extensible interfaces, architecture and components Builds any type of Cloud deployment Open source software, Apache license Seamless integration with any product and service in the cloud ecosystem and management tool in the data center, such as cloud providers VM managers virtual image managers service managers management tools schedulers For System Integrators Benefits

12/52 What is OpenNebula? FeatureFunction Internal InterfaceUnix-like CLI for fully management of VM life-cycle and physical boxes XML-RPC API and libvirt virtualization API SchedulerRequirement/rank matchmaker allowing the definition of workload and resource-aware allocation policies Support for advance reservation of capacity through Haizea Virtualization Management Xen, KVM, and VMware Generic libvirt connector (VirtualBox planned for 1.4.2) Image ManagementGeneral mechanisms to transfer and clone VM images Network ManagementDefinition of isolated virtual networks to interconnect VMs Service Management and Contextualization Support for multi-tier services consisting of groups of inter-connected VMs, and their auto-configuration at boot time SecurityManagement of users by the infrastructure administrator Fault TolerancePersistent database backend to store host and VM information ScalabilityTested in the management of medium scale infrastructures with hundreds of servers and VMs (no scalability issues has been reported) InstallationInstallation on a UNIX cluster front-end without requiring new services Distributed in Ubuntu 9.04 (Jaunty Jackalope) Flexibility and Extensibility Open, flexible and extensible architecture, interfaces and components, allowing its integration with any product or tool Features

13/52 What is OpenNebula? OpenNebula Architecture

14/52 What is OpenNebula? Request manager: Provides a XML-RPC interface to manage and get information about ONE entities. SQL Pool: Database that holds the state of ONE entities. VM Manager (virtual machine): Takes care of the VM life cycle. Host Manager: Holds the information about hosts and how to interact with them. VN Manager (virtual network): This component is in charge of generating MAC and IP addresses. OpenNebula Architecture :: Core

15/52 What is OpenNebula? Scheduler: This component searches for physical hosts to deploy newly defined VMs Command Line Interface: Commands used to manage OpenNebula entities. onevm: Virtual Machines create, list, migrate… onehost: Hosts create, list, disable… onevnet: Virtual Networks create, list, delete… OpenNebula Architecture :: Tools

16/52 What is OpenNebula? Transfer Driver: Takes care of the images. cloning, deleting, creating swap image… Virtual Machine Driver: Manager of the lifecycle of a virtual machine deploy, shutdown, poll, migrate… Information Driver: Executes scripts in physical hosts to gather information about them total memory, free memory, total cpus, cpu consumed… OpenNebula Architecture :: Drivers

17/52 What is OpenNebula? Scheduler is a separated process, just like command line interface. Drivers are also separated processes using a simple text messaging protocol to communicate with OpenNebula Core Daemon (oned) OpenNebula Architecture :: Process separation

18/52 Private Cloud :: Deploying OpenNebula

19/52 Private Cloud :: Deploying OpenNebula System Overview

20/52 Preparing the storage for the private cloud... Image Repository: Any storage medium for the VM images (usually a high performing SAN)  OpenNebula supports multiple back-ends (e.g. LVM for fast cloning)  The front-end must have access to the repository VM Directory: The home of the VM in the cluster node  Stores checkpoints, description files and VM disks  Actual operations over the VM directory depends on the storage medium  Should be shared for live-migrations  You can go on without a shared FS and use the SSH back-end  Defaults to $ONE_LOCATION/var/$VM_ID Dimensioning the Storage... Example: A 64 core cluster will typically run around 80VMs, each VM will require an average of 10GB of disk space. So you will need ~800GB for /srv/cloud/one, you will also want to store master images so ~200GB for /srv/cloud/images. A 1TB /srv/cloud will be enough for this example setup. Private Cloud :: Deploying OpenNebula Storage

21/52 Private Cloud :: Deploying OpenNebula Storage

22/52 Private Cloud :: Deploying OpenNebula Networking Networking for the private cloud OpenNebula management operations uses a ssh connections, it does not require a performing NIC Image traffic, may require the movement of heavy files (VM images, checkpoints). Dedicated storage links may be a good idea VM demands, consider the typical requirements of your VMs. Several NICs to support the VM traffic may be a good idea OpenNebula relies on bridge networking for the VMs

23/52 Private Cloud :: Deploying OpenNebula Networking

24/52 Private Cloud :: Deploying OpenNebula User Management Native user support since v1.4 oneadmin: privileged account networks and VMs (storage in v1.6) SHA1 passwords (AA module in v1.6) Stored in FS Alternatively in environment

25/52 Private Cloud :: Deploying OpenNebula Virtualization OpenNebula can interface various hypervisors Xen KVM VMware Different functionality offered depending of the HV Careful with versions Libvirt abstraction used for kvm

26/52 Private Cloud :: Deploying OpenNebula Configuration

27/52 Private Cloud :: Using OpenNebula

28/52 Support for Catalog due in 1.6 ACLs Metadata Native support, offered by XMLRPC API Meanwhile… Image repository in FS Plugins for SSH – always clone NFS – quick, possible bottleneck? Private Cloud :: Using OpenNebula Storage

29/52 DISK = [ type = “floppy|disk|cdrom|swap”, source = “path_to_disk_image_file|physical_dev”, size = “size_in_GB”, target = “device_to_map_disk”, bus = “ide|scsi|virtio|xen”, readonly = “yes|no”, clone = “yes|no”, save = “path_to_disk_image_file” ] DISK = [ source = “/images/etch/disk.img”, target = “sda” ] DISK = [ type = swap, size = 1024, target = “sdb” ] Disk description options Disk description examples Private Cloud :: Using OpenNebula Storage

30/52 Private Cloud :: Using OpenNebula A Virtual Network in OpenNebula Defines a separated MAC/IP address space to be used by VMs Each virtual network is associated with a physical network through a bridge Virtual Networks can be isolated (at layer 2 level) with ebtables and hooks Virtual Networks are managed with the onevnet utility Networks created by oneadmin are public, i.e. can be used by VMs of any other user Virtual Networks

31/52 NAME = “Private LAN” TYPE = RANGED BRIDGE = eth0 NETWORK_SIZE = 250 NETWORK_ADDRESS= NAME = “Public LAN” TYPE = FIXED BRIDGE= eth1 LEASES= [IP= ,MAC=50:20:20:20:20:20] LEASES= [IP= ] NIC = [ network = “name_of_the_virtual_network”, ip = “ip_address”, bridge = “name_of_bridge_to_bind_if”, target = “device_name_to_map_if”, mac = “HW_address”, script = “path_to_script_to_bring_up_if” ] Ranged network definition Fixed network definition Network information in VM description Private Cloud :: Using OpenNebula Virtual Networks

32/52 A User in OpenNebula Is a pair of username:password Only oneadmin can add/delete users Users are managed with the oneuser utility Private Cloud :: Using OpenNebula Users

33/52 Preparing a VM to be used with OpenNebula You can use any VM prepared for the target hypervisor Hint I: Place the vmcontext.sh script in the boot process to make better use of vlans Hint II: Do not pack useless information in the VM images:  swap. OpenNebula can create swap partitions on-the-fly in the target host  Scratch or volatile storage. OpenNebula can create plain FS on-the- fly in the target host Hint III: Install once and deploy many; prepare master images Hint IV: Do not put private information (e.g. ssh keys) in the master images, use the CONTEXT Hint V: Pass arbitrary data to a master image using CONTEXT Virtual Machines are managed with the oneuser utility Private Cloud :: Using OpenNebula Virtual Machines

34/52 OptionDescription NAMEName that the VM will get for description purposes. CPUPercentage of CPU divided by 100 required for the Virtual Machine. OS (KERNEL, INITRD)Path of the kernel and initrd files to boot from. DISK (SOURCE, TARGET, CLONE, TYPE) Description of a disk image to attach to the VM. NIC (NETWORK)Definition of a virtual network the VM will be attached to. Multiple disk an network interfaces can be specified just adding more disk/nic statements. To create swap images you can specify TYPE=swap, SIZE=. By default disk images are cloned, if you do not want that to happen CLONE=no can be specified and the VM will attach the original image. Private Cloud :: Using OpenNebula Virtual Machines

35/52 NAME = vm-example CPU = 1 MEMORY = 512 # --- kernel & boot device --- OS = [ kernel = “/vmlinuz”, initrd = “/initrd.img”, root = “sda” ] # disks --- DISK = [ source = “/images/etch/disk.img”, target = “sda” ] DISK = [ type = swap, size = 1024, target = “sdb” ] # NIC --- NIC = [ network=“public” ] Private Cloud :: Using OpenNebula Virtual Machines

36/52 Private Cloud :: Using OpenNebula Virtual Machines

37/52 Private Cloud :: Using OpenNebula After submitting a VM description to ONE it is added to the database and its state is set to PENDING. In this state IP and MAC addresses are also chosen if they are not explicitly defined. The scheduler awakes every 30 seconds and looks for VM descriptions in PENDING state and searches for a physical node that meets its requirements. Then a deploy XML-RPC message is sent to oned to make it run in the selected node. Deployment can be also made manually using the Command Line Interface: ⇒ onevm deploy Pending State

38/52 Private Cloud :: Using OpenNebula In PROLOG state the Transfer Driver prepares the images to be used by the VM. Transfer actions: CLONE: Makes a copy of a disk image file to be used by the VM. If Clone option for that file is set to false and the Transfer Driver is configured for NFS then a symbolic link is created. MKSWAP: Creates a swap disk image on the fly to be used by the VM if it is specified in the VM description. Prolog State

39/52 Private Cloud :: Using OpenNebula In this state a deployment file specific for the virtualization technology configured for the physical host is generated using the information provided in the VM description file. Then Virtual Machine Driver sends deploy command to the virtual host to start the VM. The VM will be in this state until deployment finishes or fails. Boot State

40/52 Private Cloud :: Using OpenNebula While the VM is in RUNNING state it will be periodically polled to get its consumption and state. In SHUTDOWN state Virtual Machine Driver will send the shutdown command to the underlying virtual infrastructure. Running and Shutdown States

41/52 Private Cloud :: Using OpenNebula In EPILOG state the Transfer Manager Driver is called again to perform this actions: Copy back the images that have SAVE=yes option. Delete images that were cloned or generated by MKSWAP. Epilog State

42/52 Private Cloud :: Using OpenNebula Contextualization The ISO image has the contextualization for that VM: context.sh: contains configuration variables init.sh: script called by VM at start to configure specific services certificates: directory that contains certificates for some service service.conf: service configuration

43/52 Private Cloud :: Using OpenNebula Contextualization CONTEXT = [ hostname = "$NAME", ip_private = '$NIC[IP, NETWORK="Private LAN"]', ip_gen = " $VM_ID", files = "/service/init.sh /service/", target = "sdc" ] files: Files and directories that will be included in the contextualization image target:device where the contextualization image will be available to the VM instance

44/52 Hybrid Cloud

45/52 Hybrid Cloud Overview

46/52 IM_MAD = [ name = "im_ec2", executable = "one_im_ec2", arguments = "im_ec2/im_ec2.conf" ] VM_MAD = [ name = "vmm_ec2", executable = "one_vmm_ec2", arguments = "vmm_ec2/vmm_ec2.conf", type = "xml" ] TM_MAD = [ name = "tm_dummy", executable = "one_tm", arguments = "tm_dummy/tm_dummy.conf" ] Hands on... Check the values of the driver configurations files Hybrid Cloud Configuration

47/52 Amazon EC2 cloud is managed by OpenNebula as any other cluster node You can use several accounts by adding a driver for each account (use the arguments attribute, -k and -c options). Then create a host that uses the driver You can use multiple EC2 zones, add a driver for each zone (use the arguments attribute, -u option), and a host that uses that driver You can limit the use of EC2 instances by modifying the IM file Hybrid Cloud Use

48/52 Virtual Machines can be instantiated locally or in EC2 The template must provide a description for both instantiation methods. The EC2 counterpart of your VM ( AMI_ID ) must be available for the driver account The EC2 VM template attribute: EC2 = [ AMI = "ami_id for this VM", KEYPAIR = "the keypair to use the instance", AUTHORIZED_PORTS = "ports to access the instance", INSTANCETYPE = "m1.small...", ELASTICIP = "the elastic ip for this instance", CLOUD = "host (EC2 cloud) to use this description with" ] Hybrid Cloud Use

49/52 Infrastructure Perspective Hybrid Cloud Service Execution

50/52 Service Perspective Hybrid Cloud Service Execution

51/52 On-demand Scaling of Computing Clusters On-demand Scaling of Web Servers Elastic execution of a SGE computing cluster Dynamic growth of the number of worker nodes to meet demands using EC2 Private network with NIS and NFS EC2 worker nodes connect via VPN Elastic execution of the NGinx web server The capacity of the elastic web application can be dynamically increased or decreased by adding or removing NGinx instances Hybrid Cloud Use Cases

52/52 THANK YOU FOR YOUR ATTENTION!!! More info, downloads, mailing lists at Acknowledgements Ignacio M. Llorente Rubén S. Montero Javier Fontán OpenNebula is partially funded by the “RESERVOIR– Resources and Services Virtualization without Barriers” project EU grant agreement Jaime Melis Rafael Moreno Private and Hybrid Clouds Using OpenNebula/RESERVOIR