Spec: Deploy Kolla images using Mesos
Co-Authored-By: Georgy Okrokvertskhov <gokrokvertskhov@mirantis.com> related blueprint mesos Change-Id: I0bc2d9e69819079b8cdaf9a47c5363a3017dced9
This commit is contained in:
parent
e9c47f3d64
commit
c019854a2b
188
specs/mesos-deployment.rst
Normal file
188
specs/mesos-deployment.rst
Normal file
@ -0,0 +1,188 @@
|
||||
==============================
|
||||
Deploy Kolla images with Mesos
|
||||
==============================
|
||||
|
||||
https://blueprints.launchpad.net/kolla/+spec/mesos
|
||||
|
||||
Kolla deploys the containers using Ansible, however this is just one
|
||||
way to deploy the containers. For example TripleO deploys Kolla
|
||||
containers using Heat in-guest agents.
|
||||
|
||||
This specification defines the support for deploying Kolla containers
|
||||
using Mesos and Marathon.
|
||||
|
||||
What is Mesos?
|
||||
From (http://mesos.apache.org/) Mesos "provides efficient resource
|
||||
isolation and sharing across distributed applications, or frameworks".
|
||||
The software enables resource sharing in a fine-grained manner,
|
||||
improving cluster utilization.
|
||||
|
||||
What is Marathon?
|
||||
From (https://mesosphere.github.io/marathon/):
|
||||
"A cluster-wide init and control system for services in cgroups or
|
||||
Docker containers".
|
||||
|
||||
Adding Mesos/Marathon support to Kolla will enable those interested in
|
||||
deploying OpenStack with Mesos to contribute to the Kolla community
|
||||
in a more direct way.
|
||||
|
||||
Problem description
|
||||
===================
|
||||
|
||||
The current deployment (Ansible) is done somewhat serially, meaning
|
||||
that some services depend on others, and the deployment is controlled
|
||||
by the command line (a user). In addition to deployment, Mesos/Marathon
|
||||
provides the following features that will eventually be used:
|
||||
|
||||
- life-cycle management: like service monitoring, restart, scaling
|
||||
and rolling\restarts\upgrades
|
||||
- constraints [1]: the Marathon scheduler will be used to more
|
||||
effectively place containers (esp. during scaling/recovery)
|
||||
- integration with core infrastructure services like DNS, Load
|
||||
Balancing, Service Discovery and Service components.
|
||||
|
||||
In order to reuse a large amount of functionality, it would be best
|
||||
to use an existing framework that provides a proven stable and
|
||||
mature solution.
|
||||
Given that Mesos/Marathon is used and tested at scale by many large
|
||||
companies, it will give operators the confidence to adopt
|
||||
OpenStack to meet any scaling requirements they need.
|
||||
|
||||
Marathon [2] will be used to manage the containers. Marathon is a
|
||||
framework that runs on top of Mesos and it is for long running
|
||||
services.
|
||||
|
||||
Part of this change is to start all the containers at the same time
|
||||
(in parallel) so that there are as few dependencies from the
|
||||
deployment tool’s point of view. This should enable a couple of things:
|
||||
- faster initial deployment
|
||||
- reduce unnecessary restarts during upgrades
|
||||
- make each container more self sufficient
|
||||
|
||||
Proposed change
|
||||
===============
|
||||
|
||||
- Add a deployment specific git repo (kolla-mesos) to contain the
|
||||
Mesos/Marathon specific deployment code and boot strapping.
|
||||
- Enhance Kolla container API (config.json) to permit loading
|
||||
of custom startup script while maintaining immutability with copy_once.
|
||||
- Implement an all in one (AIO) basic OpenStack
|
||||
- Implement a separate controller/compute setup similar to the Ansible one.
|
||||
- Throughout add docs to assist users and contributors/reviewers.
|
||||
|
||||
Bootstrapping:
|
||||
--------------
|
||||
|
||||
At first, Mesos/Marathon/Zookeeper bootstrapping will be done by
|
||||
setting up docker container. Later, bootstrapping will be handled by Ironic/PXE
|
||||
(the aim is to be practical and do what is easiest for the AIO).
|
||||
|
||||
Dependancy management
|
||||
---------------------
|
||||
|
||||
Instead of the serialising the dependant steps, each container is
|
||||
started and only actually starts the service if the requirements are
|
||||
fulfilled.
|
||||
|
||||
These dependencies will come in the form of:
|
||||
|
||||
- service discovery (service X needs service Y running)
|
||||
Note: that Marathon DNS and LB can be self-configured based on service
|
||||
registry information.
|
||||
To achieve this the container also needs to register itself once
|
||||
it has started.
|
||||
- checking to see if service configuration is complete
|
||||
(has keystone got the service user that is required, is the DB
|
||||
schema complete, etc..)
|
||||
Use Zookeeper to watch for these configuration steps.
|
||||
|
||||
One time tasks
|
||||
--------------
|
||||
Ansible runs a number of scripts to setup the database, keystone etc.
|
||||
These can be run as a Mesos Executor (command line run in the
|
||||
container of choice).
|
||||
|
||||
Security impact
|
||||
---------------
|
||||
|
||||
Mesos and Marathon are mature products used by various companies in
|
||||
production. The central configuration storage will require careful
|
||||
security risk assessment. The deployed OpenStack’s security should not
|
||||
be affected by the deployment tool.
|
||||
|
||||
Performance Impact
|
||||
------------------
|
||||
|
||||
Given that the Mesos slaves are distributed and all containers will be
|
||||
started in parallel, the deployment *may* be faster, though this is
|
||||
not the main focus.
|
||||
|
||||
Alternatives
|
||||
------------
|
||||
|
||||
Kubernetes was evaluated by the Kolla team 6 months ago and found to
|
||||
not work at that time as it did not support net=host and pid=host
|
||||
features of docker. Since then it has developed these features, if
|
||||
Mesos/Marathon fails to produce results, then going back to kubernetes
|
||||
is an option. However at the time of writing this Mesos/Marathon was
|
||||
deemed to be more mature and stable.
|
||||
|
||||
Implementation
|
||||
==============
|
||||
|
||||
Primary Assignee(s)
|
||||
-----------
|
||||
Angus Salkeld (asalkeld)
|
||||
Kirill Proskurin (kproskurin)
|
||||
Michal Rostecki (nihilifer)
|
||||
|
||||
Other contributor(s):
|
||||
Harm Weites (harmw)
|
||||
Jeff Peeler (jpeeler)
|
||||
Michal Jastrzebski (inc0)
|
||||
Sam Yaple (SamYaple)
|
||||
Steven Dake (sdake)
|
||||
<Please add your name here if you are getting involved in kolla-mesos>
|
||||
|
||||
Milestones
|
||||
----------
|
||||
|
||||
Target Milestone for completion:
|
||||
mitaka
|
||||
|
||||
Work Items
|
||||
----------
|
||||
1. Allow a custom startup script to run (change in Kolla)
|
||||
2. Add startup scripts to kolla-mesos to read config from zookeeper
|
||||
instead of bindmounted directory. Propose oslo.config changes to
|
||||
use this method (oslo work done in parallel, initially this will be
|
||||
done in the startup script).
|
||||
3. Add startup scripts for service discovery so that services only
|
||||
start once their needs are fulfilled.
|
||||
a. register a service once a service is running
|
||||
b. wait for dependent services if they are needed before starting
|
||||
a service.
|
||||
c. DNS and LB self-configuration based on service registry information
|
||||
5. Add bootstrapping code to install Marathon, Zookeeper,
|
||||
Mesos master and slave.
|
||||
6. Add calls to to marathon to deploy containers.
|
||||
7. Add support for kolla-mesos to kolla-cli.
|
||||
|
||||
Testing
|
||||
=======
|
||||
|
||||
Functional tests will be implemented in the OpenStack check/gating system to
|
||||
automatically check that the Mesos/Marathon deployment works for an AIO environment.
|
||||
|
||||
Documentation Impact
|
||||
====================
|
||||
A quick start guide will be written to explain how to deploy.
|
||||
A develop guide will be written on how to contribute and how the deployment works.
|
||||
|
||||
References
|
||||
==========
|
||||
|
||||
- [1] https://mesosphere.github.io/marathon/docs/constraints.html
|
||||
- [2] https://mesosphere.github.io/marathon/
|
||||
- http://radar.oreilly.com/2015/10/swarm-v-fleet-v-kubernetes-v-mesos.html
|
||||
- https://www.wehkamplabs.com/blog/2015/10/15/applying-consul-within-the-blaze-microservices-platform/
|
Loading…
Reference in New Issue
Block a user