Deployment of containerised OpenStack to bare metal using kolla and bifrost
Go to file
Pierre Riteau c585554988 CI: Fix kayobe-tox-molecule job
When molecule runs, it installs ansible>2.8, which is version 2.10.0
since today. This now also installs the ansible-base package, currently
at version 2.10.1. Then it installs the version of ansible required by
kayobe, i.e. ansible>=2.8.0,<2.10.0 (currently 2.9.13).

We end up with a tox molecule venv containing:

ansible==2.9.13
ansible-base==2.10.1

This causes the following issue:

ERROR! Unexpected Exception, this is probably a bug: cannot import name 'AnsibleCollectionLoader' from 'ansible.utils.collection_loader' (/home/zuul/src/opendev.org/openstack/kayobe/.tox/molecule/lib/python3.8/site-packages/ansible/utils/collection_loader/__init__.py)

This commit adds requirements.txt to the molecule tox deps, which
ensures the correct version of ansible gets installed first.

Change-Id: I7ef890a2ae6fd67f53e1b8bca244a1c0d44fea53
2020-09-23 18:34:23 +02:00
.github Add an issue template. 2017-12-14 20:39:55 +00:00
ansible Merge "Performance: skip LVM configuration if no groups configured" 2020-09-18 13:06:16 +00:00
dev Merge "CI: Update IPA images during upgrade" 2020-06-17 19:08:41 +00:00
doc Merge "Document that kolla_tag may need to be changed when upgrading" 2020-09-18 12:43:29 +00:00
etc/kayobe Merge "Support neutron-mlnx-agent" 2020-09-17 22:25:10 +00:00
kayobe Move dnf.yml earlier in host configure workflow 2020-09-11 19:59:02 +00:00
playbooks Merge "IPA: Switch to IPA builder and CentOS 8" 2020-06-17 19:03:01 +00:00
releasenotes Merge "Support neutron-mlnx-agent" 2020-09-17 22:25:10 +00:00
roles Remove support for CentOS 7 and Python 2 2020-05-28 10:25:51 +01:00
tools Update shebang for Python 3 script 2020-09-16 15:54:13 +02:00
zuul.d Add seed VM provisioning CI job 2020-06-16 17:19:47 +01: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
bindep.txt Update hacking for Python3 2020-09-11 15:44:17 +02:00
CONTRIBUTING.rst [Community goal] Update the contributor guide 2020-06-05 15:58:35 +02: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 Block Ansible 2.9.12 2020-08-13 20:30:30 +00:00
requirements.yml Support setting ethtool options on network interfaces 2020-08-17 16:35:11 +02:00
setup.cfg Add py38 package metadata 2020-07-15 17:32:50 +08:00
setup.py Cleanup py27 support 2020-04-20 18:04:19 +00:00
test-requirements.txt Bump hacking min version to 3.0.1 2020-09-22 15:46:48 +08:00
tox.ini CI: Fix kayobe-tox-molecule job 2020-09-23 18:34:23 +02: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