Deployment of containerised OpenStack to bare metal using kolla and bifrost
Go to file
Mark Goddard 49c3e1dab4 Python 3: fix Ansible Vault password helper
In Python 3, the return type of subprocess.check_output is bytes by
default. It needs to be decoded to a string.

Passing universal_newlines=True to the subprocess functions results in
file objects opened in text mode, decoded using the system locale. A
unit test has also been added.

Change-Id: Idb4e66aa1f2c973a956907d7986d1c05c7ce2e67
Story: 2004959
Task: 39483
2020-05-28 10:57:00 +01:00
.github Add an issue template. 2017-12-14 20:39:55 +00:00
ansible Merge "Add support for encrypted block devices" 2020-05-21 11:13:10 +00:00
dev Merge "CI: Add overcloud host configure job" 2020-04-24 00:03:24 +00:00
doc Merge "Add ability to run playbooks before and after a kayobe command" 2020-05-27 17:19:53 +00:00
etc/kayobe Merge "Add ability to run playbooks before and after a kayobe command" 2020-05-27 17:19:53 +00:00
kayobe Python 3: fix Ansible Vault password helper 2020-05-28 10:57:00 +01:00
playbooks Add support for encrypted block devices 2020-05-20 15:49:51 +00:00
releasenotes Merge "Add ability to run playbooks before and after a kayobe command" 2020-05-27 17:19:53 +00:00
roles Stop gzipping logs in get-logs.sh 2020-02-11 13:04:37 +00:00
tools Use unittest.mock instead of PyPI mock 2020-04-03 10:22:39 +01:00
zuul.d Merge "CI: Add overcloud host configure job" 2020-04-24 00:03:24 +00:00
.coveragerc Use stestr for running unit tests, add a coverage environment 2018-03-08 16:37:08 +00:00
.gitignore Add 'venvs' to list of things which we don't want git to track 2018-07-02 14:17:18 +01:00
.gitreview Fix after x/kayobe rename 2019-09-16 16:26:27 +02:00
.stestr.conf Use stestr for running unit tests, add a coverage environment 2018-03-08 16:37:08 +00:00
.yamllint Run yamllint on etc/kayobe during pep8 tox env 2019-02-14 12:17:19 +00:00
CONTRIBUTING.rst Sync Sphinx requirement 2019-06-25 02:24:45 +00:00
HACKING.rst Sync Sphinx requirement 2019-06-25 02:24:45 +00:00
LICENSE License kayobe project under Apache2 2017-04-06 10:15:29 +01:00
README.rst Update docs after repo rename x/ to openstack/ 2019-09-16 17:39:29 +01:00
requirements.txt Fix multiple CI failures 2020-05-12 19:04:43 +02:00
requirements.yml Merge "Add support for encrypted block devices" 2020-05-21 11:13:10 +00:00
setup.cfg Add ability to run playbooks before and after a kayobe command 2020-05-26 14:16:02 +01:00
setup.py Cleanup py27 support 2020-04-20 18:04:19 +00:00
test-requirements.txt Remove sphinx from test-requirements.txt 2019-10-21 11:10:13 +02:00
tox.ini Cleanup py27 support 2020-04-20 18:04:19 +00:00
Vagrantfile Upgrade Vagrant VM to CentOS 8 2020-05-19 10:08:36 +01:00

Kayobe

Kayobe enables deployment of containerised OpenStack to bare metal.

Containers offer a compelling solution for isolating OpenStack services, but running the control plane on an orchestrator such as Kubernetes or Docker Swarm adds significant complexity and operational overheads.

The hosts in an OpenStack control plane must somehow be provisioned, but deploying a secondary OpenStack cloud to do this seems like overkill.

Kayobe stands on the shoulders of giants:

  • OpenStack bifrost discovers and provisions the cloud
  • OpenStack kolla builds container images for OpenStack services
  • OpenStack kolla-ansible delivers painless deployment and upgrade of containerised OpenStack services

To this solid base, kayobe adds:

  • Configuration of cloud host OS & flexible networking
  • Management of physical network devices
  • A friendly openstack-like CLI

All this and more, automated from top to bottom using Ansible.

Features

  • Heavily automated using Ansible
  • kayobe Command Line Interface (CLI) for cloud operators
  • Deployment of a seed VM used to manage the OpenStack control plane
  • Configuration of physical network infrastructure
  • Discovery, introspection and provisioning of control plane hardware using OpenStack bifrost
  • Deployment of an OpenStack control plane using OpenStack kolla-ansible
  • Discovery, introspection and provisioning of bare metal compute hosts using OpenStack ironic and ironic inspector
  • Virtualised compute using OpenStack nova
  • Containerised workloads on bare metal using OpenStack magnum
  • Big data on bare metal using OpenStack sahara
  • Control plane and workload monitoring and log aggregation using OpenStack monasca