Adding introduction and developer quick start docs
Octavia is currently missing any documentation designed to help new developers and operators understand what we're doing with the project or how to get started using and contributing to it. This patch set aims to correct this problem. Co-Authored-By: Michael Johnson <johnsomor@gmail.com> Co-Authored-By: Leslie Lundquist <llundquist@us.ibm.com> Closes-Bug: #1558368 Change-Id: Idaa37277bd342b644a463d4a0884ea40c2e8d4f5
This commit is contained in:
parent
02df1f7cbc
commit
1360c197c9
70
devstack/contrib/new-octavia-devstack.sh
Executable file
70
devstack/contrib/new-octavia-devstack.sh
Executable file
@ -0,0 +1,70 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
# These instructions assume an Ubuntu-based host or VM for running devstack.
|
||||
# Please note that if you are running this in a VM, it is vitally important
|
||||
# that the underlying hardware have nested virtualization enabled or you will
|
||||
# experience very poor amphora performance.
|
||||
|
||||
# Set up the packages we need. Ubuntu package manager is assumed.
|
||||
apt-get update
|
||||
apt-get install git vim -y
|
||||
|
||||
# TODO(sbalukoff): Add prerequisites for other distributions.
|
||||
|
||||
# Clone the devstack repo
|
||||
git clone https://github.com/openstack-dev/devstack.git $HOME/devstack
|
||||
|
||||
cat <<EOF > $HOME/devstack/localrc
|
||||
enable_plugin barbican https://review.openstack.org/openstack/barbican
|
||||
enable_plugin neutron-lbaas https://review.openstack.org/openstack/neutron-lbaas
|
||||
enable_plugin octavia https://review.openstack.org/openstack/octavia
|
||||
LIBS_FROM_GIT+=python-neutronclient
|
||||
|
||||
KEYSTONE_TOKEN_FORMAT=UUID
|
||||
|
||||
DATABASE_PASSWORD=secretdatabase
|
||||
RABBIT_PASSWORD=secretrabbit
|
||||
ADMIN_PASSWORD=secretadmin
|
||||
SERVICE_PASSWORD=secretservice
|
||||
SERVICE_TOKEN=111222333444
|
||||
# Enable Logging
|
||||
LOGFILE=/opt/stack/logs/stack.sh.log
|
||||
VERBOSE=True
|
||||
LOG_COLOR=True
|
||||
SCREEN_LOGDIR=/opt/stack/logs
|
||||
# Pre-requisite
|
||||
ENABLED_SERVICES=key,rabbit,mysql
|
||||
# Nova
|
||||
ENABLED_SERVICES+=,n-api,n-crt,n-obj,n-cpu,n-cond,n-sch
|
||||
# Glance
|
||||
ENABLED_SERVICES+=,g-api,g-reg
|
||||
# Neutron
|
||||
ENABLED_SERVICES+=,q-svc,q-agt,q-dhcp,q-l3,q-meta,neutron
|
||||
# Enable LBaaS V2
|
||||
ENABLED_SERVICES+=,q-lbaasv2
|
||||
# Cinder (optional)
|
||||
#ENABLED_SERVICES+=,cinder,c-api,c-vol,c-sch
|
||||
# Tempest (optional)
|
||||
#ENABLED_SERVICES+=,tempest
|
||||
# Octavia
|
||||
ENABLED_SERVICES+=,octavia,o-api,o-cw,o-hm,o-hk
|
||||
EOF
|
||||
|
||||
# Create the stack user
|
||||
$HOME/devstack/tools/create-stack-user.sh
|
||||
|
||||
# Move everything into place
|
||||
mv $HOME/devstack /opt/stack/
|
||||
chown -R stack:stack /opt/stack/devstack/
|
||||
|
||||
# Fix permissions on current tty so screens can attach
|
||||
chmod go+rw `tty`
|
||||
|
||||
# Stack that stack!
|
||||
su - stack -c /opt/stack/devstack/stack.sh
|
||||
|
||||
# Add environment variables for auth/endpoints
|
||||
echo 'source /opt/stack/devstack/openrc admin admin' >> /opt/stack/.bashrc
|
||||
|
||||
# Drop into a shell
|
||||
exec su - stack
|
518
doc/source/guides/dev-quick-start.rst
Normal file
518
doc/source/guides/dev-quick-start.rst
Normal file
@ -0,0 +1,518 @@
|
||||
..
|
||||
Copyright (c) 2016 IBM
|
||||
|
||||
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.
|
||||
|
||||
======================================
|
||||
Developer / Operator Quick Start Guide
|
||||
======================================
|
||||
This document is intended for developers and operators. For an end-user guide,
|
||||
please see the end-user quick-start guide and cookbook in this documentation
|
||||
repository.
|
||||
|
||||
|
||||
Running Octavia in devstack
|
||||
===========================
|
||||
|
||||
tl;dr
|
||||
-----
|
||||
* 8GB RAM minimum
|
||||
* "vmx" or "svm" in ``/proc/cpuinfo``
|
||||
* Ubuntu 14.04 or later
|
||||
* On that host, copy and run as root:
|
||||
``octavia/devstack/contrib/new-octavia-devstack.sh``
|
||||
|
||||
|
||||
System requirements
|
||||
-------------------
|
||||
Octavia in devstack with a default (non-HA) configuration will deploy one
|
||||
amphora VM per loadbalancer deployed. The current default amphora image also
|
||||
requires at least 1GB of RAM to run effectively. As such it is important that
|
||||
your devstack environment has enough resources dedicated to it to run all its
|
||||
necessary components. For most devstack environments, the limiting resource
|
||||
will be RAM. At the present time, we recommend at least 12GB of RAM for the
|
||||
standard devstack defaults, or 8GB of RAM if cinder and swift are disabled.
|
||||
More is recommended if you also want to run a couple of application server VMs
|
||||
(so that Octavia has something to load balance within your devstack
|
||||
environment).
|
||||
|
||||
Also, because the current implementation of Octavia delivers load balancing
|
||||
services using amphorae that run as Nova virtual machines, it is effectively
|
||||
mandatory to enable nested virtualization. The software will work with software
|
||||
emulated CPUs, but be unusably slow. The idea is to make sure the BIOS of the
|
||||
systems you're running your devstack on have virtualization features enabled
|
||||
(Intel VT-x, AMD-V, etc.), and the virtualization software you're using exposes
|
||||
these features to the guest VM (sometimes called nested virtualization).
|
||||
For more information, see:
|
||||
http://docs.openstack.org/developer/devstack/guides/devstack-with-nested-kvm.html
|
||||
|
||||
The devstack environment we recommend should be running Ubuntu Linux 14.04 or
|
||||
later. These instructions may work for other Linux operating systems or
|
||||
environments. However, most people doing development on Octavia are using
|
||||
Ubuntu for their test environment, so you will probably have the easiest time
|
||||
getting your devstack working with that OS.
|
||||
|
||||
|
||||
Deployment
|
||||
----------
|
||||
1. Deploy an Ubuntu 14.04 or later Linux host with at least 8GB of RAM. (This
|
||||
can be a VM, but again, make sure you have nested virtualization features
|
||||
enabled in your BIOS and virtualization software.)
|
||||
2. Copy ``devstack/contrib/new-octavia-devstack.sh`` from this source
|
||||
repository onto that host.
|
||||
3. Run new-octavia-devstack.sh as root.
|
||||
4. Deploy loadbalancers, listeners, etc. as you would with any Neutron LBaaS v2
|
||||
enabled cloud.
|
||||
|
||||
|
||||
Running Octavia in production
|
||||
=============================
|
||||
|
||||
Notes
|
||||
-----
|
||||
|
||||
Disclaimers
|
||||
___________
|
||||
This document is not a definitive guide for deploying Octavia in every
|
||||
production environment. There are many ways to deploy Octavia depending on the
|
||||
specifics and limitations of your situation. For example, in our experience,
|
||||
large production environments often have restrictions, hidden "features" or
|
||||
other elements in the network topology which mean the default Neutron
|
||||
networking stack (with which Octavia was designed to operate) must be modified
|
||||
or replaced with a custom networking solution. This may also mean that for your
|
||||
particular environment, you may need to write your own custom networking driver
|
||||
to plug into Octavia. Obviously, instructions for doing this are beyond the
|
||||
scope of this document.
|
||||
|
||||
We hope this document provides the cloud operator or distribution creator with
|
||||
a basic understanding of how the Octavia components fit together practically.
|
||||
Through this, it should become more obvious how components of Octavia can be
|
||||
divided or duplicated across physical hardware in a production cloud
|
||||
environment to aid in achieving scalability and resiliency for the Octavia load
|
||||
balancing system.
|
||||
|
||||
In the interest of keeping this guide somewhat high-level and avoiding
|
||||
obsolescence or operator/distribution-specific environment assumptions by
|
||||
specifying exact commands that should be run to accomplish the tasks below, we
|
||||
will instead just describe what needs to be done and leave it to the cloud
|
||||
operator or distribution creator to "do the right thing" to accomplish the task
|
||||
for their environment. If you need guidance on specific commands to run to
|
||||
accomplish the tasks described below, we recommend reading through the
|
||||
plugin.sh script in devstack subdirectory of this project. The devstack plugin
|
||||
exercises all the essential components of Octavia in the right order, and this
|
||||
guide will mostly be an elaboration of this process.
|
||||
|
||||
|
||||
Environment Assumptions
|
||||
_______________________
|
||||
The scope of this guide is to provide a basic overview of setting up all
|
||||
the components of Octavia in a production environment, assuming that the
|
||||
default in-tree drivers and components (including a "standard" Neutron install)
|
||||
are going to be used.
|
||||
|
||||
For the purposes of this guide, we will therefore assume the following core
|
||||
components have already been set up for your production OpenStack environment:
|
||||
|
||||
* Nova
|
||||
* Neutron (with Neutron LBaaS v2)
|
||||
* Glance
|
||||
* Barbican (if TLS offloading functionality is enabled)
|
||||
* Keystone
|
||||
* Rabbit
|
||||
* MySQL
|
||||
|
||||
|
||||
Production Deployment Walkthrough
|
||||
---------------------------------
|
||||
|
||||
Create Octavia User
|
||||
___________________
|
||||
By default Octavia will use the 'neutron' user for keystone authentication, and
|
||||
the admin user for interactions with all other serivces. However, it doesn't
|
||||
actually share neutron's database or otherwise access Neutron outside of
|
||||
Neutron's API, so a dedicated 'octavia' keystone user should generally be
|
||||
created for Octavia to use.
|
||||
|
||||
You must:
|
||||
|
||||
* Create 'octavia' user.
|
||||
* Add the 'admin' role to this user.
|
||||
|
||||
|
||||
Load Balancer Network Configuration
|
||||
___________________________________
|
||||
Octavia makes use of an "LB Network" exclusively as a management network that
|
||||
the controller uses to talk to amphorae and vice versa. All the amphorae that
|
||||
Octavia deploys will have interfaces and IP addresses on this network.
|
||||
Therefore, it's important that the subnet deployed on this network be
|
||||
sufficiently large to allow for the maximum number of amphorae and controllers
|
||||
likely to be deployed throughout the lifespan of the cloud installation.
|
||||
|
||||
At the present time, only IPv4 subnets have been tested as the LB Network (for
|
||||
example: 172.31.0.0/16), though there are plans to eventually support IPv6
|
||||
subnets for the LB Network.
|
||||
|
||||
The LB Network is isolated from tenant networks on the amphorae by means of
|
||||
network namespaces on the amphorae. Therefore, operators need not be concerned
|
||||
about overlapping subnet ranges with tenant networks.
|
||||
|
||||
You must also create a Neutron security group which will be applied to amphorae
|
||||
created on the LB network. It needs to allow amphorae to send UDP heartbeat
|
||||
packets to the health monitor (by default, UDP port 5555), and ingress on the
|
||||
amphora's API (by default, TCP port 9443). It can also be helpful to allow SSH
|
||||
access to the amphorae from the controller for troubleshooting purposes (ie.
|
||||
TCP port 22), though this is not strictly necessary in production environments.
|
||||
|
||||
Amphorae will send periodic health checks to the controller's health manager.
|
||||
Any firewall protecting the interface on which the health manager listens must
|
||||
allow these packets from amphorae on the LB Network (by default, UDP port
|
||||
5555).
|
||||
|
||||
Finally, you need to add routing or interfaces to this network such that the
|
||||
Octavia controller (which will be described below) is able to communicate with
|
||||
hosts on this network. This also implies you should have some idea where you're
|
||||
going to run the Octavia controller components.
|
||||
|
||||
You must:
|
||||
|
||||
* Create the 'lb-mgmt-net'.
|
||||
* Assign the 'lb-mgmt-net' to the admin tenant.
|
||||
* Create a subnet and assign it to the 'lb-mgmt-net'.
|
||||
* Create neutron security group for amphorae created on the 'lb-mgmt-net'.
|
||||
which allows appropriate access to the amphorae.
|
||||
* Update firewall rules on the host running the octavia health manager to allow
|
||||
health check messages from amphorae.
|
||||
* Add appropriate routing to / from the 'lb-mgmt-net' such that egress is
|
||||
allowed, and the controller (to be created later) can talk to hosts on this
|
||||
network.
|
||||
|
||||
|
||||
Create Amphora Image
|
||||
____________________
|
||||
Octavia deploys amphorae based on a virtual machine disk image. By default we
|
||||
use the OpenStack diskimage-builder project for this. Scripts to accomplish
|
||||
this are within the diskimage-create directory of this repository. In addition
|
||||
to creating the disk image, configure a Nova flavor to use for amphorae, and
|
||||
upload the disk image to glance.
|
||||
|
||||
You must:
|
||||
|
||||
* Create amphora disk image using OpenStack diskimage-builder.
|
||||
* Create a Nova flavor for the amphorae.
|
||||
* Add amphora disk image to glance.
|
||||
* Tag the above glance disk image with 'amphora'.
|
||||
|
||||
|
||||
Install Octavia Controller Software
|
||||
___________________________________
|
||||
This seems somewhat obvious, but the important things to note here are that you
|
||||
should put this somewhere on the network where it will have access to the
|
||||
database (to be initialized below), the oslo messaging system, and the LB
|
||||
network. Octavia uses the standard python setuptools, so installation of the
|
||||
software itself should be straightforward.
|
||||
|
||||
Running multiple instances of the individual Octavia controller components on
|
||||
seperate physical hosts is recommended in order to provide scalability and
|
||||
availability of the controller software.
|
||||
|
||||
One important security note: In 0.9 of Octavia, the Octavia API is designed to
|
||||
be consumed only by the Neutron-LBaaS v2 Octavia driver. As such, there is
|
||||
presently no authentication required to use the Octavia API, and therefore the
|
||||
Octavia API should only be accessible on trusted network segments
|
||||
(specifically, the segment that runs the neutron-services daemons.)
|
||||
|
||||
The Octavia controller presently consists of several components which may be
|
||||
split across several physical machines. For the 0.9 release of Octavia, the
|
||||
important (and potentially separable) components are the controller worker,
|
||||
housekeeper, health manager and API controller. Please see the component
|
||||
diagrams elsewhere in this repository's documentation for detailed descriptions
|
||||
of each. Please use the following table for hints on which controller
|
||||
components need access to outside resources:
|
||||
|
||||
+-------------------+----------------------------------------+
|
||||
| **Component** | **Resource** |
|
||||
+-------------------+------------+----------+----------------+
|
||||
| | LB Network | Database | OSLO messaging |
|
||||
+===================+============+==========+================+
|
||||
| API | No | Yes | Yes |
|
||||
+-------------------+------------+----------+----------------+
|
||||
| controller worker | Yes | Yes | Yes |
|
||||
+-------------------+------------+----------+----------------+
|
||||
| health monitor | Yes | Yes | No |
|
||||
+-------------------+------------+----------+----------------+
|
||||
| housekeeper | Yes | Yes | No |
|
||||
+-------------------+------------+----------+----------------+
|
||||
|
||||
In addition to talking to each other via OSLO messaging, various controller
|
||||
components must also communicate with other OpenStack components, like nova,
|
||||
neutron, barbican, etc. via their APIs.
|
||||
|
||||
You must:
|
||||
|
||||
* Pick appropriate host(s) to run the Octavia components.
|
||||
* Install the dependencies for Octavia.
|
||||
* Install the Octavia software.
|
||||
|
||||
|
||||
Create Octavia Keys and Certificates
|
||||
____________________________________
|
||||
Octavia presently allows for one method for the controller to communicate with
|
||||
amphorae: The amphora REST API. Both amphora API and Octavia controller do
|
||||
bi-directional certificate-based authentication in order to authenticate and
|
||||
encrypt communication. You must therefore create appropriate TLS certificates
|
||||
which will be used for key signing, authentication, and encryption. There is a
|
||||
helper script to do this in this repository under:
|
||||
``bin/create_certficiates.sh``
|
||||
|
||||
Please note that certificates created with this helper script may not meet your
|
||||
organization's security policies, since they are self-signed certificates with
|
||||
arbitrary bit lengths, expiration dates, etc. Operators should obviously
|
||||
follow their own security guidelines in creating these certificates.
|
||||
|
||||
In addition to the above, it can sometimes be useful for cloud operators to log
|
||||
into running amphorae to troubleshoot problems. The standard method for doing
|
||||
this is to use SSH from the host running the controller worker. In order to do
|
||||
this, you must create an SSH public/private key pair specific to your cloud
|
||||
(for obvious security reasons). You must add this keypair to nova. You must
|
||||
then also update octavia.conf with the keypair name you used when adding it to
|
||||
nova so that amphorae are initialized with it on boot.
|
||||
|
||||
See the Troubleshooting Tips section below for an example of how an operator
|
||||
can SSH into an amphora.
|
||||
|
||||
You must:
|
||||
|
||||
* Create TLS certificates for communicating with the amphorae.
|
||||
* Create SSH keys for communicating with the amphorae.
|
||||
* Add the SSH keypair to nova.
|
||||
|
||||
|
||||
Configuring Octavia
|
||||
___________________
|
||||
Going into all of the specifics of how Octavia can be configured is actually
|
||||
beyond the scope of this document. For full documentation of this, please see
|
||||
the configuration reference: :doc:`../main/configref`
|
||||
|
||||
A configuration template can be found in ``etc/octavia.conf`` in this
|
||||
repository.
|
||||
|
||||
It's also important to note that this configuration file will need to be
|
||||
updated with UUIDs of the LB network, amphora security group, amphora image
|
||||
tag, SSH key path, TLS certificate path, database credentials, etc.
|
||||
|
||||
At a minimum, the configuration should specify the following, beyond the
|
||||
defaults. Your specific environment may require more than this:
|
||||
|
||||
+-----------------------+-------------------------------+
|
||||
| Section | Configuration parameter |
|
||||
+=======================+===============================+
|
||||
| DEFAULT | transport_url |
|
||||
+-----------------------+-------------------------------+
|
||||
| database | connection |
|
||||
+-----------------------+-------------------------------+
|
||||
| certificates | ca_certificate |
|
||||
+-----------------------+-------------------------------+
|
||||
| certificates | ca_private_key |
|
||||
+-----------------------+-------------------------------+
|
||||
| certificates | ca_private_key_passphrase |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_boot_network_list |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_flavor_id |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_image_owner_id |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_image_tag |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_secgroup_list |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amp_ssh_key_name [#]_ |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | amphora_driver |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | compute_driver |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | loadbalancer_topology |
|
||||
+-----------------------+-------------------------------+
|
||||
| controller_worker | network_driver |
|
||||
+-----------------------+-------------------------------+
|
||||
| haproxy_amphora | client_cert |
|
||||
+-----------------------+-------------------------------+
|
||||
| haproxy_amphora | server_ca |
|
||||
+-----------------------+-------------------------------+
|
||||
| health_manager | bind_ip |
|
||||
+-----------------------+-------------------------------+
|
||||
| health_manager | controller_ip_port_list |
|
||||
+-----------------------+-------------------------------+
|
||||
| health_manager | heartbeat_key |
|
||||
+-----------------------+-------------------------------+
|
||||
| house_keeping | spare_amphora_pool_size |
|
||||
+-----------------------+-------------------------------+
|
||||
| keystone_authtoken | admin_password |
|
||||
+-----------------------+-------------------------------+
|
||||
| keystone_authtoken | admin_tenant_name |
|
||||
+-----------------------+-------------------------------+
|
||||
| keystone_authtoken | admin_user |
|
||||
+-----------------------+-------------------------------+
|
||||
| keystone_authtoken | auth_uri |
|
||||
+-----------------------+-------------------------------+
|
||||
| keystone_authtoken | auth_version |
|
||||
+-----------------------+-------------------------------+
|
||||
| oslo_messaging | topic |
|
||||
+-----------------------+-------------------------------+
|
||||
| oslo_messaging_rabbit | rabbit_host |
|
||||
+-----------------------+-------------------------------+
|
||||
| oslo_messaging_rabbit | rabbit_userid |
|
||||
+-----------------------+-------------------------------+
|
||||
| oslo_messaging_rabbit | rabbit_password |
|
||||
+-----------------------+-------------------------------+
|
||||
|
||||
.. [#] This is technically optional, but extremely useful for troubleshooting.
|
||||
|
||||
You must:
|
||||
|
||||
* Create or update ``/etc/octavia/octavia.conf`` appropriately.
|
||||
|
||||
|
||||
Spares pool considerations
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
One configuration directive deserves some extra consideration in this document:
|
||||
|
||||
Depending on the specifics of your production environment, you may decide to
|
||||
run Octavia with a non-empty "spares pool." Since the time it takes to spin up
|
||||
a new amphora can be non-trivial in some cloud environments (and the
|
||||
reliability of such operations can sometimes be less than ideal), this
|
||||
directive instructs Octavia to attempt to maintain a certain number of amphorae
|
||||
running in an idle, unconfigured state. These amphora will run base amphora
|
||||
health checks and wait for configuration from the Octavia controller. The
|
||||
overall effect of this is to greatly reduce the time it takes and increase the
|
||||
reliability of deploying a new load balancing service on demand. This comes at
|
||||
the cost of having a number of deployed amphorae which consume resources but
|
||||
are not actively providing load balancing services, and at the cost of not
|
||||
being able to use Nova anti-affinity features for ACTIVE-STANDBY load
|
||||
balancer topologies.
|
||||
|
||||
|
||||
Initialize Octavia Database
|
||||
___________________________
|
||||
This is controlled through alembic migrations under the octavia/db directory in
|
||||
this repository. A tool has been created to aid in the initialization of the
|
||||
octavia database. This should be available under
|
||||
``/usr/local/bin/octavia-db-manage`` on the host on which the octavia
|
||||
controller worker is installed. Note that this tool looks at the
|
||||
``/etc/octavia/octavia.conf`` file for its database credentials, so
|
||||
initializing the database must happen after Octavia is configured.
|
||||
|
||||
It's also important to note here that all of the components of the Octavia
|
||||
controller will need direct access to the database (including the API handler),
|
||||
so you must ensure these components are able to communicate with whichever host
|
||||
is housing your database.
|
||||
|
||||
You must:
|
||||
|
||||
* Create database credentials for Octavia.
|
||||
* Add these to the ``/etc/octavia/octavia.conf`` file.
|
||||
* Run ``/usr/local/bin/octavia-db-manage upgrade head`` on the controller
|
||||
worker host to initialize the octavia database.
|
||||
|
||||
|
||||
Launching the Octavia Controller
|
||||
________________________________
|
||||
We recommend using upstart / systemd scripts to ensure the components of the
|
||||
Octavia controller are all started and kept running. It of course doesn't hurt
|
||||
to first start by running these manually to ensure configuration and
|
||||
communication is working between all the components.
|
||||
|
||||
You must:
|
||||
|
||||
* Make sure each Octavia controller component is started appropriately.
|
||||
|
||||
|
||||
Configuring Neutron LBaaS
|
||||
_________________________
|
||||
This is fairly straightforward. Neutron LBaaS needs to be directed to use the
|
||||
Octavia service provider. There should be a line like the following in
|
||||
``/etc/neutron/neutron_lbaas.conf`` file's ``[service providers]`` section:
|
||||
|
||||
::
|
||||
|
||||
service_provider = LOADBALANCERV2:Octavia:neutron_lbaas.drivers.octavia.driver.OctaviaDriver:default
|
||||
|
||||
In addition to the above you must add the octavia API ``base_url`` to the
|
||||
``[octavia]`` section of ``/etc/neutron/neutron.conf``. For example:
|
||||
|
||||
::
|
||||
|
||||
[octavia]
|
||||
base_url=http://127.0.0.1:9876
|
||||
|
||||
You must:
|
||||
|
||||
* Update ``/etc/neutron/neutron_lbaas.conf`` as described above.
|
||||
* Add the octavia API URL to ``/etc/neutron/neutron.conf``.
|
||||
|
||||
|
||||
Install Neutron-LBaaS v2 extension in Horizon
|
||||
_____________________________________________
|
||||
This isn't strictly necessary for all cloud installations, however, if yours
|
||||
makes use of the Horizon GUI interface for tenants, it is probably also a good
|
||||
idea to make sure that it is configured with the Neutron-LBaaS v2 extension.
|
||||
|
||||
You may:
|
||||
|
||||
* Install the neutron-lbaasv2 GUI extension in Horizon
|
||||
|
||||
|
||||
Test deployment
|
||||
_______________
|
||||
If all of the above instructions have been followed, it should now be possible
|
||||
to deploy load balancing services using the python neutronclient CLI,
|
||||
communicating with the neutron-lbaas v2 API.
|
||||
|
||||
Example:
|
||||
|
||||
::
|
||||
|
||||
# neutron lbaas-loadbalancer-create --name lb1 private-subnet
|
||||
# neutron lbaas-loadbalancer-show lb1 # Keep re-running this command until this shows a provisioning status of 'ACTIVE'
|
||||
# neutron lbaas-listener-create --name listener1 --loadbalancer lb1 --protocol HTTP --protocol-port 80
|
||||
|
||||
Upon executing the above, log files should indicate that an amphora is deployed
|
||||
to house the load balancer, and that this load balancer is further modified to
|
||||
include a listener. The amphora should be visible to the octavia or admin
|
||||
tenant using the ``nova list`` command, and the listener should respond on the
|
||||
load balancer's IP on port 80 (with an error 503 in this case, since no pool or
|
||||
members have been defined yet—but this is usually enough to see that the
|
||||
Octavia load balancing system is working). For more information on configuring
|
||||
load balancing services as a tenant, please see the end-user quick-start guide
|
||||
and cookbook.
|
||||
|
||||
|
||||
Troubleshooting Tips
|
||||
====================
|
||||
The troubleshooting hints in this section are meant primarily for developers
|
||||
or operators troubleshooting underlying Octavia components, rather than
|
||||
end-users or tenants troubleshooting the load balancing service itself.
|
||||
|
||||
|
||||
SSH into Amphorae
|
||||
-----------------
|
||||
If you are using the reference amphora image, it may be helpful to log into
|
||||
running amphorae when troubleshooting service problems. To do this, first
|
||||
discover the ``lb_network_ip`` address of the amphora you would like to SSH
|
||||
into by looking in the ``amphora`` table in the octavia database. Then from the
|
||||
host housing the controller worker, run:
|
||||
|
||||
::
|
||||
|
||||
ssh -i /etc/octavia/.ssh/octavia_ssh_key ubuntu@[lb_network_ip]
|
@ -10,6 +10,7 @@ Getting started
|
||||
.. toctree::
|
||||
:maxdepth: 1
|
||||
|
||||
main/introduction.rst
|
||||
main/glossary.rst
|
||||
|
||||
For users
|
||||
@ -27,6 +28,7 @@ For developers
|
||||
.. toctree::
|
||||
:maxdepth: 1
|
||||
|
||||
guides/dev-quick-start.rst
|
||||
main/CONSTITUTION.rst
|
||||
main/HACKING.rst
|
||||
devref/flows.rst
|
||||
@ -38,6 +40,7 @@ For operators
|
||||
.. toctree::
|
||||
:maxdepth: 1
|
||||
|
||||
guides/dev-quick-start.rst
|
||||
main/configref.rst
|
||||
|
||||
====
|
||||
|
152
doc/source/main/introduction.rst
Normal file
152
doc/source/main/introduction.rst
Normal file
@ -0,0 +1,152 @@
|
||||
..
|
||||
Copyright (c) 2016 IBM
|
||||
|
||||
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.
|
||||
|
||||
===================
|
||||
Introducing Octavia
|
||||
===================
|
||||
Welcome to Octavia!
|
||||
|
||||
Octavia is an open source, operator-scale load balancing solution designed to
|
||||
work with OpenStack.
|
||||
|
||||
Octavia was borne out of the Neutron LBaaS project. Its conception influenced
|
||||
the transformation of the Neutron LBaaS project, as Neutron LBaaS moved from
|
||||
version 1 to version 2. Starting with the Liberty release of OpenStack, Octavia
|
||||
has become the reference implementation for Neutron LBaaS version 2.
|
||||
|
||||
Octavia accomplishes its delivery of load balancing services by managing a
|
||||
fleet of virtual machines, containers, or bare metal servers—collectively known
|
||||
as *amphorae*\— which it spins up on demand. This on-demand, horizontal scaling
|
||||
feature differentiates Octavia from other load balancing solutions, thereby
|
||||
making Octavia truly suited "for the cloud."
|
||||
|
||||
Where Octavia fits into the OpenStack ecosystem
|
||||
-----------------------------------------------
|
||||
Load balancing is essential for enabling simple or automatic delivery scaling
|
||||
and availability. In turn, application delivery scaling and availability must
|
||||
be considered vital features of any cloud. Together, these facts imply that
|
||||
load balancing is a vital feature of any cloud.
|
||||
|
||||
Therefore, we consider Octavia to be as essential as Nova, Neutron, Glance or
|
||||
any other "core" project that enables the essential features of a modern
|
||||
OpenStack cloud.
|
||||
|
||||
In accomplishing its role, Octavia makes use of other OpenStack projects:
|
||||
|
||||
* **Nova** - For managing amphora lifecycle and spinning up compute resources
|
||||
on demand.
|
||||
* **Neutron** - For network connectivity between amphorae, tenant environments,
|
||||
and external networks.
|
||||
* **Barbican** - For managing TLS certificates and credentials, when TLS
|
||||
session termination is configured on the amphorae.
|
||||
* **Keystone** - For authentication against the Octavia API, and for Octavia to
|
||||
authenticate with other OpenStack projects.
|
||||
* **Glance** - For storing the amphora virtual machine image.
|
||||
* **Oslo** - For communication between Octavia controller components, making
|
||||
Octavia work within the standard OpenStack framework and review system, and
|
||||
project code structure.
|
||||
* **Taskflow** - Is technically part of Oslo; however, Octavia makes
|
||||
extensive use of this job flow system when orchestrating back-end service
|
||||
configuration and management.
|
||||
|
||||
Octavia is designed to interact with the components listed previously. In each
|
||||
case, we’ve taken care to define this interaction through a driver interface.
|
||||
That way, external components can be swapped out with functionally-equivalent
|
||||
replacements— without having to restructure major components of Octavia. For
|
||||
example, if you use an SDN solution other than Neutron in your environment, it
|
||||
should be possible for you to write an Octavia networking driver for your SDN
|
||||
environment, which can be a drop-in replacement for the standard Neutron
|
||||
networking driver in Octavia.
|
||||
|
||||
It is important for you to know that Octavia is not necessarily designed as a
|
||||
complete replacement for the Neutron LBaaS project. That is to say, Octavia is
|
||||
designed to "plug in" to Neutron LBaaS in the same way that any proprietary
|
||||
vendor solution would: through a Neutron LBaaS version 2 driver interface. You
|
||||
could think of Octavia as an "open source vendor" for Neutron LBaaS, rather
|
||||
than as a substitute for Neutron LBaaS. For this reason, we recommend that
|
||||
tenants configure load balancing services with Octavia through the Neutron
|
||||
LBaaS version 2 CLI and API.
|
||||
|
||||
Soon, Octavia will supplant Neutron LBaaS as the load balancing solution for
|
||||
OpenStack. At that time, third-party vendor drivers that presently "plug in"
|
||||
to Neutron LBaaS will plug in to Octavia instead. For end-users, this
|
||||
transition should be relatively seamless, because Octavia supports the Neutron
|
||||
LBaaS v2 API and it has a similar CLI interface.
|
||||
|
||||
|
||||
Octavia terminology
|
||||
-------------------
|
||||
Before you proceed further in this introduction, please note:
|
||||
|
||||
Experience shows that—within the subsegment of the IT industry that creates,
|
||||
deploys, and uses load balancing devices or services— terminology is often used
|
||||
inconsistently. To reduce confusion, the Octavia team has created a glossary of
|
||||
terms as they are defined and used within the context of the Octavia project
|
||||
and Neutron LBaaS version 2. This glossary is available here: :doc:`glossary`
|
||||
|
||||
If you are familiar with Neutron LBaaS version 1 terms and usage, it is
|
||||
especially important for you to understand how the meanings of the terms “VIP,"
|
||||
"load balancer," and "load balancing," have changed in Neutron LBaaS version 2.
|
||||
|
||||
Our use of these terms should remain consistent with the :doc:`glossary`
|
||||
throughout Octavia's documentation, in discussions held by Octavia team members
|
||||
on public mailing lists, in IRC channels, and at conferences. To avoid
|
||||
misunderstandings, it's a good idea to familiarize yourself with these glossary
|
||||
definitions.
|
||||
|
||||
|
||||
A 10,000-foot overview of Octavia components
|
||||
--------------------------------------------
|
||||
.. image:: octavia-component-overview.svg
|
||||
:width: 660px
|
||||
:alt: Octavia Component Overview
|
||||
|
||||
Octavia version 0.9 consists of the following major components:
|
||||
|
||||
* **amphorae** - Amphorae are the individual virtual machines, containers, or
|
||||
bare metal servers that accomplish the delivery of load balancing services to
|
||||
tenant application environments. In Octavia version 0.8, the reference
|
||||
implementation of the amphorae image is an Ubuntu virtual machine running
|
||||
HAProxy.
|
||||
|
||||
* **controller** - The Controller is the "brains" of Octavia. It consists of
|
||||
four sub-components, which are individual daemons. They can be run on
|
||||
separate back-end infrastructure if desired:
|
||||
|
||||
* **API Controller** - As the name implies, this subcomponent runs Octavia's
|
||||
API. It takes API requests, performs simple sanitizing on them, and ships
|
||||
them off to the controller worker over the Oslo messaging bus.
|
||||
|
||||
* **Controller Worker** - This subcomponent takes sanitized API commands from
|
||||
the API controller and performs the actions necessary to fulfill the API
|
||||
request.
|
||||
|
||||
* **Health Manager** - This subcomponent monitors individual amphorae to
|
||||
ensure they are up and running, and otherwise healthy. It also handles
|
||||
failover events if amphorae fail unexpectedly.
|
||||
|
||||
* **Housekeeping Manager** - This subcomponent cleans up stale (deleted)
|
||||
database records, manages the spares pool, and manages amphora certificate
|
||||
rotation.
|
||||
|
||||
* **network** - Octavia cannot accomplish what it does without manipulating
|
||||
the network environment. Amphorae are spun up with a network interface on the
|
||||
"load balancer network," and they may also plug directly into tenant networks
|
||||
to reach back-end pool members, depending on how any given load balancing
|
||||
service is deployed by the tenant.
|
||||
|
||||
For a more complete description of Octavia's components, please see the
|
||||
:doc:`../design/version0.5/component-design` document within this documentation
|
||||
repository.
|
400
doc/source/main/octavia-component-overview.svg
Normal file
400
doc/source/main/octavia-component-overview.svg
Normal file
@ -0,0 +1,400 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||
<!-- Generated by Microsoft Visio, SVG Export OctaviaComp.svg Page-1 -->
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ev="http://www.w3.org/2001/xml-events"
|
||||
xmlns:v="http://schemas.microsoft.com/visio/2003/SVGExtensions/" width="11.6929in" height="8.26772in"
|
||||
viewBox="0 0 841.89 595.276" xml:space="preserve" color-interpolation-filters="sRGB" class="st15">
|
||||
<v:documentProperties v:langID="1033" v:metric="true" v:viewMarkup="false">
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="msvSubprocessMaster" v:prompt="" v:val="VT4(Rectangle)"/>
|
||||
<v:ud v:nameU="msvNoAutoConnect" v:val="VT0(1):26"/>
|
||||
</v:userDefs>
|
||||
</v:documentProperties>
|
||||
|
||||
<style type="text/css">
|
||||
<![CDATA[
|
||||
.st1 {fill:#339933;fill-opacity:0.64;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st2 {fill:#1ba1e2;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st3 {fill:#ffffff;font-family:Segoe UI;font-size:1.16666em}
|
||||
.st4 {font-size:1em}
|
||||
.st5 {fill:#d80073;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st6 {marker-end:url(#mrkr4-43);marker-start:url(#mrkr4-41);stroke:#1897d5;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}
|
||||
.st7 {fill:#1897d5;fill-opacity:1;stroke:#1897d5;stroke-opacity:1;stroke-width:0.44247787610619}
|
||||
.st8 {marker-end:url(#mrkr4-43);stroke:#1897d5;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}
|
||||
.st9 {fill:#f09609;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st10 {fill:none;stroke:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st11 {fill:#339933;fill-opacity:0.79;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st12 {fill:#339933;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st13 {marker-start:url(#mrkr4-41);stroke:#1897d5;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}
|
||||
.st14 {fill:#a200ff;stroke:#ffffff;stroke-linecap:round;stroke-linejoin:round;stroke-width:0.5}
|
||||
.st15 {fill:none;fill-rule:evenodd;font-size:12px;overflow:visible;stroke-linecap:square;stroke-miterlimit:3}
|
||||
]]>
|
||||
</style>
|
||||
|
||||
<defs id="Markers">
|
||||
<g id="lend4">
|
||||
<path d="M 2 1 L 0 0 L 2 -1 L 2 1 " style="stroke:none"/>
|
||||
</g>
|
||||
<marker id="mrkr4-41" class="st7" v:arrowType="4" v:arrowSize="2" v:setback="4.34" refX="4.34" orient="auto"
|
||||
markerUnits="strokeWidth" overflow="visible">
|
||||
<use xlink:href="#lend4" transform="scale(2.26) "/>
|
||||
</marker>
|
||||
<marker id="mrkr4-43" class="st7" v:arrowType="4" v:arrowSize="2" v:setback="4.52" refX="-4.52" orient="auto"
|
||||
markerUnits="strokeWidth" overflow="visible">
|
||||
<use xlink:href="#lend4" transform="scale(-2.26,-2.26) "/>
|
||||
</marker>
|
||||
</defs>
|
||||
<g v:mID="0" v:index="1" v:groupContext="foregroundPage">
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="msvThemeOrder" v:val="VT0(0):26"/>
|
||||
</v:userDefs>
|
||||
<title>Page-1</title>
|
||||
<v:pageProperties v:drawingScale="0.0393701" v:pageScale="0.0393701" v:drawingUnits="24" v:shadowOffsetX="8.50394"
|
||||
v:shadowOffsetY="-8.50394"/>
|
||||
<v:layer v:name="Connector" v:index="0"/>
|
||||
<v:layer v:name="Flowchart" v:index="1"/>
|
||||
<g id="shape1023-1" v:mID="1023" v:groupContext="shape" transform="translate(307.343,-28.3465)">
|
||||
<title>Parallelogram.1023</title>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:prompt="" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<path d="M0 595.28 L102.05 595.28 L113.39 510.24 L11.34 510.24 L0 595.28 Z" class="st1"/>
|
||||
</g>
|
||||
<g id="shape1-3" v:mID="1" v:groupContext="shape" transform="translate(331.214,-253.382)">
|
||||
<title>Rectangle</title>
|
||||
<desc>Controller Worker Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="223.228" cy="569.54" width="446.46" height="51.4712"/>
|
||||
<rect x="0" y="543.804" width="446.457" height="51.4712" class="st2"/>
|
||||
<text x="147.47" y="573.74" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Controller Worker Driver</text> </g>
|
||||
<g id="shape2-6" v:mID="2" v:groupContext="shape" transform="translate(451.214,-166.925)">
|
||||
<title>Square</title>
|
||||
<desc>Certificate Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="43.2283" cy="552.047" width="86.46" height="86.4567"/>
|
||||
<rect x="0" y="508.819" width="86.4567" height="86.4567" class="st2"/>
|
||||
<text x="12.02" y="547.85" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Certificate<v:newlineChar/><tspan
|
||||
x="24.74" dy="1.2em" class="st4">Driver</tspan></text> </g>
|
||||
<g id="shape3-10" v:mID="3" v:groupContext="shape" transform="translate(571.214,-166.925)">
|
||||
<title>Square.3</title>
|
||||
<desc>Compute Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="43.2283" cy="552.047" width="86.46" height="86.4567"/>
|
||||
<rect x="0" y="508.819" width="86.4567" height="86.4567" class="st2"/>
|
||||
<text x="14.65" y="547.85" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Compute<v:newlineChar/><tspan
|
||||
x="24.74" dy="1.2em" class="st4">Driver</tspan></text> </g>
|
||||
<g id="shape4-14" v:mID="4" v:groupContext="shape" transform="translate(691.214,-166.925)">
|
||||
<title>Square.4</title>
|
||||
<desc>Network Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="43.2283" cy="552.047" width="86.46" height="86.4567"/>
|
||||
<rect x="0" y="508.819" width="86.4567" height="86.4567" class="st2"/>
|
||||
<text x="16.89" y="547.85" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Network<v:newlineChar/><tspan
|
||||
x="24.74" dy="1.2em" class="st4">Driver</tspan></text> </g>
|
||||
<g id="shape5-18" v:mID="5" v:groupContext="shape" transform="translate(331.214,-166.925)">
|
||||
<title>Square.5</title>
|
||||
<desc>Amphora Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="43.2283" cy="552.047" width="86.46" height="86.4567"/>
|
||||
<rect x="0" y="508.819" width="86.4567" height="86.4567" class="st2"/>
|
||||
<text x="14.51" y="547.85" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Amphora<v:newlineChar/><tspan
|
||||
x="24.74" dy="1.2em" class="st4">Driver</tspan></text> </g>
|
||||
<g id="shape1001-22" v:mID="1001" v:groupContext="shape" transform="translate(687.192,-53.5394)">
|
||||
<title>Ellipse.6</title>
|
||||
<desc>Neutron</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="47.25" cy="563.776" width="82.69" height="55.125"/>
|
||||
<path d="M0 563.78 A47.25 31.5 0 0 1 94.5 563.78 A47.25 31.5 0 1 1 0 563.78 Z" class="st5"/>
|
||||
<text x="21.52" y="567.98" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Neutron</text> </g>
|
||||
<g id="shape1002-25" v:mID="1002" v:groupContext="shape" transform="translate(567.192,-53.5394)">
|
||||
<title>Ellipse.5</title>
|
||||
<desc>Nova</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="47.25" cy="563.776" width="82.69" height="55.125"/>
|
||||
<path d="M0 563.78 A47.25 31.5 0 0 1 94.5 563.78 A47.25 31.5 0 1 1 0 563.78 Z" class="st5"/>
|
||||
<text x="31" y="567.98" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Nova</text> </g>
|
||||
<g id="shape1003-28" v:mID="1003" v:groupContext="shape" transform="translate(447.192,-53.5394)">
|
||||
<title>Ellipse.69</title>
|
||||
<desc>Barbican</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="47.25" cy="563.776" width="82.69" height="55.125"/>
|
||||
<path d="M0 563.78 A47.25 31.5 0 0 1 94.5 563.78 A47.25 31.5 0 1 1 0 563.78 Z" class="st5"/>
|
||||
<text x="20.68" y="567.98" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Barbican</text> </g>
|
||||
<g id="shape1004-31" v:mID="1004" v:groupContext="shape" transform="translate(210.906,-330.27)">
|
||||
<title>Ellipse.3</title>
|
||||
<desc>Oslo Messaging</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="47.25" cy="563.776" width="82.69" height="55.125"/>
|
||||
<path d="M0 563.78 A47.25 31.5 0 0 1 94.5 563.78 A47.25 31.5 0 1 1 0 563.78 Z" class="st5"/>
|
||||
<text x="33.21" y="559.58" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Oslo<v:newlineChar/><tspan
|
||||
x="13.9" dy="1.2em" class="st4">Messaging</tspan></text> </g>
|
||||
<g id="shape1006-35" v:mID="1006" v:groupContext="shape" v:layerMember="0" transform="translate(331.214,-272.031)">
|
||||
<title>Dynamic connector.1006</title>
|
||||
<path d="M-8.68 588.19 L-9.04 588.19 L-29.47 588.19" class="st6"/>
|
||||
</g>
|
||||
<g id="shape1007-44" v:mID="1007" v:groupContext="shape" v:layerMember="0" transform="translate(727.356,-166.925)">
|
||||
<title>Dynamic connector.1007</title>
|
||||
<path d="M7.09 595.28 L7.09 636.62" class="st8"/>
|
||||
</g>
|
||||
<g id="shape1008-49" v:mID="1008" v:groupContext="shape" v:layerMember="0" transform="translate(607.356,-166.925)">
|
||||
<title>Dynamic connector.1008</title>
|
||||
<path d="M7.09 595.28 L7.09 636.62" class="st8"/>
|
||||
</g>
|
||||
<g id="shape1009-54" v:mID="1009" v:groupContext="shape" v:layerMember="0" transform="translate(487.356,-166.925)">
|
||||
<title>Dynamic connector.1009</title>
|
||||
<path d="M7.09 595.28 L7.09 636.62" class="st8"/>
|
||||
</g>
|
||||
<g id="shape1010-59" v:mID="1010" v:groupContext="shape" v:layerMember="0" transform="translate(417.671,-203.067)">
|
||||
<title>Dynamic connector.1010</title>
|
||||
<path d="M0 588.19 L24.5 588.19" class="st8"/>
|
||||
</g>
|
||||
<g id="group1011-64" transform="translate(71.7133,-304.853)" v:mID="1011" v:groupContext="group">
|
||||
<title>Sheet.1011</title>
|
||||
<g id="shape9-65" v:mID="9" v:groupContext="shape" transform="translate(0,-0.447576)">
|
||||
<title>Square.9</title>
|
||||
<desc>Octavia API</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="538.583" width="113.39" height="113.386"/>
|
||||
<rect x="0" y="481.89" width="113.386" height="113.386" class="st9"/>
|
||||
<text x="33.64" y="534.38" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Octavia<v:newlineChar/><tspan
|
||||
x="46.39" dy="1.2em" class="st4">API</tspan></text> </g>
|
||||
<g id="shape15-69" v:mID="15" v:groupContext="shape" transform="translate(80.3899,0)">
|
||||
<title>Sheet.15</title>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
<image x="0" y="564.279" width="32.9959" height="30.9961" preserveAspectRatio="none" xlink:href="data:image/png;base64,
|
||||
iVBORw0KGgoAAAANSUhEUgAAACEAAAAfCAYAAABplKSyAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMA
|
||||
AA7DAcdvqGQAAAI9SURBVFhHxZYhUxxBEIVXICIQCEQEAolERiAQCEREBAKBQCAQEQj+AzIyMiIiAhGBQCAQCATixAkEAqoQCERE
|
||||
BAJxvC9sX/UNb2/3iqpNV311M29mumd3evq2Go1G/x0r9o0V+8aKfWPFLsjmiv587s+CFach+yxOxHmhfxfX4qtYyGNtWNEhOxQ0
|
||||
4Lb+XanH5sVfETptNtXp7VjRIfstngUd+CMeBYEfRB5Du3Z+HFZ0yDbqAF1gQwfOj8OKgexjam+LCNIGm7gQ/45DtgDhq8SKIFsX
|
||||
T+KnIB/y6+7KpTgW+DlyccCKIPsl7gXnnR3PAsHJjyuBn4lrPY5lxapaFDjIDh1lMuYxx5aNZ8XJ69gEt+NAcGw7gqeddmSMndp4
|
||||
VqyqTYFTOlzDcJTZKNZ8ECTjQJRzgbG9vGa81omBjCfNjoJhw/wvaU5mas2wYiDbTY4yEyU7zW+qJbNvQkZi7osbkZ0FlOVxDUnr
|
||||
juqxcj5Ju1bOD7z4ej1pnNa/JSQlZ7yU1lDMmhIzbo5/g1Z8zfhw0AQJS1AKUlstuRPMtQXrjRDI+Fs+E9nZe2ATyzaWE0EWtYIz
|
||||
5tq5s24jF7wTFwesCDKSkw8U7j/fC+RAlyoasOk1sSp+iIm6krGio3aYg7Sx6/w4rOiQ8TS5eg5Tu+wz75vz47BiiWxORM3gWCIY
|
||||
tYSbxLGFxvcnSXjrfDms6JCxkS0RmxgU41ELuFUk9WIen4YV25CRbJ8Kjf+N9ax1xYp9Y8W+sWK/jKoXFAS4xJXVHUYAAAAASUVO
|
||||
RK5CYII="/>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
</g>
|
||||
</g>
|
||||
<g id="group1012-73" transform="translate(331.214,-304.853)" v:mID="1012" v:groupContext="group">
|
||||
<title>Sheet.1012</title>
|
||||
<g id="shape6-74" v:mID="6" v:groupContext="shape" transform="translate(-1.59872E-14,-0.447576)">
|
||||
<title>Square.6</title>
|
||||
<desc>Octavia Worker</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="538.583" width="113.39" height="113.386"/>
|
||||
<rect x="0" y="481.89" width="113.386" height="113.386" class="st9"/>
|
||||
<text x="33.64" y="534.38" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Octavia<v:newlineChar/><tspan
|
||||
x="34.05" dy="1.2em" class="st4">Worker</tspan></text> </g>
|
||||
<g id="shape16-78" v:mID="16" v:groupContext="shape" transform="translate(80.3899,0)">
|
||||
<title>Sheet.16</title>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
<image x="0" y="564.279" width="32.9959" height="30.9961" preserveAspectRatio="none" xlink:href="data:image/png;base64,
|
||||
iVBORw0KGgoAAAANSUhEUgAAACEAAAAfCAYAAABplKSyAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMA
|
||||
AA7DAcdvqGQAAAI9SURBVFhHxZYhUxxBEIVXICIQCEQEAolERiAQCEREBAKBQCAQEQj+AzIyMiIiAhGBQCAQCATixAkEAqoQCERE
|
||||
BAJxvC9sX/UNb2/3iqpNV311M29mumd3evq2Go1G/x0r9o0V+8aKfWPFLsjmiv587s+CFach+yxOxHmhfxfX4qtYyGNtWNEhOxQ0
|
||||
4Lb+XanH5sVfETptNtXp7VjRIfstngUd+CMeBYEfRB5Du3Z+HFZ0yDbqAF1gQwfOj8OKgexjam+LCNIGm7gQ/45DtgDhq8SKIFsX
|
||||
T+KnIB/y6+7KpTgW+DlyccCKIPsl7gXnnR3PAsHJjyuBn4lrPY5lxapaFDjIDh1lMuYxx5aNZ8XJ69gEt+NAcGw7gqeddmSMndp4
|
||||
VqyqTYFTOlzDcJTZKNZ8ECTjQJRzgbG9vGa81omBjCfNjoJhw/wvaU5mas2wYiDbTY4yEyU7zW+qJbNvQkZi7osbkZ0FlOVxDUnr
|
||||
juqxcj5Ju1bOD7z4ej1pnNa/JSQlZ7yU1lDMmhIzbo5/g1Z8zfhw0AQJS1AKUlstuRPMtQXrjRDI+Fs+E9nZe2ATyzaWE0EWtYIz
|
||||
5tq5s24jF7wTFwesCDKSkw8U7j/fC+RAlyoasOk1sSp+iIm6krGio3aYg7Sx6/w4rOiQ8TS5eg5Tu+wz75vz47BiiWxORM3gWCIY
|
||||
tYSbxLGFxvcnSXjrfDms6JCxkS0RmxgU41ELuFUk9WIen4YV25CRbJ8Kjf+N9ax1xYp9Y8W+sWK/jKoXFAS4xJXVHUYAAAAASUVO
|
||||
RK5CYII="/>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
</g>
|
||||
</g>
|
||||
<g id="group1013-82" transform="translate(497.749,-305.301)" v:mID="1013" v:groupContext="group">
|
||||
<title>Sheet.1013</title>
|
||||
<g id="shape7-83" v:mID="7" v:groupContext="shape">
|
||||
<title>Square.7</title>
|
||||
<desc>Health Manager</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="538.583" width="113.39" height="113.386"/>
|
||||
<rect x="0" y="481.89" width="113.386" height="113.386" class="st9"/>
|
||||
<text x="36.47" y="534.38" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Health<v:newlineChar/><tspan
|
||||
x="29.11" dy="1.2em" class="st4">Manager</tspan></text> </g>
|
||||
<g id="shape17-87" v:mID="17" v:groupContext="shape" transform="translate(80.3899,0)">
|
||||
<title>Sheet.17</title>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
<image x="0" y="564.279" width="32.9959" height="30.9961" preserveAspectRatio="none" xlink:href="data:image/png;base64,
|
||||
iVBORw0KGgoAAAANSUhEUgAAACEAAAAfCAYAAABplKSyAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMA
|
||||
AA7DAcdvqGQAAAI9SURBVFhHxZYhUxxBEIVXICIQCEQEAolERiAQCEREBAKBQCAQEQj+AzIyMiIiAhGBQCAQCATixAkEAqoQCERE
|
||||
BAJxvC9sX/UNb2/3iqpNV311M29mumd3evq2Go1G/x0r9o0V+8aKfWPFLsjmiv587s+CFach+yxOxHmhfxfX4qtYyGNtWNEhOxQ0
|
||||
4Lb+XanH5sVfETptNtXp7VjRIfstngUd+CMeBYEfRB5Du3Z+HFZ0yDbqAF1gQwfOj8OKgexjam+LCNIGm7gQ/45DtgDhq8SKIFsX
|
||||
T+KnIB/y6+7KpTgW+DlyccCKIPsl7gXnnR3PAsHJjyuBn4lrPY5lxapaFDjIDh1lMuYxx5aNZ8XJ69gEt+NAcGw7gqeddmSMndp4
|
||||
VqyqTYFTOlzDcJTZKNZ8ECTjQJRzgbG9vGa81omBjCfNjoJhw/wvaU5mas2wYiDbTY4yEyU7zW+qJbNvQkZi7osbkZ0FlOVxDUnr
|
||||
juqxcj5Ju1bOD7z4ej1pnNa/JSQlZ7yU1lDMmhIzbo5/g1Z8zfhw0AQJS1AKUlstuRPMtQXrjRDI+Fs+E9nZe2ATyzaWE0EWtYIz
|
||||
5tq5s24jF7wTFwesCDKSkw8U7j/fC+RAlyoasOk1sSp+iIm6krGio3aYg7Sx6/w4rOiQ8TS5eg5Tu+wz75vz47BiiWxORM3gWCIY
|
||||
tYSbxLGFxvcnSXjrfDms6JCxkS0RmxgU41ELuFUk9WIen4YV25CRbJ8Kjf+N9ax1xYp9Y8W+sWK/jKoXFAS4xJXVHUYAAAAASUVO
|
||||
RK5CYII="/>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
</g>
|
||||
</g>
|
||||
<g id="group1014-91" transform="translate(664.285,-304.853)" v:mID="1014" v:groupContext="group">
|
||||
<title>Sheet.1014</title>
|
||||
<g id="shape8-92" v:mID="8" v:groupContext="shape" transform="translate(3.19744E-14,-0.447576)">
|
||||
<title>Square.8</title>
|
||||
<desc>Housekeeping Manager</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="538.583" width="113.39" height="113.386"/>
|
||||
<rect x="0" y="481.89" width="113.386" height="113.386" class="st9"/>
|
||||
<text x="12.33" y="534.38" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Housekeeping<v:newlineChar/><tspan
|
||||
x="29.11" dy="1.2em" class="st4">Manager</tspan></text> </g>
|
||||
<g id="shape18-96" v:mID="18" v:groupContext="shape" transform="translate(80.3899,0)">
|
||||
<title>Sheet.18</title>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
<image x="0" y="564.279" width="32.9959" height="30.9961" preserveAspectRatio="none" xlink:href="data:image/png;base64,
|
||||
iVBORw0KGgoAAAANSUhEUgAAACEAAAAfCAYAAABplKSyAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMA
|
||||
AA7DAcdvqGQAAAI9SURBVFhHxZYhUxxBEIVXICIQCEQEAolERiAQCEREBAKBQCAQEQj+AzIyMiIiAhGBQCAQCATixAkEAqoQCERE
|
||||
BAJxvC9sX/UNb2/3iqpNV311M29mumd3evq2Go1G/x0r9o0V+8aKfWPFLsjmiv587s+CFach+yxOxHmhfxfX4qtYyGNtWNEhOxQ0
|
||||
4Lb+XanH5sVfETptNtXp7VjRIfstngUd+CMeBYEfRB5Du3Z+HFZ0yDbqAF1gQwfOj8OKgexjam+LCNIGm7gQ/45DtgDhq8SKIFsX
|
||||
T+KnIB/y6+7KpTgW+DlyccCKIPsl7gXnnR3PAsHJjyuBn4lrPY5lxapaFDjIDh1lMuYxx5aNZ8XJ69gEt+NAcGw7gqeddmSMndp4
|
||||
VqyqTYFTOlzDcJTZKNZ8ECTjQJRzgbG9vGa81omBjCfNjoJhw/wvaU5mas2wYiDbTY4yEyU7zW+qJbNvQkZi7osbkZ0FlOVxDUnr
|
||||
juqxcj5Ju1bOD7z4ej1pnNa/JSQlZ7yU1lDMmhIzbo5/g1Z8zfhw0AQJS1AKUlstuRPMtQXrjRDI+Fs+E9nZe2ATyzaWE0EWtYIz
|
||||
5tq5s24jF7wTFwesCDKSkw8U7j/fC+RAlyoasOk1sSp+iIm6krGio3aYg7Sx6/w4rOiQ8TS5eg5Tu+wz75vz47BiiWxORM3gWCIY
|
||||
tYSbxLGFxvcnSXjrfDms6JCxkS0RmxgU41ELuFUk9WIen4YV25CRbJ8Kjf+N9ax1xYp9Y8W+sWK/jKoXFAS4xJXVHUYAAAAASUVO
|
||||
RK5CYII="/>
|
||||
<rect v:rectContext="foreign" x="0" y="564.279" width="32.9959" height="30.9961" class="st10"/>
|
||||
</g>
|
||||
</g>
|
||||
<g id="shape1016-100" v:mID="1016" v:groupContext="shape" v:layerMember="0" transform="translate(185.099,-368.968)">
|
||||
<title>Dynamic connector.1016</title>
|
||||
<path d="M0 602.25 L16.77 602.4" class="st8"/>
|
||||
</g>
|
||||
<g id="shape1017-105" v:mID="1017" v:groupContext="shape" v:layerMember="0" transform="translate(305.406,-354.795)">
|
||||
<title>Dynamic connector.1017</title>
|
||||
<path d="M0 588.3 L16.77 588.16" class="st8"/>
|
||||
</g>
|
||||
<g id="shape1018-110" v:mID="1018" v:groupContext="shape" v:layerMember="0" transform="translate(128.406,-305.301)">
|
||||
<title>Dynamic connector.1018</title>
|
||||
<path d="M0 603.96 L0 604.32 L0 621.46 L86.16 621.46" class="st6"/>
|
||||
</g>
|
||||
<g id="group1019-117" transform="translate(223.609,-244.57)" v:mID="1019" v:groupContext="group">
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:prompt="" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<title>Can.1019</title>
|
||||
<desc>Database</desc>
|
||||
<g id="shape1020-118" v:mID="1020" v:groupContext="shape">
|
||||
<title>Sheet.1020</title>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="ControlHalfHeight" v:prompt="" v:val="VT0(0.11811023622047):24"/>
|
||||
<v:ud v:nameU="FillForegnd" v:prompt="" v:val="VT0(1):26"/>
|
||||
<v:ud v:nameU="ControlHalfHeight" v:prompt="" v:val="VT0(0.095964566929134):1"/>
|
||||
<v:ud v:nameU="FillForegnd" v:prompt="" v:val="VT5(#d80073)"/>
|
||||
</v:userDefs>
|
||||
<path d="M0 588.37 A34.5472 6.90945 -180 0 0 69.09 588.37 L69.09 533.09 L0 533.09 L0 588.37 Z" class="st5"/>
|
||||
</g>
|
||||
<g id="shape1019-120" v:mID="1019" v:groupContext="groupContent">
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="34.5472" cy="560.728" width="69.1" height="69.0945"/>
|
||||
<ellipse cx="34.5472" cy="533.091" rx="34.5472" ry="6.90945" class="st5"/>
|
||||
<text x="5.84" y="564.93" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Database</text> </g>
|
||||
</g>
|
||||
<g id="shape1021-123" v:mID="1021" v:groupContext="shape" transform="translate(293.17,-39.3661)">
|
||||
<title>Parallelogram.1021</title>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:prompt="" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<path d="M0 595.28 L102.05 595.28 L113.39 510.24 L11.34 510.24 L0 595.28 Z" class="st11"/>
|
||||
</g>
|
||||
<g id="shape1022-125" v:mID="1022" v:groupContext="shape" transform="translate(278.531,-50.3858)">
|
||||
<title>Parallelogram.1022</title>
|
||||
<desc>Amphora</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:prompt="" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="552.756" width="113.39" height="85.0394"/>
|
||||
<path d="M0 595.28 L102.05 595.28 L113.39 510.24 L11.34 510.24 L0 595.28 Z" class="st12"/>
|
||||
<text x="27.98" y="556.96" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Amphora</text> </g>
|
||||
<g id="group1054-128" transform="translate(359.038,-138.579)" v:mID="1054" v:groupContext="group">
|
||||
<title>Sheet.1054</title>
|
||||
<g id="shape1050-129" v:mID="1050" v:groupContext="shape" v:layerMember="0" transform="translate(30.8081,-28.3465)">
|
||||
<title>Dynamic connector.1050</title>
|
||||
<path d="M-6.99 603.95 L-7 604.31 L-7.33 623.62" class="st13"/>
|
||||
</g>
|
||||
<g id="shape1051-134" v:mID="1051" v:groupContext="shape" v:layerMember="0" transform="translate(14.1732,-28.3465)">
|
||||
<title>Dynamic connector.1051</title>
|
||||
<path d="M-6.84 595.28 L-7.17 614.58" class="st8"/>
|
||||
</g>
|
||||
</g>
|
||||
<g id="group1064-139" transform="translate(60.1975,-453.543)" v:mID="1064" v:groupContext="group">
|
||||
<title>Sheet.1064</title>
|
||||
<g id="shape1056-140" v:mID="1056" v:groupContext="shape">
|
||||
<title>Rectangle.1056</title>
|
||||
<desc>Neutron</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="68.2087" cy="491.339" width="136.42" height="18.8976"/>
|
||||
<rect x="0" y="481.89" width="136.417" height="113.386" class="st5"/>
|
||||
<text x="42.48" y="495.54" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Neutron</text> </g>
|
||||
<g id="shape1057-143" v:mID="1057" v:groupContext="shape" transform="translate(11.5157,-11.3386)">
|
||||
<title>Rectangle.1057</title>
|
||||
<desc>LBaaS v2 User API Handler</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="56.6929" cy="537.101" width="113.39" height="42.3913"/>
|
||||
<rect x="0" y="515.906" width="113.386" height="79.3701" class="st14"/>
|
||||
<text x="29.5" y="532.9" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>LBaaS v2<v:newlineChar/><tspan
|
||||
x="4.28" dy="1.2em" class="st4">User API Handler</tspan></text> </g>
|
||||
<g id="shape1058-147" v:mID="1058" v:groupContext="shape" transform="translate(20.9587,-17.0079)">
|
||||
<title>Rectangle.1058</title>
|
||||
<desc>Octavia Driver</desc>
|
||||
<v:userDefs>
|
||||
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
|
||||
</v:userDefs>
|
||||
<v:textBlock v:margins="rect(4,4,4,4)" v:tabSpace="42.5197"/>
|
||||
<v:textRect cx="47.25" cy="577.01" width="94.5" height="36.5315"/>
|
||||
<rect x="0" y="558.744" width="94.5" height="36.5315" class="st9"/>
|
||||
<text x="24.2" y="572.81" class="st3" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>Octavia <tspan
|
||||
x="28.77" dy="1.2em" class="st4">Driver</tspan></text> </g>
|
||||
</g>
|
||||
<g id="shape1065-151" v:mID="1065" v:groupContext="shape" v:layerMember="0" transform="translate(121.32,-470.551)">
|
||||
<title>Dynamic connector.1065</title>
|
||||
<path d="M7.09 595.28 L7.09 638.1" class="st8"/>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 25 KiB |
Loading…
x
Reference in New Issue
Block a user