Welcome to Blazar - Reservation-as-a-Service for OpenStack.
|Nova filters and extensions||https://github.com/openstack/blazar-nova|
Idea of creating Blazar originated from two different use cases:
- Compute host reservation (when user with admin privileges can reserve hardware resources that are dedicated to the sole use of a tenant)
- Virtual machine (instance) reservation (when user may ask reservation service to provide him working VM not necessary now, but also in the future)
Now these ideas have been transformed to more general view: with Blazar user can request the resources of cloud environment to be provided (“leased”) to his project for a specific amount of time, immediately or in future.
Both virtual (Instances, Volumes, Networks) and hardware (full hosts with specific characteristics of RAM, CPU and etc) resources can be allocated via “lease”.
In terms of benefits added, Resource Reservation Service will:
- improve visibility of cloud resources consumption (current and planned for future);
- enable cloud resource planning based on current and future demand from end users;
- automate the processes of resource allocation and reclaiming;
- provide energy efficiency for physical hosts (both compute and storage ones);
- potentially provide leases as billable items for which customers can be charged a flat fee or a premium price depending on amount of reserved cloud resources and their usage
Glossary of terms
Reservation is an allocation of certain cloud resource (Nova instance, Cinder volume, Compute host, etc.) to a particular project. Speaking about virtual reservations, we may have not only mean simple, solid ones (like already mentioned instances and volumes), but also complex ones - like Heat stacks and Sahara (ex-Savanna) clusters. Reservation is characterized by status, resource type and identifier and lease it belongs to.
Lease is a negotiation agreement between the provider (Blazar, using OpenStack resources) and the consumer (user) where the former agrees to make some kind of resources (both virtual and physical) available to the latter, based on a set of lease terms presented by the consumer. Here lease may be described as a contract between user and reservation service about cloud resources to be provided right now or later. Technically speaking, lease is a group of reservations granted to a particular project upon request. Lease is characterized by start time, end time, set of individual reservations and associated events.
Event is simply something that may happen to a lease. In the most simplest case event might describe lease start and lease end. Also it might send notification to user (e.g. about soon to expire leases) and some extra actions.
Blazar is created to:
- manage cloud resources not only right now, but also in the future;
- have dedicated recourses on certain amount of time;
- prepare for the peak loads and perform capacity planning;
- optimise energy consumption.
Service Architecture Design
Blazar design can be described by following diagram:
blazar-client - provides the opportunity to communicate with Blazar via REST API (blazar-api service).
blazar-api - waits for the REST calls from the outside world to redirect them to the manager. blazar-api communicates with blazar-manager via RPC. Runs as a separated process.
blazar-manager - implements all logic and operations with leases, reservations and events. Communicates with Blazar DB and stores there data structure of connected leases, reservations (both physical and virtual) and events. blazar-manager service is responsible for running events created for lease and process all actions that should be done this moment. Manager uses resource-plugins to work with concrete resources (instances, volumes, compute hosts). blazar-manager uses Keystone trusts to commit actions on behalf of user who has created lease before.
resource-plugin - responsible for exact actions to do with reserved resources (VMs, volumes, etc.) When working knows only about resource ID and token to use. All resource plugins work in the same process as blazar-manager.
Virtual instance reservation
Note: virtual instance reservation feature is not available in current release. Expected to be available in the future (feature tracker).
Virtual instance reservation mostly looks like usual instance booting for user - he/she only passes special hints to Nova containing information about future lease - lease start and end dates, its name, etc. Special Nova API extensions parse these parameter and use them to call Blazar, passing to it ID of just created instance. If there is a need to reserve all instances in cloud (like in developer labs to automate process of resource reclaiming), default reservation extension might be used. By default it starts lease at the moment of request and gives it one month of lifetime.
During the time lease has not started yet, instance will be in shelved.
Compute host reservation
Now process of compute hosts reserving contains two steps:
- admin marks hosts from common pool as possible to be reserved. That is implemented by moving these hosts to special aggregate.
- user asks for reserving of host with specified characteristics like:
- the region
- the availability zone
- the host capabilities extra specs (scoped and non-scoped format should be accepted)
- the number of CPU cores
- the amount of free RAM
- the amount of free disk space
- the number of hosts
Technically speaking, resource ID here will be not host ID, because there might be many of them wanted. Resource here will be new aggregate containing reserved hosts. The time lease starts, user may use reserved compute capacity to run his/her instances on it passing special scheduler hint to Nova. When host is reserved, it’s not used for usual instance running, it might be used only when lease starts and only by passing reservation ID to Nova.
Lease types (concepts)
- Immediate reservation. Resources are provisioned immediately (like VM boot or moving host to reserved user aggregate) or not at all. If request can be fulfilled, lease is created and success status is returned. Lease should be marked as active or to_be_started. Otherwise (if request resource cannot be provisioned right now) failure status for this request should be returned.
- Reservation with retries. Mostly looks like previous variant, but in case of failure, user may want to have several (configurable number) retries to process lease creation action. In this case request will be processed till that will be possible to create lease but not more than set in configuration file number of times.
- Best-effort reservation. Also might have place if lease creation request cannot be fulfilled immediately. Best-effort mechanism starts something like scavenger hunt trying to find resources for reservations. For compute hosts reservation that makes much sense, because in case there are instances belonging to other tenant on eligible hosts, and without them there will be possible to reserve these hosts, Blazar may start instances migration. This operation can be timely and fairly complex and so different strategies may be applied depending on heuristic factors such as the number, type and state of the instances to be migrated. Also Blazar should assert that there are at least enough potential candidates for the migration prior to starting the actual migration. If Blazar decides to start migration, it returns success state and marks lease as in_progress, otherwise - failure. If this 'hunting' ends successfully before configurable timeout has passed, lease should be marked as active, otherwise its status is set to timedout.
- Delayed resource acquiring or scheduled reservation. In this reservation type lease is created successfully if Blazar thinks there will be enough resources to process provisioning later (otherwise this request returns failure status). Lease is marked as inactive till all resources will be actually provisioned. That works pretty nice and predictable speaking about compute hosts reservation (because hosts as resources are got not from common cloud pool, but from admin defined pool). So Blazar is possible to predict these physical resources usage and use that information during lease creation. If we speak about virtual reservations, here situation is more complicated, because all resources are got from common cloud resources pool, and Blazar cannot guarantee there will be enough resources to provision them. In this failure case lease state will be marked as error with appropriate explanation.
User & Developer Guides
See installation guide.
How to participate
See how to contribute.
See Blazar REST API.
- Blazar/Development Guidelines
- Blazar/How to contribute
- Blazar/Installation using Devstack
- Blazar/Installation without Devstack
- Blazar/PTL Elections Icehouse
- Blazar/PTL Elections Juno
- Blazar/REST API
- Blazar/Release Notes
- Blazar/Release Notes/0.1.0
- Blazar/Use Cases