Octavia v0.5 component design

This design represents the overall layout of components that will
make up the first major milestone release of Octavia (v0.5). The
intent here is to have a scalable service delivery layer, to get
communication with external components right, and not yet worry
about making the command and control layer scalable.

Change-Id: I09ab7185683b66ec2567119616bc54cf9d8cc000
This commit is contained in:
Stephen Balukoff 2014-08-12 00:41:43 -07:00
parent 507ff77b29
commit a37d6f8d17
4 changed files with 869 additions and 0 deletions

@ -0,0 +1,514 @@
=============================
Octavia v0.5 Component Design
=============================
Please refer to the following diagram of the Octavia v0.5 components:
.. graphviz:: v0.5-component-design.dot
This milestone release of Octavia concentrates on making the service delivery
scalable (though individual listeners are not horizontally scalable at this
stage), getting API and other interfaces between major components correct,
without worrying about making the command and control layer scalable.
Note that this design is not yet "operator grade" but is a good first step to
achieving operator grade (which will occur with version 1 of Octavia).
================
LBaaS Components
================
The entities in this section describe components that are part of the Neutron
LBaaS project, with which Octavia interfaces to deliver load balancing
services.
USER API HANDLER
----------------
This is the front-end that users (and user GUIs or what have you) talk to to
manipulate load balancing services.
**Notes:**
* All implementation details are hidden from the user in this interface
* Performs a few simple sanity checks on user-supplied data, but otherwise
looks to a driver provide more detail around whether what the user is asking
for is possible on the driver's implementation.
* Any functionality that the user asks for that their back-end flavor / driver
doesn't support will be met with an error when the user attempts to configure
services this way. (There may be multiple kinds of errors: "incomplete
configuration" would be non-fatal and allow DB objects to be created /
altered. "incompatible configuration" would be fatal and disallow DB objects
from being created / associations made.) Examples of this include: UDP
protocol for a listener on a driver/flavor that uses only haproxy as its
back-end.
* Drivers should also be able to return 'out of resources' or 'some other
error occurred' errors (hopefully with helpful error messages).
* This interface is stateless, though drivers may keep state information in a
database. In any case, this interface should be highly scalable.
* Talks some "intermediate driver interface" with the driver. This takes the
form of python objects passed directly within the python code to the driver.
=========================
LBaaS / Octavia Crossover
=========================
The entities in this section are "glue" components which allow Octavia to
interface with other services in the OpenStack environment. The idea here is
that we want Octavia to be as loosely-coupled as possible with those services
with which it must interact in order to keep these interfaces as clean as
possible.
Initially, all the components in this section will be entirely under the
purview of the Octavia project. Over time some of these components might be
eliminated entirely, or reduced in scope as these third-party services
evolve and increase in cleanly-consumable functionality.
DRIVER
------
This is the part of the load balancing service that actually interfaces between
the (sanitized) user and operator configuration and the back-end load balancing
appliances or other "service providing entity."
**Notes:**
* Configuration of the driver is handled via service profile definitions in
association with the Neutron flavor framework. Specifically, a given flavor
has service profiles associated with it, and service profiles which
specify the Octavia driver will include meta-data (in the form of JSON
configuration) which is used by the driver to define implementation
specifics (for example, HA configuration and other details).
* Driver will be loaded by the daemon that does the user API and operator API.
It is not, in and of itself, its own daemon, though a given vendor's back-end
may contain its own daemons or other services that the driver interfaces
with.
* It is thought that the driver front-end should be stateless in order to make
it horizontally scalable and to preserves the statelessness of the user and
operator API handlers. Note that the driver may interface with back-end
components which need not be stateless.
* It is also possible for multiple instances of the driver will talk to the
same Octavia VM at the same time. Emphasis on the idempotency of the update
algorithms used should help minimize the issues this can potentially cause.
NETWORK DRIVER
--------------
In order to keep Octavia's design more clean as a pure consumer of network
services, yet still be able to develop Octavia at a time when it is impossible
to provide the kind of load balancing services we need to provide without
"going around" the existing Neutron API, we have decided to write a "network
driver" component which does those dirty back-end configuration commands via
an API we write, until these can become a standard part of Neutron. This
component should be as loosely coupled with Octavia as Octavia will be with
Neutron and present a standard interface to Octavia for accomplishing network
configuration tasks (some of which will simply be a direct correlation with
existing Neutron API commands).
**Notes:**
* This is a daemon or "unofficial extension", presumably living on a Neutron
network node which should have "back door" access to all things Neutron and
exposes an API that should only be used by Octavia.
* Exactly what API will be provided by this driver will be defined as we
continue to build out the reference implementation for Octavia.
* Obviously, as we discover missing functionality in the Neutron API, we should
work with the Neutron core devs to get these added to the API in a timely
fashion: We want the Network driver to be as lightweight as possible.
==================
Octavia Components
==================
Everything from here down are entities that have to do with the Octavia driver
and load balancing system. Other vendor drivers are unlikely to have the same
components and internal structure. It is planned that Octavia will become the
new reference implementation for LBaaS, though it of course doesn't need to be
the only one. (In fact, a given operator should be able to use multiple vendors
with potentially multiple drivers and multiple driver configurations through
the Neutron Flavor framework.)
OPERATOR API HANDLER
--------------------
This is exactly like the USER API HANDLER in function, except that
implementation details are exposed to the operator, and certain admin-level
features are exposed (ex. listing a given tenant's loadbalancers, & etc.)
It's also anticipated that the Operator API needs will vary enough from
implementation to implementation that no single Operator API will be sufficient
for the needs of all vendor implementations. (And operators will definitely
have implementation-specific concerns.) Also, we anticipate that most vendors
will already have an operator API or other interface which is controlled and
configured outsite the purview of OpenStack in general. As such it makes sense
for Octavia to have its own operator API / interface.
**Notes:**
* This interface is stateless. State should be managd by the controller, and
stored in a highly available database.
CONTROLLER
----------
This is the component providing all the command and control for the Octavia
VMs. On the front end, it takes its commands and controls from the LBaaS
driver.
It should be noted that in later releases of Octavia, the controller functions
will be split across several components. At this stage we are less concerned
with how this internal communcation will happen, and are most concerned with
ensuring communication with Octavia VMs, the LBaaS driver, and the Network
driver are all made as perfect as possible.
Among the controller's responsibilities are:
* Sending configuration and certificate information to an octavia backend
driver, which in the reference implementation will be generating
configuration files for haproxy and PEM-formatted user certificates and
sending these to individual octavia VMs. Configuration files will be
generated from jinja templates kept in an template directory specific to
the haproxy driver.
* Processing the configuration updates that need to be applied to individual
octavia VMs, as sent by the LBaaS driver.
* Interfacing with network driver to plumb additional interfaces on the octavia
VMs as necessary.
* Monitoring the health of all octavia VMs (via a driver interface).
* Receiving and routing certain kinds of notifications originating on the
octavia VMs (ex. "member down")
* This is a stateful service, and should keep its state in a central, highly
available database of some sort.
* Respecting colocation / apolocation requirements of loadbalancers as set
forth by users.
* Receiving notifications, statistics data and other short, regular messages
from octavia VMs and routing them to the appropriate entity.
* Responding to requests from octavia VMs for configuration data.
* Responding to requests from the user API or operator API handler driver for
data about specific loadbalancers or sub-objects, their status, and
statistics.
* octavia VM lifecycle management, including interfacing with Nova and Neutron
to spin up new octavia VMs as necessary and handle initial configuration and
network plumbing for their LB network interface, and cleaning this up when a
octavia VM is destroyed.
* Maintaining a pool of spare octavia VMs (ie. spawning new ones as necessary
and deleting ones from the pool when we have too much inventory here.)
* Gracefully spinning down "dirty old octavia VMs"
* Loading and calling configured octavia backend drivers.
**Notes:**
* Almost all the intelligence around putting together and validating
loadbalancer configurations will live here-- the octavia VM API is meant to
be as simple as possible so that minor feature improvements do not
necessarily entail pushing out new octavia VMs across an entire installation.
* The size of the spare octavia VM pool should be determined by the flavor
being offered.
* The controller also handles spinning up octavia VMs in the case of a true
active/standby topology (ie. where the spares pool is effectively zero.) It
should have enough intelligence to communicate to Nova that these octavia
VMs should not be on the same physical host in this topology.
* It also handles spinning up new octavia VMs when one fails in the above
topology.
* Since spinning up a new octavia VM is a task that can take a long time, the
controller should spawn a job or child process which handles this highly
asynchronous request.
VM DRIVER
---------
This is the abstraction layer that the controller talks to for communicating
with the Octavia VMs. Since we want to keep Octavia flexible enough so that
certain components (like the Octavia VM) can be replaced by third party
products if the operator so desires, it's important to keep many of the
implementation-specific details contained within driver layers. A VM driver
also gives the operator the ability to have different open-source Octavia VMs
with potentially different capabilities (accessed via different flavors) which
can be handy for, for example, field-testing a new Octavia VM image.
The reference implementation for the VM driver will be for the Octavia VM
described below.
Responsibilities of the VM driver include:
* Generating configuration files for haproxy and PEM-formatted user
certificates and sending these to individual octavia VMs. Configuration
files will be generated from jinja templates kept in an template directory
specific to the haproxy driver.
* Handling all communication to and from Octavia VMs.
LB NETWORK
----------
This is the subnet that controllers will use to communicate with octavia VMs.
This means that controllers must have connectivity (either layer 2 or routed)
to this subnet in order to function, and visa versa. Since Octavia VMs will be
communicating on it, this means the network is not part of the "undercloud."
**Notes:**
* As certain sensitive data (TLS private keys, for example) will be transmitted
over this communication infrastructure, all messages carrying a sensitive
payload should be done via encrypted and authenticated means. Further, we
recommend that messages to and from octavia VMs be signed regardless of the
sensitivity of their content.
OCTAVIA VM
----------
This is a Nova VM which actually provides the load balancing services as
configured by the user. Responsibilities of these entities include:
* Actually accomplishing the load balancing services for user-configured
loadbalancers using haproxy.
* Sending regular heartbeats (which should include some status information).
* Responding to specific requests from the controller for very basic
loadbalancer or sub-object status data, including statistics.
* Doing common high workload, low intelligence tasks that we don't want to
burden the controller with. (ex. Shipping listener logs to a swift data
store, if configured.)
* Sending "edge" notifications (ie. status changes) to the controller when
members go up and down, when listeners go up and down, etc.
**Notes:**
* Each octavia VM will generally need its own dedicated LB network IP address,
both so that we don't accidentally bind to any IP:port the user wants to use
for loadbalancing services, and so that an octavia VM that is not yet in use
by any loadbalancer service can still communicate on the network and receive
commands from its controller. Whether this IP address exists on the same
subnet as the loadbalancer services it hosts is immaterial, so long as
front-end and back-end interfaces can be plumbed after a VM is launched.
* Since octavia VMs speak to controllers in a "trusted" way, it's important to
ensure that users do not have command-line access to the octavia VMs. In
other words, the octavia VMs should be a black box from the users'
perspective.
* Octavia VMs will be powered using haproxy 1.5 initially. We may decide to use
other software (especially for TLS termination) later on.
* The "glue scripts" which communicate with the controller should be as
lightweight as possible: Intelligence about how to put together an haproxy
config, for example, should not live on the octavia VM. Rather, the octavia
VM should perform simple syntax checks, start / restart haproxy if the checks
pass, and report success/failure of the haproxy restart.
* With few exceptions, most of the API commands the octavia VM will ever do
should be safely handled synchronously (ie. nothing should take longer than a
second or two to complete).
* Connection logs, and other things anticipated to generate a potential large
amount of data should be communicated by the octavia VM directly to which
ever service is going to consume that data. (for example, if logs are being
shunted off to swift on a nightly basis, the octavia VM should handle this
directly and not go through the controller.)
INTERNAL HEALTH MONITORS
------------------------
There are actually a few of these, all of which need to be driven by some
daemon(s) which periodically check that heartbeats from monitored entities are
both current and showing "good" status, if applicable. Specifically:
* Controllers need to be able to monitor the availability and overall health
of octavia VMs they control. For active node octavia VMs, this check should
happen pretty quickly: About once every 5 seconds. For spare node octavia
VMs, the check can happen much more infrequently (say, once per minute).
The idea here is that internal health monitors will monitor a periodic
heartbeat coming from the octavia VMs, and take appropriate action (assuming
these are down) if they fail to check in with a heartbeat frequently enough.
This means that internal health monitors need to take the form of a daemon
which is constantly checking for and processing heartbeat requests (and
updating Controller or octavia VM statuses, and triggering other events as
appropriate).
======================================================
Some notes on Controller <-> octavia VM communications
======================================================
In order to keep things as scalable as possible, the thought was that short,
periodic and arguably less vital messages being emitted by the octavia VM and
associated controller would be done via HMAC-signed UDP, and more vital, more
sensitive, and potentially longer transactional messages would be handled via a
RESTful API on the controller, accessed via bi-directionally authenticated
HTTPS.
Specifically, we should expect the following to happen over UDP:
* heartbeats from the octavia VM to the controller
* stats data from the octavia VM to the controller
* "edge" alert notifications (change in status) from the octavia VM to the
controller
* Notification of pending tasks in queue from controller to octavia VM
And the following would happen over TCP:
* haproxy / tls certificate configuration changes
=================================================
Supported Octavia VM Virtual Appliance Topologies
=================================================
Initially, I propose we support two topologies with version 0.5 of Octavia:
Option 1: "Single active node + spares pool"
--------------------------------------------
* This is similar to what HP is doing right now with Libra: Each octavia VM is
stand-alone with a frequent health-check monitor in place and upon failure,
an already-spun-up octavia VM is moved from the spares pool and configured to
take the old one's place. This allows for acceptable recovery times on
octavia VM failure while still remaining efficient, as far as VM resource
utilization is concerned.
Option 2: "True Active / Standby"
---------------------------------
* This is similar to what Blue Box is doing right now where octavia VMs are
deployed in pairs and use corosync / pacemaker to monitor each other's health
and automatically take over (usually in less than 5 seconds) if the "active"
node fails. This provides for the fastest possible recovery time on hardware
failure, but is much less efficient, as far as VM resource utilization is
concerned.
* In this topology a floating IP address (different from a Neutron floating
IP!) is used to determine which octavia VM is the "active" one at any given
time.
* In this topology, both octavia VMs need to be colocated on the same subnet.
As such a "spares pool" doesn't make sense for this type of layout, unless
all spares are on the same mamangement network with the active nodes.
We considered also supporting "Single node" topology, but this turns out to be
the same thing as option 1 above with a spares pool size of zero.
============================
Supported Network Topologies
============================
This is actually where things get tricky, as far as octavia VM plumbing is
concerned. And it only grows trickier when we consider that front-end
connectivity (ie. to the 'loadbalancer' vip_address) and back-end connectivity
(ie. to members of a loadbalancing pool) can be handled in different ways.
Having said this, we can break things down into LB network, front-end and
back-end topology to discuss the various possible permutations here.
LB Network
----------
Each octavia VM needs to have a connection to a LB network. And each controller
needs to have access to this management network (this could be layer-2 or
routed connectivity). Command and control will happen via the octavia VM's
LB network IP.
Front-end topologies
--------------------
There are generally two ways to handle the octavia VM's connection to the
front-end IP address (this is the vip_address of the loadbalancer object):
**Option 1: Layer-2 connectivity**
The octavia VM can have layer-2 connectivity to the neutron network which is
host to the subnet on which the loadbalancer vip_address resides. In this
scenario, the octavia VM would need to send ARP responses to requests for the
vip_address, and therefore octavia VMs need to have interfaces plumbed on said
vip_address subnets which participate in ARP.
Note that this is somewhat problematic for active / standby virtual appliance
topologies because the vip_address for a given load balancer effectively
becomes a highly-available IP address (a true floating VIP), which means on
service failover from active to standby, the active octavia VM needs to
relenquish all the vip_addresses it has, and the standby needs to take them
over *and* start up haproxy services. This is OK if a given octavia
VM only has a few load balancers, but can lead to several minutes' down-time
during a graceful failover if there are a dozen or more load balancers on the
active/standby octavia VM pair. It's also more risky: The standby node might
not be able to start up all the haproxy services during such a
failover. What's more, most types of VRRP-like services which handle floating
IPs require octavia VMs to have an additional IP address on the subnet housing
the floating vip_address in order for the standby VM to monitor the active VM.
Also note that in this topology, octavia VMs need an additional virtual network
interface plumbed when new front-end loadbalancer vip_addresses are assigned to
them which exist on subnets to which they don't already have access.
**Option 2: Routed (layer-3) connectivity**
In this layout, static routes are injected into the routing infrastructure
(Neutron) which essentially allow traffic destined for any given loadbalancer
vip_address to be routed to an IP address which lives on the octavia VM. (I
would recommend this be something other than the LB network IP.) In this
topology, it's actually important that the loadbalancer vip_address does *not*
exist in any subnet with potential front-end clients because in order for
traffic to reach the loadbalancer, it must pass through the routing
infrastructure (and in this case, front-end clients would attempt layer-2
connectivity to the vip_address).
This topology also works much better for active/standby configurations, because
both the active and standby octavia VMs can bind to the vip_addresses of all
their assigned loadbalancer objects on a dummy, non-ARPing interface, both can
be running all haproxy services at the same time, and keep the
standby server processes from interfering with active loadbalancer traffic
through the use of fencing scripts on the octavia VMs. Static routing is
accomplished to a highly available floating "routing IP" (using some VRRP-like
service for just this IP) which becomes the trigger for the fencing scripts on
the octavia VM. In this scenario, fail-overs are both much more reliable, and
can be accomplished in usually < 5 seconds.
Further, in this topology, octavia VMs do not need any additional virtual
interfaces plumbed when new front-end loadbalancer vip_addresses are assigned
to them.
Back-end topologies
-------------------
There are also two ways that octavia VMs can potentially talk to back-end
member IP addresses. Unlike the front-end topologies (where option 1 and option
2 are basically mutually exclusive, if not practically exclusive) both of these
types of connectivity can be used on a single octavia VM, and indeed, within a
single loadbalancer configuration.
**Option 1: Layer-2 connectivity**
This is layer-2 connectivity to back-end members, and is implied when a member
object has a subnet_id assigned to it. In this case, the existence of the
subnet_id implies octavia VMs need to have layer-2 connectivity to that subnet,
which means they need to have a virtual interface plumbed to it, as well as an
IP address on the subnet. This type of connectivity is useful for "secure"
back-end subnets that exist behind a NATing firewall where PAT is not in use on
the firewall. (In this way it effectively bypasses the firewall.) I anticipate
this will be the most common form of back-end connectivity in use by most
OpenStack users.
**Option 2: Routed (layer-3) connectivity**
This is routed connectivity to back-end members. This is implied when a member
object does not have a subnet_id specified. In this topology, it is assumed
that member ip_addresses are reachable through standard neutron routing, and
therefore connections to them can be initiated from the octavia VM's default
gateway. No new virtual interfaces need to be plumbed for this type of
connectivity to members.

@ -0,0 +1,225 @@
/*
* Copyright 2014 OpenStack Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
/*
* Requires graphviz version 2.37 or later to render correctly
*/
digraph G {
labelloc="t";
label="Octavia component design (v0.5)";
rankdir=LR;
splines=false;
subgraph cluster_Neutron {
label="Neutron";
color="green";
NetworkingServices [shape=rectangle label="Networking Services"];
subgraph cluster_LBaaS {
label="LBaaS";
color="yellow";
UserAPIHandler [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td style="invis"></td>
<td style="invis"></td>
<td color="#707070" sides="lt"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="tr"></td>
</tr>
<tr>
<td style="invis"></td>
<td color="#707070" sides="lt"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="tr"></td>
<td color="#707070" sides="r"></td>
</tr>
<tr>
<td sides="lt"></td>
<td sides="t"></td>
<td sides="t"><br/>User API Handler</td>
<td sides="t"></td>
<td sides="tr"></td>
<td color="#707070" sides="r"></td>
<td color="#707070" sides="r"></td>
</tr>
<tr>
<td sides="l"></td>
<td sides="ltb"></td>
<td sides="tb" port="driver"><font point-size="10">Driver</font></td>
<td sides="trb"></td>
<td sides="r"></td>
<td color="#707070" sides="r"></td>
<td color="#707070" sides="br"></td>
</tr>
<tr>
<td sides="l"></td>
<td style="invis"></td>
<td style="invis"></td>
<td style="invis"></td>
<td sides="r"></td>
<td color="#707070" sides="rb"></td>
<td style="invis"></td>
</tr>
<tr>
<td sides="lb"></td>
<td sides="b"></td>
<td sides="b"></td>
<td sides="b"></td>
<td sides="br"></td>
<td style="invis"></td>
<td style="invis"></td>
</tr>
</table>>];
};
};
subgraph cluster_Octavia {
label="Octavia";
color="blue";
NetworkingDriver [shape=rectangle label="Networking Driver"];
OperatorAPIHandler [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td style="invis"></td>
<td style="invis"></td>
<td color="#707070" sides="lt"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="tr"></td>
</tr>
<tr>
<td style="invis"></td>
<td color="#707070" sides="lt"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="t"></td>
<td color="#707070" sides="tr"></td>
<td color="#707070" sides="r"></td>
</tr>
<tr>
<td sides="lt"></td>
<td sides="t"></td>
<td sides="t"><br/>Operator API Handler</td>
<td sides="t"></td>
<td sides="tr"></td>
<td color="#707070" sides="r"></td>
<td color="#707070" sides="rb"></td>
</tr>
<tr>
<td sides="l"></td>
<td style="invis"></td>
<td style="invis"></td>
<td style="invis"></td>
<td sides="r"></td>
<td color="#707070" sides="rb"></td>
<td style="invis"></td>
</tr>
<tr>
<td sides="lb"></td>
<td sides="b"></td>
<td sides="b"></td>
<td sides="b"></td>
<td sides="br"></td>
<td style="invis"></td>
<td style="invis"></td>
</tr>
</table>>];
subgraph cluster_Controller {
label="";
color=white;
Controller [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td> Controller </td>
</tr>
<tr>
<td sides="tlrb"><font point-size="10"> Health Monitor </font></td>
</tr>
<tr>
<td sides="tlrb"><font point-size="10"> VM Driver </font></td>
</tr>
</table>>];
Database [shape=cylinder];
};
subgraph cluster_OctaviaVMs2 {
label="";
color="white";
id="OctaviaMVs2";
OctaviaVM3 [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td>Octavia VM</td>
</tr>
</table>>];
OctaviaVM4 [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td>Octavia VM</td>
</tr>
</table>>];
OctaviaVM5 [shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td>Octavia VM</td>
</tr>
</table>>];
};
subgraph cluster_Network {
label="LB Network";
color="gray";
bgcolor="gray";
Stuff [style=invis shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td>Stuff<br/></td>
</tr>
</table>>];
LBNetwork [shape=none margin=0 label=""];
Things [style=invis shape=none margin=0 label=
<<table border="0" cellspacing="0" cellborder="1">
<tr>
<td>Things<br/><br/></td>
</tr>
</table>>];
};
OperatorAPIHandler -> Controller [dir=none];
Controller -> LBNetwork [style=invis];
LBNetwork -> {OctaviaVM3 OctaviaVM4 OctaviaVM5} [style=invis];
Controller -> {OctaviaVM3 OctaviaVM4 OctaviaVM5} [constraint=false dir=none];
Controller -> NetworkingDriver [constraint=false dir=none];
Controller -> Database [constraint=false dir=none];
};
UserAPIHandler:driver -> Controller [dir=none];
NetworkingServices -> NetworkingDriver [dir=none];
}

@ -12,6 +12,14 @@ Contents:
specs/*
Version 0.5 specs:
.. toctree::
:glob:
:maxdepth: 1
specs/version0.5/*
Version 1 specs:
.. toctree::
@ -20,6 +28,18 @@ Version 1 specs:
specs/version1/*
============================
Octavia Design Documentation
============================
Version 0.5:
.. toctree::
:glob:
:maxdepth: 1
design/version0.5/*
==================
Indices and tables
==================

@ -0,0 +1,110 @@
..
This work is licensed under a Creative Commons Attribution 3.0 Unported
License.
http://creativecommons.org/licenses/by/3.0/legalcode
=============================================
Octavia v0.5 master component design document
=============================================
Problem description
===================
We need to define the various components that will make up Octavia v0.5.
Proposed change
===============
This is the first functional release of Octavia, incorporating a scalable
service delivery layer, but not yet concerned with a scalable command and
control layer.
See doc/source/design/version0.5 for a detailed description of the v0.5
component design.
Alternatives
------------
We're open to suggestions, but note that later designs already discussed on the
mailing list will incorporate several features of this design.
Data model impact
-----------------
Octavia 0.5 introduces the main data model which will also be used in
subsequent releases.
REST API impact
---------------
None
Security impact
---------------
The only sensitive data used in Octavia 0.5 are the TLS private keys used with
TERMINATED_HTTPS functionality. However, the back-end storage aspect of these
secrets will be handled by Barbican.
Octavia VMs will also need to keep copies of these secrets locally in order
to facilitate seamless service restarts. These local stores should be made
on a memory filesystem.
Notifications impact
--------------------
None
Other end user impact
---------------------
None
Performance Impact
------------------
None
Other deployer impact
---------------------
Operator API and UI may need to be changed as a result of this specification.
Developer impact
----------------
None beyond implementing the spec. :)
Implementation
==============
Assignee(s)
-----------
Lots of us will be working on this!
Work Items
----------
Again, lots of things to be done here.
Dependencies
============
Barbican
Testing
=======
A lot of new tests will need to be written to test the separate components,
their interfaces, and likely failure scenarios.
Documentation Impact
====================
This specification largely defines the documentation of the component design.
Component design is becoming a part of the project standard documentation.
References
==========
Mailing list discussion of similar designs earlier this year