The designation of byo
is no longer applicable due to being able to deploy on
physical hardware or cloud resources using the playbooks in the byo
directory.
Consolidation of these directories will make maintaining the code base easier
and provide a more straightforward project for users and developers.
The main points of this proposal are:
playbooks/init
.playbooks/byo
and playbooks/common
into one set of
directories at playbooks/openshift-*
.This consolidation effort may be more appropriate when the project moves to using a container as the default installation method.
Currently there are two separate sets of initialization playbooks:
playbooks/byo/openshift-cluster/initialize_groups.yml
playbooks/common/openshift-cluster/std_include.yml
Although these playbooks are located in the openshift-cluster
directory they
are shared by all of the openshift-*
areas. These playbooks would be better
organized in a playbooks/init
directory collocated with all their related
playbooks.
In the example below, the following changes have been made:
playbooks/byo/openshift-cluster/initialize_groups.yml
renamed to
playbooks/init/initialize_host_groups.yml
playbooks/common/openshift-cluster/std_include.yml
renamed to
playbooks/init/main.yml
- include: playbooks/init/initialize_host_groups.yml
has been added to the
top of playbooks/init/main.yml
playbooks/init
The initialize_host_groups.yml
playbook is only one play with one task for
importing variables for inventory group conversions. This task could be further
consolidated with the play in evaluate_groups.yml
.
The new standard initialization playbook would be
playbooks/init/main.yml
.
> $ tree openshift-ansible/playbooks/init
.
├── evaluate_groups.yml
├── initialize_facts.yml
├── initialize_host_groups.yml
├── initialize_openshift_repos.yml
├── initialize_openshift_version.yml
├── main.yml
├── roles -> ../../roles
├── validate_hostnames.yml
└── vars
└── cluster_hosts.yml
# openshift-ansible/playbooks/init/main.yml
---
- include: initialize_host_groups.yml
- include: evaluate_groups.yml
- include: initialize_facts.yml
- include: validate_hostnames.yml
- include: initialize_openshift_repos.yml
- include: initialize_openshift_version.yml
byo
and common
Playbook ConsolidationHistorically, the byo
directory coexisted with other platform directories
which contained playbooks that then called into common
playbooks to perform
common installation steps for all platforms. Since the other platform
directories have been removed this separation is no longer necessary.
In the example below, the following changes have been made:
playbooks/byo/openshift-master
renamed to
playbooks/openshift-master
playbooks/common/openshift-master
renamed to
playbooks/openshift-master/private
byo
entry point playbooks have been updated to include their
respective playbooks from private/
.All user consumable playbooks are in the root of openshift-master
and no entry
point playbooks exist in the private
directory. Maintaining the separation
between entry point playbooks and the private playbooks allows individual pieces
of the deployments to be used as needed by other components.
openshift-ansible/playbooks/openshift-master
> $ tree
.
├── config.yml
├── private
│ ├── additional_config.yml
│ ├── config.yml
│ ├── filter_plugins -> ../../../filter_plugins
│ ├── library -> ../../../library
│ ├── lookup_plugins -> ../../../lookup_plugins
│ ├── restart_hosts.yml
│ ├── restart_services.yml
│ ├── restart.yml
│ ├── roles -> ../../../roles
│ ├── scaleup.yml
│ └── validate_restart.yml
├── restart.yml
└── scaleup.yml
# openshift-ansible/playbooks/openshift-master/config.yml
---
- include: ../init/main.yml
- include: private/config.yml
With the consolidation of the directory structure and component installs being
removed from openshift-cluster
, that directory is no longer necessary. To
deploy an entire OpenShift cluster, a playbook would be created to tie together
all of the different components. The following example shows how multiple
components would be combined to perform a complete install.
# openshift-ansible/playbooks/deploy_cluster.yml
---
- include: init/main.yml
- include: openshift-etcd/private/config.yml
- include: openshift-nfs/private/config.yml
- include: openshift-loadbalancer/private/config.yml
- include: openshift-master/private/config.yml
- include: openshift-node/private/config.yml
- include: openshift-glusterfs/private/config.yml
- include: openshift-hosted/private/config.yml
- include: openshift-service-catalog/private/config.yml
As a developer of OpenShift-Ansible, I want simplify the playbook directory structure so that users can easily find deployment playbooks and developers know where new features should be developed.
Given the size of this refactoring effort, it should be broken into smaller steps which can be completed independently while still maintaining a functional project.
Steps:
openshift-*
component areaopenshift-cluster