summaryrefslogtreecommitdiffstats
path: root/docs/ands_ansible.txt
diff options
context:
space:
mode:
authorSuren A. Chilingaryan <csa@suren.me>2017-04-02 08:05:51 +0200
committerSuren A. Chilingaryan <csa@suren.me>2017-04-02 08:05:51 +0200
commit035ab0212eede4c7ab894fa78b14da0fa6056ef4 (patch)
tree32e7d8c35b830b89bdb708013a67f343c71c5e57 /docs/ands_ansible.txt
parent1744778d4ffb5183020a5196c7ea020b18e1436a (diff)
downloadands-035ab0212eede4c7ab894fa78b14da0fa6056ef4.tar.gz
ands-035ab0212eede4c7ab894fa78b14da0fa6056ef4.tar.bz2
ands-035ab0212eede4c7ab894fa78b14da0fa6056ef4.tar.xz
ands-035ab0212eede4c7ab894fa78b14da0fa6056ef4.zip
Support pod variants, i.e. one of the specified pods will be actually configured depending on the inventory/group parameters
Diffstat (limited to 'docs/ands_ansible.txt')
-rw-r--r--docs/ands_ansible.txt120
1 files changed, 120 insertions, 0 deletions
diff --git a/docs/ands_ansible.txt b/docs/ands_ansible.txt
new file mode 100644
index 0000000..80a7cf0
--- /dev/null
+++ b/docs/ands_ansible.txt
@@ -0,0 +1,120 @@
+Ands (Advanced aNalysis and Data Services)
+
+Ansible groups
+==============
+ - OpenShift
+ nodes [enforced] All OpenShift Nodes
+ storage_nodes All OpenShift Nodes with attached storage
+ masters [enforced] All OpenShift Nodes with attached storage and acting as masters
+
+ Additional building blocks:
+ simple_nodes OpenShift Node (without Storage)
+ simple_storage_nodes OpenShift Node with Storage atached, but not acting as Master
+
+ - oVirt
+ ? ovirt_servers All oVirt servers
+ ? ovirt_masters All oVirt masters
+
+ - General
+ ands_servers All server hardware running in the server rooms
+ ands_storage_servers All servers with storage attached (OpenShift storage, oVirt storage, PDV storage)
+ ands_cuda_servers All servers with NVIDIA hardware
+ ands_opencl_servers All servers expected to run OpenCL SDK
+ ands_desktops Destkop computers outside of the server room
+ ands Everything
+
+Ansible roles
+=============
+ - Preparation of Vagrant nodes
+ ands_vagrant_vm vagrant Configures Vagrantfile and starts virtual machines if necessary
+
+ - Ands-specific
+ ands_facts ands Detect current Ands configuration
+ ands_storage ands_storage_servers Detects large storage device and configures LVM, sets aside space for Heketi if ands_heketi_* is set
+
+ - General (abstract roles)
+ common ands Standard repositories & software
+ keepalived masters Keepalived Service
+ openvpn nodes Configures required tunnels (contains templates for all planned tunnels)
+ docker nodes Installs docker and configures LVM-based docker storage backend
+ glusterfs servers Installs glusterfs, provisions requested volumes, and mounts them
+
+ - OpenShift
+ openshift_resource include Populates OpenShift resources (should be executed on master nodes)
+ ands_openshift nodes Configures /etc/hosts (to be independent of DNS), user accounts, GlusterFS endpoints in all projects, Heketi service if needed
+ ands_kaas masters For all projects configure Gluster volumes, populates OpenShift resources and configuration user configuration
+
+ - Katrin-specific
+ kaas
+
+Ansible parameters (global)
+==================
+ We are listing here only variables which have the global scope, i.e. affect multiple roles. The role parameters are documented
+ within the role itself. General (non ands_*) roles should not rely on ands_* variables directly (except in 'defaults').
+ => Instead the playbooks are used to set role-specific parameters based on ands_* variables.
+
+ - Domains
+ ands_openshift_subdomain group_vars The default subdomain of the OpenShift cluster (kaas.kit.edu)
+ ands_cluster_domain group_vars The default domain name of all cluster servers (.ipe.kit.edu)
+
+ - High Availability
+ ands_openshift_lb group_vars The FQDN of load-balancer of the OpenShift cluster (katrin.kit.edu)
+ ands_ipfailover_interface group_vars Interface to run IPFailover service
+ ands_ipfailover_vips group_vars Virtual IPs to maintain by IPFailover service
+
+ - Networks
+ ands_storage_network group_vars CIDR of storage network
+ ands_openshift_network group_vars CIDR of OpenShift network (normally, we use storage network)
+ ands_openshift_public_network group_vars CIDR of OpenShift public network (normally, we use infrastructure network)
+ ands_openshift_ingress_network group_vars CIDR of OpenShift ingress network
+
+ - Host names / IPs
+ ands_host_id inventory ID is equivalent to the IP in the infrastructure network
+ ands_storage_hostname computed IP or hostname of the host in the Infiniband storage network
+ ands_hpc_hostname computed IP or hostname of the host in the Infiniband HPC network
+
+ - Storage
+ ands_data_device ands_storage The raid device where Ands LVM will be populated. Normally will be autodetected based on size.
+ ands_data_vg ands_storage The LVM VG on the main storage device
+ ands_data_path ands_storage The path where the large storage is mounted
+ ands_data_volume_size group_vars If not specified, all disks space will be imideately used. Oherwise, it is possible to keep it for other uses and grow as needed.
+ ands_heketi_volume_size group_vars If specified, some space will set aside on LVM some space for Heketi volume
+ ands_storage_domains ands_storage List of GlusterFS volumens and mount points (configured in ands_facts and may add additional heketi domain in ands_storage)
+
+ - Docker specific
+ docker_storage_device ands_storage Storage device to create Docker LVM on (if not existing yet)
+ docker_storage_vg ands_storage LVM VG for Docker volumes (autodetected if not specified)
+
+ - GlusterFS specific
+ glusterfs_version group_vars
+ glusterfs_transport group_vars
+
+ - OPenShift specific
+ ands_openshift_labels setup/configs Labels to assign to the nodes
+ ands_openshift_projects setup/configs List of projects to configure (with GlusterFS endpoints, etc.)
+ ands_openshift_users setup/configs Optional list of user names with contacts
+ ands_openshift_roles setup/configs User-permissions. Configures list of admins, project users, etc.
+ ands_secrets setup/configs Passwords, etc.
+
+ ands_paths setup/configs Default mount point paths
+ ands_storage_domains setup/configs List of GlusterFS volumes along with hosting servers
+ ands_openshift_volumes setup/configs List of OpenShift volumes linked to GlusterFS volumes and paths. Used to generate PV/PVC. Can be restricted per project.
+ ands_openshift_files setup/configs List of directories/files on the GlusterFS we want to create, ensure permissions/owners.
+
+ kaas_glusterfs_endpoints <hard-corded> Specifies the name of GlusterFS endpoint, should be configured by the ands_openshift service (but currently hardcorded)
+
+ - Project specific
+ volumes project Overrides list of PV/PVC to populate in the project
+ files project Additional files to ensure are existing and have correct permissions
+ file_owner project Default user owning files
+ file_group project Default group owning files
+ pods project Configuration of the expected pods
+ oc project If necessary may give detailed instructions in which prioritu resources should be populated
+
+ - KATRIN specific
+ katrin_node group_vars FQDN of KaaS router (katrin.kit.edu, but now katrin.ipe.kit.edu or something)
+ katrin_openvpn_network group_vars OpenVPN network encompassing all subnets to Katrin control network
+ katrin_openvpn_subnet_bits group_vars Subnet size
+ katrin_openvpn_subnet_offset group_vars Offset of a first subnet (according to the specified size)
+
+