Okeanos IaaS Cloud Whitepaper
Okeanos IaaS Cloud Whitepaper
Okeanos IaaS Cloud Whitepaper
The OkeanOS Datacenter Operating System is a complete software solution for the rapid and easy deployment of IaaS cloud services, either public or private, hosted on existing or new datacenters. OkeanOS technology brings the plug and play model to the datacenter resources. Due to its unique LEGO-style philosophy, all resources can be easily managed from a simple cockpit. Existing hardware infrastructures are commoditized and offered as the building bricks for any tailor-made information system, in a few minutes.
6x
2x
8x
2x
WEB 1
WEB 2
APPLICATION 1
APPLICATION 2
APPLICATION 3
DB
Architectural Overview
Essentially, OkeanOS enables customers to build compute and storage clouds, making more efficient use of their processing and storage resources, within their Datacenter, to handle a variety of workloads. They can prepare in a few minutes, numerous of custom ordered machines, with all flavors of server OS, connected in any possible way, secured and easily managed. OkeanOS offers a no-hassle, intuitive Web UI for all custom architectures. OkeanOS can be programmatically accessed, via command line interface plus a RESTful API. Thus integration to existing environments or usage of existing tools is done seamlessly. OkeanOS encapsulates the Synnefo Cloud Management Layer and the Google Ganeti Cluster management software on top of KVM virtualized Computing resources. The API is a superset of the OpenStack Compute API to allow use of 3rd party tools with OkeanOS
The main software layers comprising an OkeanOS deployment are outlined in the following figure.
USERS
CLIENTS
http://
>_
http://
ADMIN API
DATACENTER
KVM SINGLE VM
VIRTUAL HARDWARE
Key Features
means two things: (a) the Web UI runs on the client side, eliminating unnecessary server roundtrips, (b) The API implementation is always up-to-date, with all functionality available both programmatically and over the UI. Command-line management When the need arises to provision and manage resources automatically and in bulk, the ./kamaki command-line tool can be used to perform low-level administrative tasks. ./kamaki is just another client to the OkeanOS API, targeted to advanced end users and developers. Public Networking OkeanOS supports full IPv4 and IPv6 connectivity to the public Internet for its VMs. The network implementation is deploymentspecific, behind Ganeti, and may be customized extensively to the customers individual needs. A reference OkeanOS implementation supports host-based routing for multiple IP address pools, with
KVM-based Virtual Machines OkeanOS supports KVM-based VMs, managed by Google Ganeti. KVM does full system virtualization, and supports Microsoft Windows, Linux, and BSD deployments inside its VMs. So far, server Images for Red Hat Enterprise Linux / CentOS, Fedora, Debian Linux, Ubuntu/Kubuntu, and Microsoft Windows Server 2008R2 have been tested extensively inside OkeanOS deployments, using virtio-based storage and network drivers for minimal virtualization overhead. Google Ganeti for VM control OkeanOS uses Google Ganeti for VM management at the backend. The Ganeti-based control plane ensures stability, redundancy, manageability, upgradability and above all production readiness. Ganeti employs a simple, clean design with readable, well-commented and well-maintained code. Having a distinct, well-defined VM control plane allows OkeanOS deployments to benefit from the evolution process of Ganeti and provides for cleanly-separated layers. Ganeti gives a competitive advantage regarding VM migrations, intelligent resource allocation and handling of physical node downtimes. Clean RESTful API Every bit of functionality provided by OkeanOS is exported to end users via a clean, RESTful API called the OkeanOS API. The OkeanOS API is a superset of OpenStack Compute API v1.1. Following an open standard ensures compatibility with a multitude of third-party cloud management tools and lowers the barrier to entry for migration of existing software deployments on the cloud. Intuitive Web UI OkeanOS comes with a clear, simple Web UI though which the user may quickly provision new and manage existing compute, network and storage resources. The Web UI is a client-side Javascript/ jQuery application using the OkeanOS API behind the scenes, which
minimal overhead, and no Network Address Translation. Eliminating the need for NAT allows VMs to migrate freely between physical hosts, without introducing SPOFs. Private Networking OkeanOS provides virtual Ethernets as a separate resource, giving the user freedom to create arbitrary network topologies of interconnected VMs, e.g., for multi-tiered deployments of enterprise software. Private networks are supported by the API and are exposed all the way to the UI. Each private network is an isolated Ethernet segment, carrying raw L2 Ethernet frames. This gives unrestricted choice of IP addressing schemes, allows running own DHCP services, and supports non-IP traffic as well. VMs see a separate virtual Ethernet NIC for each private LAN they are part of. Out-of-the-box Firewalling The user may protect each public IPv4/IPv6 interface with a virtual firewall, choosing from a number of predefined firewall configurations. Firewalling is provided as a virtual appliance by the infrastructure and works independently from the guest OS running inside a VM. Bridging of cloud-based with physical resources One cannot expect a complete deployment of physical resources to be migrated overnight to the cloud. OkeanOS exploits private networking functionality to form secure bridges between virtual networks and your existing physical network in your server room or datacenter, essentially bringing cloud-based resources right next to your physical servers. Need your virtual resources to allocate IP addresses from your physical DHCP server? Now thats possible. Self-healing distributed storage backend VM storage volumes are physically stored as objects in a distributed, redundant, object-based storage backend. The storage backend is deployed in commodity physical nodes, with no need for proprietary
hardware or custom interconnects; it is a distributed, sharednothing architecture, with no SPOFs. Storage bandwidth and capacity scales with the number of storage nodes. Nodes are added and removed in a live system, with dynamic object replication and automatic rebalancing. Having a shared-storage backend allows for seamless VM migrations among physical nodes. Intelligent Storage with snapshots and clones Efficient VM provisioning is key to delivering elastic scaling of cloud resources. A custom volume composition layer in OkeanOS
provides for low-overhead snapshots of VM storage volumes and creation of clones from them. In this scheme, VM images correspond to snapshots in the storage backend; everybody can mass deploy long-lived, persistent VMs running on cloned storage volumes, in a matter of seconds. Users can keep point-in-time snapshots of their work; they can revert to them and start over, or follow a diverging path in history by cloning them to a new VM. Storage functionality is exported all the way up to the UI via a clean RESTful API for volume management.
Deployment details
BROWSER UI http://
COMMAND LINE
>_
REST API
WEB SERVER
DB SQL LOGIC
SQL
API SERVER RAPI OBJECT STORAGE NODE GANETI MASTER OBJECT STORAGE NODE
QUEUE
GANETI NODE