From 645e3a2b691754644f2619a54a631b7f9a024716 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 3 Jan 2024 14:50:47 +0000 Subject: [PATCH 001/102] Additions to enable Azimuth appliance support. --- multinode-app.yml | 15 ++++ roles/cluster-infra/tasks/main.yml | 47 ++++++++++ ui-meta/multinode-appliance.yml | 133 +++++++++++++++++++++++++++++ 3 files changed, 195 insertions(+) create mode 100644 multinode-app.yml create mode 100644 roles/cluster-infra/tasks/main.yml create mode 100644 ui-meta/multinode-appliance.yml diff --git a/multinode-app.yml b/multinode-app.yml new file mode 100644 index 0000000..60d77a5 --- /dev/null +++ b/multinode-app.yml @@ -0,0 +1,15 @@ +--- + +# Provision the infrastructure +# The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group +- hosts: openstack + roles: + - cluster_infra + +# Write the outputs as the final task +- hosts: localhost + tasks: + - debug: var=outputs + vars: + outputs: + cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" \ No newline at end of file diff --git a/roles/cluster-infra/tasks/main.yml b/roles/cluster-infra/tasks/main.yml new file mode 100644 index 0000000..5733038 --- /dev/null +++ b/roles/cluster-infra/tasks/main.yml @@ -0,0 +1,47 @@ +--- + +- name: Install Terraform binary + include_role: + name: stackhpc.terraform.install + +- name: Make Terraform project directory + file: + path: "{{ terraform_project_path }}" + state: directory + +- name: Write backend configuration + copy: + content: | + terraform { + backend "{{ terraform_backend_type }}" { } + } + dest: "{{ terraform_project_path }}/backend.tf" + +# Patching in this appliance is implemented as a switch to a new base image +# So unless explicitly patching, we want to use the same image as last time +# To do this, we query the previous Terraform state before updating +- block: + - name: Get previous Terraform state + stackhpc.terraform.terraform_output: + binary_path: "{{ terraform_binary_path }}" + project_path: "{{ terraform_project_path }}" + backend_config: "{{ terraform_backend_config }}" + register: cluster_infra_terraform_output + + - name: Extract image from Terraform state + set_fact: + cluster_previous_image: "{{ cluster_infra_terraform_output.outputs.cluster_image.value }}" + when: '"cluster_image" in cluster_infra_terraform_output.outputs' + when: + - terraform_state == "present" + - cluster_upgrade_system_packages is not defined or not cluster_upgrade_system_packages + +- name: Copy Terraform files into project directory + ansible.builtin.copy: + src: "{{ item }}.j2" + dest: "{{ terraform_project_path }}/{{ item }}" + loop: "{{ query('fileglob', '../../../*.tf') }}" + +- name: Provision infrastructure + include_role: + name: stackhpc.terraform.infra \ No newline at end of file diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml new file mode 100644 index 0000000..ade8319 --- /dev/null +++ b/ui-meta/multinode-appliance.yml @@ -0,0 +1,133 @@ +# The machine-readable name of the appliance +name: "multinode" +# The human-readable label for the appliance +label: "Multinode Deployment" +# A short description of the appliance, rendered as-is +description: An appliance for deploying a multinode cluster on Azimuth. +# The URL of the logo for the appliance +# This should be an HTTPS URL, because plain HTTP URLs will cause content warnings when Azimuth is served over HTTPS +# Alternatively, as shown here, a data URL can be used to encode the image directly +logo:  + + +# A list of parameters to be gathered from the user +parameters: + # The name of the Ansible variable that will be populated with the parameter value. + # This field is required. + - name: vxlan_vni + # A human-readable name for the parameter. Defaults to the name if not given. + label: Set the VXLAN VNI value. + # An optional short description for the parameter. + description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + # The kind of the parameter. This field is required. + # Valid values are: + #  list + # A list of items. + # string + #  A string or something that can be coerced. + #  integer + #  An integer or a string that can be coerced. + #  number + #  Any number, i.e. an integer or a float, or a string that can be coerced. + #  boolean + # A boolean flag. + #  Valid values are: true/false, 1/0, "1"/"0", "true"/"false" and "yes"/"no". + #  choice + # A value from a set of choices. + #  cloud.size + # The ID of a size in the target tenancy. + #  cloud.machine + #  The ID of a machine in the target tenancy. + # cloud.ip + #  The ID of an external IP in the target tenancy. + #  cloud.volume + #  The ID of a volume in the target tenancy. + #  cloud.cluster + #  The ID of another cluster in the target tenancy. + kind: "integer" + # Indicates whether the parameter is required. Defaults to true if not given. + required: true + # The default value value for the parameter. Defaults to null if not given, indicating no default. + default: null + # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. + # Defaults to false if not given. + immutable: true + # Additional options for the parameter. The valid options depend on the kind of the parameter. + # list + # min_length: An optional minimum length for the list. + #  max_length: An optional maximum length for the list. + # item: An optional item validator, consisting of a kind and some options. + # string + # min_length: An optional minimum length for the string. + # max_length: An optional maximum length for the string. + #  pattern: An optional regular expression pattern to validate the string against. + #  integer + #  number + options: + min: 1 + max: 100000 + #  boolean + # permanent: If true, indicates that the parameter cannot become false again once it has + #  been set to true. Defaults to false if not given. + #  choice + #  choices: The list of valid choices for the parameter. This field is required. + #  cloud.size + #  min_cpus: An optional minimum number of CPUs that the size must have. + #  min_ram: An optional minimum amount of RAM in MB that the size must have. + # min_disk: An optional minimum root disk size in GB that the size must have. + #  cloud.volume + #  min_size: An optional minimum size in GB for the volume. + #  cloud.cluster + # tag: An optional tag that the cluster must have. + # options: + # min_ram: 1024 + # min_disk: 10 + + #- name: backend_count + # label: Backend node count + # description: The number of backend nodes. + # kind: integer + # options: + # min: 1 + # default: 3 + + #- name: backend_flavor + # label: Backend node size + # description: The size to use for the backend nodes. + # kind: "cloud.size" + # immutable: true + # options: + # min_ram: 1024 + # min_disk: 10 + +# A template describing the usage of the appliance +# This is rendered in the "Cluster details" modal in the Azimuth UI +usage_template: |- + This sample appliance demonstrates how to build an appliance for use with the + [Azimuth](https://github.com/stackhpc/azimuth) Cluster-as-a-Service (CaaS) system. + + This content is defined in the `usage_template` field of the cluster metadata for the appliance. + It is generated by first rendering the `usage_template` using + [nunjucks](https://mozilla.github.io/nunjucks/) - a client-side templating engine with a similar + syntax to [Jinja2](https://jinja.palletsprojects.com/). The output from rendering the template + is treated as [Markdown](https://en.wikipedia.org/wiki/Markdown), which is used to produce the + HTML that is shown to the user. + + When the template is rendered, the cluster API object available as the variable `cluster`. + This means that the template is able to access the cluster parameter values and outputs in + order to use them during rendering. + + Markdown also allow the template to use + + * all sorts of + * *rich* ***formatting*** **options** + + # Accessing the cluster + + We can use the cluster outputs to render a link to the service using the allocated external IP: + + {% if cluster.outputs.cluster_access_ip %} + Web service available at [{{ cluster.outputs.cluster_access_ip }}](http://{{ cluster.outputs.cluster_access_ip }}). + {% else %} + Web service is not ready yet. + {% endif %} \ No newline at end of file From 5b8bd80a5ceddc521054fd1375cd227517e0ce2c Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 3 Jan 2024 15:36:47 +0000 Subject: [PATCH 002/102] Small typo amendment. --- roles/cluster-infra/tasks/main.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/roles/cluster-infra/tasks/main.yml b/roles/cluster-infra/tasks/main.yml index 5733038..485f0a4 100644 --- a/roles/cluster-infra/tasks/main.yml +++ b/roles/cluster-infra/tasks/main.yml @@ -38,7 +38,7 @@ - name: Copy Terraform files into project directory ansible.builtin.copy: - src: "{{ item }}.j2" + src: "{{ item }}" dest: "{{ terraform_project_path }}/{{ item }}" loop: "{{ query('fileglob', '../../../*.tf') }}" From 18e5d2856e8ef493e0bd3bde862becd4e62e6573 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 09:59:47 +0000 Subject: [PATCH 003/102] Updated usage template for multinode appliance. --- ui-meta/multinode-appliance.yml | 36 ++++++++------------------------- 1 file changed, 8 insertions(+), 28 deletions(-) diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml index ade8319..53c0601 100644 --- a/ui-meta/multinode-appliance.yml +++ b/ui-meta/multinode-appliance.yml @@ -103,31 +103,11 @@ parameters: # A template describing the usage of the appliance # This is rendered in the "Cluster details" modal in the Azimuth UI usage_template: |- - This sample appliance demonstrates how to build an appliance for use with the - [Azimuth](https://github.com/stackhpc/azimuth) Cluster-as-a-Service (CaaS) system. - - This content is defined in the `usage_template` field of the cluster metadata for the appliance. - It is generated by first rendering the `usage_template` using - [nunjucks](https://mozilla.github.io/nunjucks/) - a client-side templating engine with a similar - syntax to [Jinja2](https://jinja.palletsprojects.com/). The output from rendering the template - is treated as [Markdown](https://en.wikipedia.org/wiki/Markdown), which is used to produce the - HTML that is shown to the user. - - When the template is rendered, the cluster API object available as the variable `cluster`. - This means that the template is able to access the cluster parameter values and outputs in - order to use them during rendering. - - Markdown also allow the template to use - - * all sorts of - * *rich* ***formatting*** **options** - - # Accessing the cluster - - We can use the cluster outputs to render a link to the service using the allocated external IP: - - {% if cluster.outputs.cluster_access_ip %} - Web service available at [{{ cluster.outputs.cluster_access_ip }}](http://{{ cluster.outputs.cluster_access_ip }}). - {% else %} - Web service is not ready yet. - {% endif %} \ No newline at end of file + This is a Multinode appliance which deploys a cluster of nodes including: + * Root node + * Log node + * Audit node + * Home node + * **tmp** node + * **var** node + * **var_tmp** node \ No newline at end of file From 7bb2cd907015d74ceebb9a98b1936e4ea45d8d9d Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 10:17:36 +0000 Subject: [PATCH 004/102] Added 'roles' path to ansible.cfg. --- ansible/ansible.cfg | 1 + 1 file changed, 1 insertion(+) diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 35367c1..39be919 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -5,6 +5,7 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False +roles_path = ../roles [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file From e97a5bdaee0f322f4a9b7aaac837436aa45787b1 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 10:45:00 +0000 Subject: [PATCH 005/102] Moved ansible.cfg to repo root directory. --- ansible.cfg | 11 +++++++++++ 1 file changed, 11 insertions(+) create mode 100644 ansible.cfg diff --git a/ansible.cfg b/ansible.cfg new file mode 100644 index 0000000..39be919 --- /dev/null +++ b/ansible.cfg @@ -0,0 +1,11 @@ +[defaults] +stdout_callback = yaml +callbacks_enabled = timer, profile_tasks, profile_roles +host_key_checking = False +pipelining = True +forks = 30 +deprecation_warnings=False +roles_path = ../roles + +[ssh_connection] +ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file From d4f9786713d40c1a318c79d5ec874e6b7482fc61 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 11:09:04 +0000 Subject: [PATCH 006/102] Added a requirements yaml file to repo root. --- requirements.yml | 4 ++++ 1 file changed, 4 insertions(+) create mode 100644 requirements.yml diff --git a/requirements.yml b/requirements.yml new file mode 100644 index 0000000..981aa68 --- /dev/null +++ b/requirements.yml @@ -0,0 +1,4 @@ +collections: + - name: https://github.com/stackhpc/ansible-collection-terraform + type: git + version: 71c998a0fd274519d37df5202af5b9f53eca1482 \ No newline at end of file From 0fec8b36b9c44d9fef79ee2013ac0811b265b4c0 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 11:19:44 +0000 Subject: [PATCH 007/102] Roles directory typo fix in config. --- ansible.cfg | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ansible.cfg b/ansible.cfg index 39be919..560f2b6 100644 --- a/ansible.cfg +++ b/ansible.cfg @@ -5,7 +5,7 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False -roles_path = ../roles +roles_path = roles [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file From 644d46fe5db215fadaeb52b2db937b14b18fa6ef Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 12:08:14 +0000 Subject: [PATCH 008/102] Changed ansible collection version. --- requirements.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.yml b/requirements.yml index 981aa68..fb396fb 100644 --- a/requirements.yml +++ b/requirements.yml @@ -1,4 +1,4 @@ collections: - name: https://github.com/stackhpc/ansible-collection-terraform type: git - version: 71c998a0fd274519d37df5202af5b9f53eca1482 \ No newline at end of file + version: 8c7acce4538aab8c0e928972155a2ccb5cb1b2a1 \ No newline at end of file From 93a2a2fac6d099c025dee8203338c2b4fa55a518 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 12:10:03 +0000 Subject: [PATCH 009/102] Added symlink of requirements. --- roles/requirements.yml | 1 + 1 file changed, 1 insertion(+) create mode 100644 roles/requirements.yml diff --git a/roles/requirements.yml b/roles/requirements.yml new file mode 100644 index 0000000..6e76d52 --- /dev/null +++ b/roles/requirements.yml @@ -0,0 +1 @@ +../requirements.yml \ No newline at end of file From b15ebf1e402b39877b71770f8ecd065447f35df6 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 12:13:59 +0000 Subject: [PATCH 010/102] Deleted link to create one after. --- roles/requirements.yml | 1 - 1 file changed, 1 deletion(-) delete mode 100644 roles/requirements.yml diff --git a/roles/requirements.yml b/roles/requirements.yml deleted file mode 100644 index 6e76d52..0000000 --- a/roles/requirements.yml +++ /dev/null @@ -1 +0,0 @@ -../requirements.yml \ No newline at end of file From 09218544b390a8d721cbe1716879e42a3b235f0a Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 4 Jan 2024 12:14:25 +0000 Subject: [PATCH 011/102] Symlink added. --- roles/requirements.yml | 1 + 1 file changed, 1 insertion(+) create mode 120000 roles/requirements.yml diff --git a/roles/requirements.yml b/roles/requirements.yml new file mode 120000 index 0000000..6e76d52 --- /dev/null +++ b/roles/requirements.yml @@ -0,0 +1 @@ +../requirements.yml \ No newline at end of file From fd1e533b1746fc05537bf31278d9d8a1fa0e8bc9 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 12:35:25 +0000 Subject: [PATCH 012/102] Added Group Vars to maybe fix the inability to find roles. --- group_vars/openstack.yml | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 group_vars/openstack.yml diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml new file mode 100644 index 0000000..4aaa3b7 --- /dev/null +++ b/group_vars/openstack.yml @@ -0,0 +1,26 @@ +# The default Terraform state key for backends that support it +terraform_state_key: "cluster/{{ cluster_id }}/tfstate" + +# Set up the terraform backend +# This setup allows us to use the Consul backend when enabled without any changes +terraform_backend_type: "{{ 'consul' if 'CONSUL_HTTP_ADDR' in ansible_env else 'local' }}" +terraform_backend_config_defaults: + consul: + path: "{{ terraform_state_key }}" + gzip: "true" + local: {} +terraform_backend_config: "{{ terraform_backend_config_defaults[terraform_backend_type] }}" + +# These variables control the location of the Terraform binary +terraform_binary_directory: "{{ playbook_dir }}/bin" +terraform_binary_path: "{{ terraform_binary_directory }}/terraform" + +# This controls the location where the Terraform files are rendered +terraform_project_path: "{{ playbook_dir }}/terraform" + +# Indicates whether the Terraform operation is reconciling or removing resources +# Valid values are 'present' and 'absent' +terraform_state: "{{ cluster_state | default('present') }}" + +# The user that should be used to SSH to the cluster hosts +cluster_ssh_user: ubuntu \ No newline at end of file From baa2521ffd1de7628393c103c62184ef77ee5389 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 12:53:20 +0000 Subject: [PATCH 013/102] Change roles directory name. --- roles/{cluster-infra => cluster_infra}/tasks/main.yml | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename roles/{cluster-infra => cluster_infra}/tasks/main.yml (100%) diff --git a/roles/cluster-infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml similarity index 100% rename from roles/cluster-infra/tasks/main.yml rename to roles/cluster_infra/tasks/main.yml From 2f36b843c55f5f68a95c3e4540d2c69330262bc7 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 13:09:30 +0000 Subject: [PATCH 014/102] Added templates so that gateway_ips can be provided. --- roles/cluster_infra/tasks/main.yml | 9 +++++ roles/cluster_infra/templates/outputs.tf.j2 | 36 +++++++++++++++++++ roles/cluster_infra/templates/providers.tf.j2 | 10 ++++++ 3 files changed, 55 insertions(+) create mode 100644 roles/cluster_infra/templates/outputs.tf.j2 create mode 100644 roles/cluster_infra/templates/providers.tf.j2 diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index 485f0a4..e10aaef 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -36,6 +36,15 @@ - terraform_state == "present" - cluster_upgrade_system_packages is not defined or not cluster_upgrade_system_packages + +- name: Template Terraform files into project directory + template: + src: "{{ item }}.j2" + dest: "{{ terraform_project_path }}/{{ item }}" + loop: + - outputs.tf + - providers.tf + - name: Copy Terraform files into project directory ansible.builtin.copy: src: "{{ item }}" diff --git a/roles/cluster_infra/templates/outputs.tf.j2 b/roles/cluster_infra/templates/outputs.tf.j2 new file mode 100644 index 0000000..26fd967 --- /dev/null +++ b/roles/cluster_infra/templates/outputs.tf.j2 @@ -0,0 +1,36 @@ +# This is used to determine the image to use unless explicitly patching +output "cluster_image" { + description = "The id of the image used to build the cluster nodes" + value = "{{ cluster_previous_image | default(cluster_image) }}" +} + +output "cluster_gateway_ip" { + description = "The IP address of the gateway used to contact the cluster nodes" + value = "${openstack_networking_floatingip_v2.load_balancer.address}" +} + +output "cluster_nodes" { + description = "A list of the nodes in the cluster from which an Ansible inventory will be populated" + value = concat( + [ + { + name = "${openstack_compute_instance_v2.load_balancer.name}" + ip = "${openstack_compute_instance_v2.load_balancer.network[0].fixed_ip_v4}" + groups = ["load_balancers"], + facts = { + openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" + } + } + ], + [ + for backend in openstack_compute_instance_v2.backend: { + name = "${backend.name}" + ip = "${backend.network[0].fixed_ip_v4}" + groups = ["backends"], + facts = { + openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" + } + } + ] + ) +} \ No newline at end of file diff --git a/roles/cluster_infra/templates/providers.tf.j2 b/roles/cluster_infra/templates/providers.tf.j2 new file mode 100644 index 0000000..7e326da --- /dev/null +++ b/roles/cluster_infra/templates/providers.tf.j2 @@ -0,0 +1,10 @@ +terraform { + required_version = ">= 0.14" + + # We need the OpenStack provider + required_providers { + openstack = { + source = "terraform-provider-openstack/openstack" + } + } +} \ No newline at end of file From c29c28c2526c8bae21aae323e53c5eef3c395e62 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 13:23:15 +0000 Subject: [PATCH 015/102] Changed few tf files and 'template' to submit correct data. --- roles/cluster_infra/tasks/main.yml | 5 +- roles/cluster_infra/templates/outputs.tf.j2 | 146 +++++++++++++----- roles/cluster_infra/templates/providers.tf.j2 | 10 -- 3 files changed, 113 insertions(+), 48 deletions(-) delete mode 100644 roles/cluster_infra/templates/providers.tf.j2 diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index e10aaef..720eb08 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -43,13 +43,12 @@ dest: "{{ terraform_project_path }}/{{ item }}" loop: - outputs.tf - - providers.tf - name: Copy Terraform files into project directory ansible.builtin.copy: - src: "{{ item }}" + src: "{{ item }}.tf" dest: "{{ terraform_project_path }}/{{ item }}" - loop: "{{ query('fileglob', '../../../*.tf') }}" + loop: "{{ query('fileglob', '../../../*') }}" - name: Provision infrastructure include_role: diff --git a/roles/cluster_infra/templates/outputs.tf.j2 b/roles/cluster_infra/templates/outputs.tf.j2 index 26fd967..aaec76c 100644 --- a/roles/cluster_infra/templates/outputs.tf.j2 +++ b/roles/cluster_infra/templates/outputs.tf.j2 @@ -1,36 +1,112 @@ -# This is used to determine the image to use unless explicitly patching -output "cluster_image" { - description = "The id of the image used to build the cluster nodes" - value = "{{ cluster_previous_image | default(cluster_image) }}" -} - -output "cluster_gateway_ip" { - description = "The IP address of the gateway used to contact the cluster nodes" - value = "${openstack_networking_floatingip_v2.load_balancer.address}" -} - -output "cluster_nodes" { - description = "A list of the nodes in the cluster from which an Ansible inventory will be populated" - value = concat( - [ - { - name = "${openstack_compute_instance_v2.load_balancer.name}" - ip = "${openstack_compute_instance_v2.load_balancer.network[0].fixed_ip_v4}" - groups = ["load_balancers"], - facts = { - openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" - } - } - ], - [ - for backend in openstack_compute_instance_v2.backend: { - name = "${backend.name}" - ip = "${backend.network[0].fixed_ip_v4}" - groups = ["backends"], - facts = { - openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" - } - } - ] +output "ansible_control_access_ip_v4" { + value = openstack_compute_instance_v2.ansible_control.access_ip_v4 +} + +output "seed_access_ip_v4" { + value = openstack_compute_instance_v2.seed.access_ip_v4 +} + +output "ssh_user" { + value = var.ssh_user +} + +resource "local_file" "hosts" { + content = templatefile( + "${path.module}/templates/hosts.tpl", + { + compute_hostname = openstack_compute_instance_v2.compute.*.name + controller_hostname = openstack_compute_instance_v2.controller.*.name + ansible_control_hostname = openstack_compute_instance_v2.ansible_control.name + storage_hostname = openstack_compute_instance_v2.storage.*.name + seed_hostname = openstack_compute_instance_v2.seed.name + wazuh_manager_hostname = openstack_compute_instance_v2.wazuh_manager.*.name + } + ) + filename = "ansible/files/hosts" + file_permission = "0644" +} + +resource "local_file" "admin_networks" { + content = templatefile( + "${path.module}/templates/admin-oc-networks.tpl", + { + access_cidr = data.openstack_networking_subnet_v2.network.cidr + compute_hostname = openstack_compute_instance_v2.compute.*.name + controller_hostname = openstack_compute_instance_v2.controller.*.name + ansible_control_hostname = openstack_compute_instance_v2.ansible_control.name + ansible_control = openstack_compute_instance_v2.ansible_control.access_ip_v4 + compute = openstack_compute_instance_v2.compute.*.access_ip_v4 + controllers = openstack_compute_instance_v2.controller.*.access_ip_v4 + storage_hostname = openstack_compute_instance_v2.storage.*.name + storage = openstack_compute_instance_v2.storage.*.access_ip_v4 + seed_hostname = openstack_compute_instance_v2.seed.name + seed = openstack_compute_instance_v2.seed.access_ip_v4 + wazuh_manager_hostname = openstack_compute_instance_v2.wazuh_manager.*.name + wazuh_manager = openstack_compute_instance_v2.wazuh_manager.*.access_ip_v4 + } + ) + filename = "ansible/files/admin-oc-networks.yml" + file_permission = "0644" +} + +resource "local_file" "openstack_inventory" { + content = templatefile( + "${path.module}/templates/openstack-inventory.tpl", + { + seed_addr = openstack_compute_instance_v2.seed.access_ip_v4, + ssh_user = var.ssh_user + } + ) + filename = "ansible/files/openstack-inventory" + file_permission = "0644" +} + +resource "local_file" "deploy_openstack" { + content = templatefile( + "${path.module}/templates/deploy-openstack.tpl", + { + seed_addr = openstack_compute_instance_v2.seed.access_ip_v4, + ssh_user = var.ssh_user, + deploy_wazuh = var.deploy_wazuh + controller_hostname = openstack_compute_instance_v2.controller.*.name + } ) -} \ No newline at end of file + filename = "ansible/files/deploy-openstack.sh" + file_permission = "0755" +} + +resource "ansible_host" "control_host" { + name = openstack_compute_instance_v2.ansible_control.access_ip_v4 + groups = ["ansible_control"] +} + +resource "ansible_host" "compute_host" { + for_each = { for host in openstack_compute_instance_v2.compute : host.name => host.access_ip_v4 } + name = each.value + groups = ["compute"] +} + +resource "ansible_host" "controllers_hosts" { + for_each = { for host in openstack_compute_instance_v2.controller : host.name => host.access_ip_v4 } + name = each.value + groups = ["controllers"] +} + +resource "ansible_host" "seed_host" { + name = openstack_compute_instance_v2.seed.access_ip_v4 + groups = ["seed"] +} + +resource "ansible_host" "storage" { + for_each = { for host in openstack_compute_instance_v2.storage : host.name => host.access_ip_v4 } + name = each.value + groups = ["storage"] +} + +resource "ansible_group" "cluster_group" { + name = "cluster" + children = ["compute", "ansible_control", "controllers", "seed", "storage"] + variables = { + ansible_user = var.ssh_user + } +} diff --git a/roles/cluster_infra/templates/providers.tf.j2 b/roles/cluster_infra/templates/providers.tf.j2 deleted file mode 100644 index 7e326da..0000000 --- a/roles/cluster_infra/templates/providers.tf.j2 +++ /dev/null @@ -1,10 +0,0 @@ -terraform { - required_version = ">= 0.14" - - # We need the OpenStack provider - required_providers { - openstack = { - source = "terraform-provider-openstack/openstack" - } - } -} \ No newline at end of file From 63c8f5417557ff94cff752f32c2771ac2c7e57f4 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 13:39:06 +0000 Subject: [PATCH 016/102] Trying to copy all tf files to the appropriate location. --- roles/cluster_infra/tasks/main.yml | 18 +- .../templates/authentication.tf.j2 | 4 + .../templates/compute_instances.tf.j2 | 160 ++++++++++++++++++ roles/cluster_infra/templates/data.tf.j2 | 8 + roles/cluster_infra/templates/variables.tf.j2 | 104 ++++++++++++ roles/cluster_infra/templates/versions.tf.j2 | 15 ++ roles/cluster_infra/templates/volumes.tf.j2 | 11 ++ 7 files changed, 314 insertions(+), 6 deletions(-) create mode 100644 roles/cluster_infra/templates/authentication.tf.j2 create mode 100644 roles/cluster_infra/templates/compute_instances.tf.j2 create mode 100644 roles/cluster_infra/templates/data.tf.j2 create mode 100644 roles/cluster_infra/templates/variables.tf.j2 create mode 100644 roles/cluster_infra/templates/versions.tf.j2 create mode 100644 roles/cluster_infra/templates/volumes.tf.j2 diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index 720eb08..afbc51b 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -43,12 +43,18 @@ dest: "{{ terraform_project_path }}/{{ item }}" loop: - outputs.tf - -- name: Copy Terraform files into project directory - ansible.builtin.copy: - src: "{{ item }}.tf" - dest: "{{ terraform_project_path }}/{{ item }}" - loop: "{{ query('fileglob', '../../../*') }}" + - variables.tf + - authentication.tf + - compute_instances.tf + - data.tf + - versions.tf + - volumes.tf + +#- name: Copy Terraform files into project directory +# ansible.builtin.copy: +# src: "{{ item }}.tf" +# dest: "{{ terraform_project_path }}/{{ item }}.tf" +# loop: "{{ query('fileglob', '../../../*') }}" - name: Provision infrastructure include_role: diff --git a/roles/cluster_infra/templates/authentication.tf.j2 b/roles/cluster_infra/templates/authentication.tf.j2 new file mode 100644 index 0000000..266e107 --- /dev/null +++ b/roles/cluster_infra/templates/authentication.tf.j2 @@ -0,0 +1,4 @@ +resource "openstack_compute_keypair_v2" "keypair" { + name = var.multinode_keypair + public_key = file(var.ssh_public_key) +} \ No newline at end of file diff --git a/roles/cluster_infra/templates/compute_instances.tf.j2 b/roles/cluster_infra/templates/compute_instances.tf.j2 new file mode 100644 index 0000000..a8db2c4 --- /dev/null +++ b/roles/cluster_infra/templates/compute_instances.tf.j2 @@ -0,0 +1,160 @@ +resource "openstack_compute_instance_v2" "ansible_control" { + name = format("%s-%s", var.prefix, var.ansible_control_vm_name) + flavor_name = var.ansible_control_vm_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + network { + name = var.multinode_vm_network + } + + dynamic "block_device" { + for_each = var.ansible_control_disk_size > 0 ? [1] : [] + content { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.ansible_control_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + } + timeouts { + create = "90m" + } + lifecycle { + ignore_changes = [ + user_data + ] + } +} + +resource "openstack_compute_instance_v2" "seed" { + name = format("%s-seed", var.prefix) + flavor_name = var.seed_vm_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + network { + name = var.multinode_vm_network + } + + dynamic "block_device" { + for_each = var.seed_disk_size > 0 ? [1] : [] + content { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.seed_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + } + timeouts { + create = "90m" + } +} + +resource "openstack_compute_instance_v2" "compute" { + name = format("%s-compute-%02d", var.prefix, count.index + 1) + flavor_name = var.multinode_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + image_name = var.multinode_image + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + count = var.compute_count + network { + name = var.multinode_vm_network + } + dynamic "block_device" { + for_each = var.compute_disk_size > 0 ? [1] : [] + content { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.compute_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + } + timeouts { + create = "90m" + } +} +resource "openstack_compute_instance_v2" "controller" { + name = format("%s-controller-%02d", var.prefix, count.index + 1) + flavor_name = var.multinode_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + image_name = var.multinode_image + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + count = var.controller_count + network { + name = var.multinode_vm_network + } + dynamic "block_device" { + for_each = var.controller_disk_size > 0 ? [1] : [] + content { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.controller_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + } + timeouts { + create = "90m" + } +} + +resource "openstack_compute_instance_v2" "storage" { + name = format("%s-storage-%02d", var.prefix, count.index + 1) + flavor_name = var.storage_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + image_name = var.multinode_image + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + count = var.storage_count + network { + name = var.multinode_vm_network + } + dynamic "block_device" { + for_each = var.storage_disk_size > 0 ? [1] : [] + content { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.storage_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + } + timeouts { + create = "90m" + } +} + +resource "openstack_compute_instance_v2" "wazuh_manager" { + name = format("%s-wazuh-manager-%02d", var.prefix, count.index + 1) + flavor_name = var.infra_vm_flavor + key_pair = resource.openstack_compute_keypair_v2.keypair.name + image_name = var.multinode_image + config_drive = true + user_data = file("templates/userdata.cfg.tpl") + count = var.deploy_wazuh ? 1 : 0 + network { + name = var.multinode_vm_network + } + block_device { + uuid = data.openstack_images_image_v2.multinode_image.id + source_type = "image" + volume_size = var.infra_vm_disk_size + boot_index = 0 + destination_type = "volume" + delete_on_termination = true + } + timeouts { + create = "90m" + } +} diff --git a/roles/cluster_infra/templates/data.tf.j2 b/roles/cluster_infra/templates/data.tf.j2 new file mode 100644 index 0000000..5c91dc0 --- /dev/null +++ b/roles/cluster_infra/templates/data.tf.j2 @@ -0,0 +1,8 @@ +data "openstack_images_image_v2" "multinode_image" { + name = var.multinode_image + most_recent = true +} + +data "openstack_networking_subnet_v2" "network" { + name = var.multinode_vm_subnet +} \ No newline at end of file diff --git a/roles/cluster_infra/templates/variables.tf.j2 b/roles/cluster_infra/templates/variables.tf.j2 new file mode 100644 index 0000000..950c01c --- /dev/null +++ b/roles/cluster_infra/templates/variables.tf.j2 @@ -0,0 +1,104 @@ +variable "storage_count" { + type = string +} + +variable "ssh_public_key" { + type = string +} + +variable "ssh_user" { + type = string +} + +variable "ansible_control_vm_name" { + type = string +} + +variable "seed_vm_flavor" { + type = string +} + +variable "prefix" { + type = string + default = "kayobe-mn" +} + +variable "compute_count" { + type = string +} + +variable "controller_count" { + type = string +} + +variable "multinode_image" { + type = string +} + +variable "multinode_keypair" { + type = string +} + +variable "ansible_control_vm_flavor" { + type = string +} + +variable "multinode_flavor" { + type = string +} + +variable "storage_flavor" { + type = string +} + +variable "infra_vm_flavor" { + type = string +} + +variable "multinode_vm_network" { + type = string +} + +variable "multinode_vm_subnet" { + type = string +} + +variable "compute_disk_size" { + description = "Block storage root disk size for compute nodes in GB. Set to 0 on baremetal to use physical storage." + type = number +} + +variable "controller_disk_size" { + description = "Block storage root disk size for controller nodes in GB. Set to 0 on baremetal to use physical storage." + type = number +} + +variable "ansible_control_disk_size" { + description = "Block storage root disk size for the ansible control node in GB. Set to 0 on baremetal to use physical storage." + type = number + default = 100 +} + +variable "seed_disk_size" { + description = "Block storage root disk size for the seed node in GB. Set to 0 on baremetal to use physical storage." + type = number + default = 100 +} + +variable "storage_disk_size" { + description = "Block storage root disk size for storage nodes in GB. Set to 0 on baremetal to use physical storage." + type = number + default = 100 +} + +variable "infra_vm_disk_size" { + description = "Block storage root disk size for infrastructure VMs." + type = number + default = 100 +} + +variable "deploy_wazuh" { + description = "Bool, whether or not to deploy Wazuh." + type = bool + default = false +} diff --git a/roles/cluster_infra/templates/versions.tf.j2 b/roles/cluster_infra/templates/versions.tf.j2 new file mode 100644 index 0000000..a380cc4 --- /dev/null +++ b/roles/cluster_infra/templates/versions.tf.j2 @@ -0,0 +1,15 @@ +terraform { + required_version = ">= 0.14" + backend "local" { + } + required_providers { + openstack = { + source = "terraform-provider-openstack/openstack" + version = "1.49.0" + } + ansible = { + source = "ansible/ansible" + version = "1.1.0" + } + } +} diff --git a/roles/cluster_infra/templates/volumes.tf.j2 b/roles/cluster_infra/templates/volumes.tf.j2 new file mode 100644 index 0000000..f7eaeef --- /dev/null +++ b/roles/cluster_infra/templates/volumes.tf.j2 @@ -0,0 +1,11 @@ +resource "openstack_blockstorage_volume_v3" "volumes" { + count = var.storage_count + name = format("%s-osd-%02d", var.prefix, count.index + 1) + size = 40 +} + +resource "openstack_compute_volume_attach_v2" "attachments" { + count = var.storage_count + instance_id = openstack_compute_instance_v2.storage.*.id[count.index] + volume_id = openstack_blockstorage_volume_v3.volumes.*.id[count.index] +} \ No newline at end of file From 4351735e28ca35342d378378ddc951e0acefe927 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 13:54:15 +0000 Subject: [PATCH 017/102] Added TF Variables to use to build. --- roles/cluster_infra/tasks/main.yml | 1 + .../templates/terraform.tfvars.j2 | 31 +++++++++++++++++++ terraform.tfvars | 31 +++++++++++++++++++ 3 files changed, 63 insertions(+) create mode 100644 roles/cluster_infra/templates/terraform.tfvars.j2 create mode 100644 terraform.tfvars diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index afbc51b..b90aa5f 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -49,6 +49,7 @@ - data.tf - versions.tf - volumes.tf + - terraform.tfvars #- name: Copy Terraform files into project directory # ansible.builtin.copy: diff --git a/roles/cluster_infra/templates/terraform.tfvars.j2 b/roles/cluster_infra/templates/terraform.tfvars.j2 new file mode 100644 index 0000000..0115a10 --- /dev/null +++ b/roles/cluster_infra/templates/terraform.tfvars.j2 @@ -0,0 +1,31 @@ +prefix = "TestMN" + +ansible_control_vm_flavor = "general.v1.small" +ansible_control_vm_name = "ansible-control" +ansible_control_disk_size = 100 + +seed_vm_flavor = "general.v1.small" +seed_disk_size = 100 + +multinode_flavor = "general.v1.medium" +multinode_image = "Rocky9-lvm" +multinode_keypair = "MaxMNKP" +multinode_vm_network = "stackhpc-ipv4-geneve" +multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" +compute_count = "2" +controller_count = "3" +compute_disk_size = 100 +controller_disk_size = 100 + +ssh_public_key = "~/.ssh/id_ed25519.pub" +ssh_user = "cloud-user" + +storage_count = "3" +storage_flavor = "general.v1.small" +storage_disk_size = 100 + +deploy_wazuh = true +infra_vm_flavor = "general.v1.small" +infra_vm_disk_size = 100 + +EOF \ No newline at end of file diff --git a/terraform.tfvars b/terraform.tfvars new file mode 100644 index 0000000..0115a10 --- /dev/null +++ b/terraform.tfvars @@ -0,0 +1,31 @@ +prefix = "TestMN" + +ansible_control_vm_flavor = "general.v1.small" +ansible_control_vm_name = "ansible-control" +ansible_control_disk_size = 100 + +seed_vm_flavor = "general.v1.small" +seed_disk_size = 100 + +multinode_flavor = "general.v1.medium" +multinode_image = "Rocky9-lvm" +multinode_keypair = "MaxMNKP" +multinode_vm_network = "stackhpc-ipv4-geneve" +multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" +compute_count = "2" +controller_count = "3" +compute_disk_size = 100 +controller_disk_size = 100 + +ssh_public_key = "~/.ssh/id_ed25519.pub" +ssh_user = "cloud-user" + +storage_count = "3" +storage_flavor = "general.v1.small" +storage_disk_size = 100 + +deploy_wazuh = true +infra_vm_flavor = "general.v1.small" +infra_vm_disk_size = 100 + +EOF \ No newline at end of file From 6a0f55e20efec23265963d40dd12dc6dd3ec5c54 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 14:13:25 +0000 Subject: [PATCH 018/102] Check current playbook directory. --- multinode-app.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index 60d77a5..8597511 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -12,4 +12,8 @@ - debug: var=outputs vars: outputs: - cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" \ No newline at end of file + cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" + + - name: Show Playbook Directory + debug: + msg: "{{ playbook_dir }}" \ No newline at end of file From bacaa2f02d9b84add86320c3614a0b22073c3354 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 14:39:50 +0000 Subject: [PATCH 019/102] remove versions.tf --- roles/cluster_infra/tasks/main.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index b90aa5f..962315c 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -47,7 +47,6 @@ - authentication.tf - compute_instances.tf - data.tf - - versions.tf - volumes.tf - terraform.tfvars From f72a422ddfd1ecec1b609274c6e5eb1503c9fc9d Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 14:51:07 +0000 Subject: [PATCH 020/102] Edited backend type and vars. --- group_vars/openstack.yml | 4 ++-- roles/cluster_infra/tasks/main.yml | 1 + roles/cluster_infra/templates/versions.tf.j2 | 2 -- 3 files changed, 3 insertions(+), 4 deletions(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 4aaa3b7..c83dd63 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -3,7 +3,7 @@ terraform_state_key: "cluster/{{ cluster_id }}/tfstate" # Set up the terraform backend # This setup allows us to use the Consul backend when enabled without any changes -terraform_backend_type: "{{ 'consul' if 'CONSUL_HTTP_ADDR' in ansible_env else 'local' }}" +terraform_backend_type: 'local' terraform_backend_config_defaults: consul: path: "{{ terraform_state_key }}" @@ -23,4 +23,4 @@ terraform_project_path: "{{ playbook_dir }}/terraform" terraform_state: "{{ cluster_state | default('present') }}" # The user that should be used to SSH to the cluster hosts -cluster_ssh_user: ubuntu \ No newline at end of file +cluster_ssh_user: cloud-user \ No newline at end of file diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index 962315c..b90aa5f 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -47,6 +47,7 @@ - authentication.tf - compute_instances.tf - data.tf + - versions.tf - volumes.tf - terraform.tfvars diff --git a/roles/cluster_infra/templates/versions.tf.j2 b/roles/cluster_infra/templates/versions.tf.j2 index a380cc4..74359a0 100644 --- a/roles/cluster_infra/templates/versions.tf.j2 +++ b/roles/cluster_infra/templates/versions.tf.j2 @@ -1,7 +1,5 @@ terraform { required_version = ">= 0.14" - backend "local" { - } required_providers { openstack = { source = "terraform-provider-openstack/openstack" From 7403414036052b8fa2847eab39a271521e2fbc09 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:14:53 +0000 Subject: [PATCH 021/102] Locate playbook directory. --- multinode-app.yml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/multinode-app.yml b/multinode-app.yml index 8597511..0edc84b 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -1,5 +1,11 @@ --- +- hosts: localhost + tasks: + - name: Show Playbook Directory + debug: + msg: "{{ playbook_dir }}" + # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group - hosts: openstack From f666fed89f5bd706bf2d7b301675617cf1200381 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:28:29 +0000 Subject: [PATCH 022/102] Change directory for project. --- group_vars/openstack.yml | 14 ++++++++++++-- roles/cluster_infra/tasks/main.yml | 10 +--------- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index c83dd63..8a7587f 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -16,11 +16,21 @@ terraform_binary_directory: "{{ playbook_dir }}/bin" terraform_binary_path: "{{ terraform_binary_directory }}/terraform" # This controls the location where the Terraform files are rendered -terraform_project_path: "{{ playbook_dir }}/terraform" +terraform_project_path: "{{ playbook_dir }}" # Indicates whether the Terraform operation is reconciling or removing resources # Valid values are 'present' and 'absent' terraform_state: "{{ cluster_state | default('present') }}" # The user that should be used to SSH to the cluster hosts -cluster_ssh_user: cloud-user \ No newline at end of file +cluster_ssh_user: cloud-user + +tf_files: [] + #- outputs.tf + #- variables.tf + # - authentication.tf + # - compute_instances.tf + # - data.tf + # - versions.tf + # - volumes.tf + # - terraform.tfvars diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index b90aa5f..c7f24d6 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -41,15 +41,7 @@ template: src: "{{ item }}.j2" dest: "{{ terraform_project_path }}/{{ item }}" - loop: - - outputs.tf - - variables.tf - - authentication.tf - - compute_instances.tf - - data.tf - - versions.tf - - volumes.tf - - terraform.tfvars + loop: "{{ tf_files }}" #- name: Copy Terraform files into project directory # ansible.builtin.copy: From 1e1bdbe782cf5cdaa5587fa06de38cf85e717a8e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:31:57 +0000 Subject: [PATCH 023/102] Remove backend type. --- versions.tf | 2 -- 1 file changed, 2 deletions(-) diff --git a/versions.tf b/versions.tf index a380cc4..74359a0 100644 --- a/versions.tf +++ b/versions.tf @@ -1,7 +1,5 @@ terraform { required_version = ">= 0.14" - backend "local" { - } required_providers { openstack = { source = "terraform-provider-openstack/openstack" From e6969d2b3c2be6512603f4c7c863a805bfd7720e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:37:21 +0000 Subject: [PATCH 024/102] Typo fix. --- terraform.tfvars | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/terraform.tfvars b/terraform.tfvars index 0115a10..b492809 100644 --- a/terraform.tfvars +++ b/terraform.tfvars @@ -26,6 +26,4 @@ storage_disk_size = 100 deploy_wazuh = true infra_vm_flavor = "general.v1.small" -infra_vm_disk_size = 100 - -EOF \ No newline at end of file +infra_vm_disk_size = 100 \ No newline at end of file From 73e4f9e3c37fe0095f98a4c2b1a878bff54780d9 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:51:27 +0000 Subject: [PATCH 025/102] Change tfvars to j2 temp. --- multinode-app.yml | 11 +++++++++++ terraform.tfvars => terraform.tfvars.j2 | 2 +- 2 files changed, 12 insertions(+), 1 deletion(-) rename terraform.tfvars => terraform.tfvars.j2 (93%) diff --git a/multinode-app.yml b/multinode-app.yml index 0edc84b..ffc1207 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -5,6 +5,17 @@ - name: Show Playbook Directory debug: msg: "{{ playbook_dir }}" + - name: Generate SSH Key + community.crypto.openssh_keypair: + path: "{{ playbook_dir }}/ssh_key" + type: ed25519 + size: 2048 + state: present + force: yes + - name: Template Terraform files into project directory + template: + src: terraform.tfvars.j2 + dest: "{{ playbook_dir }}/terraform.tfvars" # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group diff --git a/terraform.tfvars b/terraform.tfvars.j2 similarity index 93% rename from terraform.tfvars rename to terraform.tfvars.j2 index b492809..f2ed58b 100644 --- a/terraform.tfvars +++ b/terraform.tfvars.j2 @@ -17,7 +17,7 @@ controller_count = "3" compute_disk_size = 100 controller_disk_size = 100 -ssh_public_key = "~/.ssh/id_ed25519.pub" +ssh_public_key = "{{ playbook_dir }}/ssh_key.pub" ssh_user = "cloud-user" storage_count = "3" From d834bb6012dcaa0002e5eca618a484d38c2fb11c Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:56:19 +0000 Subject: [PATCH 026/102] SSH gen alternative method. --- multinode-app.yml | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index ffc1207..6d3951f 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -5,13 +5,14 @@ - name: Show Playbook Directory debug: msg: "{{ playbook_dir }}" + - name: Generate SSH Key - community.crypto.openssh_keypair: + ansible.posix.ssh_keypair: path: "{{ playbook_dir }}/ssh_key" - type: ed25519 + type: rsa size: 2048 state: present - force: yes + - name: Template Terraform files into project directory template: src: terraform.tfvars.j2 From 6a3cea82875a41886a785e7ec6e216a84efb0534 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 5 Jan 2024 15:58:36 +0000 Subject: [PATCH 027/102] SSH alt method 2. --- multinode-app.yml | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 6d3951f..3da4ca2 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -7,11 +7,7 @@ msg: "{{ playbook_dir }}" - name: Generate SSH Key - ansible.posix.ssh_keypair: - path: "{{ playbook_dir }}/ssh_key" - type: rsa - size: 2048 - state: present + command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" - name: Template Terraform files into project directory template: From 608881f9645b219704f85193557480fc3d505375 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 10:15:23 +0000 Subject: [PATCH 028/102] Update cluster_gateway_ip output variable. --- outputs.tf | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/outputs.tf b/outputs.tf index aaec76c..f307c8f 100644 --- a/outputs.tf +++ b/outputs.tf @@ -2,6 +2,10 @@ output "ansible_control_access_ip_v4" { value = openstack_compute_instance_v2.ansible_control.access_ip_v4 } +output "cluster_gateway_ip" { + value = openstack_compute_instance_v2.ansible_control.access_ip_v4 +} + output "seed_access_ip_v4" { value = openstack_compute_instance_v2.seed.access_ip_v4 } From b4096ed6167d4153e2ecc17c6db4d1a2ddb83a99 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:11:04 +0000 Subject: [PATCH 029/102] Include cluster_nodes variable in output. --- outputs.tf | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/outputs.tf b/outputs.tf index f307c8f..ff7ecd9 100644 --- a/outputs.tf +++ b/outputs.tf @@ -53,6 +53,27 @@ resource "local_file" "admin_networks" { file_permission = "0644" } +output "cluster_nodes" { + value = concat( + [ + { + name = var.compute_hostname + ip = var.compute + groups = ["compute"], + } + ], + [ + for backend in openstack_compute_instance_v2.backend: { + name = "${backend.name}" + ip = "${backend.network[0].fixed_ip_v4}" + groups = ["backends"], + } + ] + ) +} + + + resource "local_file" "openstack_inventory" { content = templatefile( "${path.module}/templates/openstack-inventory.tpl", From 4fa6cbbfb7e2ba178c6e159560286f824028472a Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:16:34 +0000 Subject: [PATCH 030/102] Remove backend from cluster_nodes variable. --- outputs.tf | 7 ------- 1 file changed, 7 deletions(-) diff --git a/outputs.tf b/outputs.tf index ff7ecd9..a4c16ce 100644 --- a/outputs.tf +++ b/outputs.tf @@ -61,13 +61,6 @@ output "cluster_nodes" { ip = var.compute groups = ["compute"], } - ], - [ - for backend in openstack_compute_instance_v2.backend: { - name = "${backend.name}" - ip = "${backend.network[0].fixed_ip_v4}" - groups = ["backends"], - } ] ) } From d934190bfd9d89021fc94f7943806640a1a824c4 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:21:07 +0000 Subject: [PATCH 031/102] Amend variable call. --- outputs.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/outputs.tf b/outputs.tf index a4c16ce..6ae8ffb 100644 --- a/outputs.tf +++ b/outputs.tf @@ -57,8 +57,8 @@ output "cluster_nodes" { value = concat( [ { - name = var.compute_hostname - ip = var.compute + name = "${var.compute_hostname}" + ip = "${var.compute}" groups = ["compute"], } ] From 3d3324e0b5ba07a88135648108f144c92c89403d Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:24:51 +0000 Subject: [PATCH 032/102] Changed variables being provided to cluster-nodes. --- outputs.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/outputs.tf b/outputs.tf index 6ae8ffb..33e9ec5 100644 --- a/outputs.tf +++ b/outputs.tf @@ -57,8 +57,8 @@ output "cluster_nodes" { value = concat( [ { - name = "${var.compute_hostname}" - ip = "${var.compute}" + name = "${openstack_compute_instance_v2.compute.*.name}" + ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" groups = ["compute"], } ] From 6f921cab5a9bbc2bf3a7978e1c99efe69cad890e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:31:27 +0000 Subject: [PATCH 033/102] Test change to cluster_nodes variable name. --- outputs.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/outputs.tf b/outputs.tf index 33e9ec5..73972dc 100644 --- a/outputs.tf +++ b/outputs.tf @@ -57,8 +57,8 @@ output "cluster_nodes" { value = concat( [ { - name = "${openstack_compute_instance_v2.compute.*.name}" - ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" + name = openstack_compute_instance_v2.compute.*.name + ip = openstack_compute_instance_v2.compute.*.access_ip_v4 groups = ["compute"], } ] From 09be066f4d3aabace3b62a67226821878066d8df Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:38:07 +0000 Subject: [PATCH 034/102] Remove cluster_nodes concat var. --- outputs.tf | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/outputs.tf b/outputs.tf index 73972dc..9e38470 100644 --- a/outputs.tf +++ b/outputs.tf @@ -54,15 +54,13 @@ resource "local_file" "admin_networks" { } output "cluster_nodes" { - value = concat( - [ + value = [ { - name = openstack_compute_instance_v2.compute.*.name - ip = openstack_compute_instance_v2.compute.*.access_ip_v4 + name = "${openstack_compute_instance_v2.compute.*.name}" + ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" groups = ["compute"], } ] - ) } From ac40ab65f0dccaa03a661081525759e7b274b33e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:43:39 +0000 Subject: [PATCH 035/102] Formatting amendment. --- outputs.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/outputs.tf b/outputs.tf index 9e38470..c06a5c6 100644 --- a/outputs.tf +++ b/outputs.tf @@ -58,7 +58,7 @@ output "cluster_nodes" { { name = "${openstack_compute_instance_v2.compute.*.name}" ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" - groups = ["compute"], + groups = ["compute"] } ] } From ff3f864212a5acd1ad3d6cd23b65be8a2d9e1778 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 11:53:10 +0000 Subject: [PATCH 036/102] Concat the list of cluster_nodes. --- outputs.tf | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/outputs.tf b/outputs.tf index c06a5c6..08a579e 100644 --- a/outputs.tf +++ b/outputs.tf @@ -54,13 +54,15 @@ resource "local_file" "admin_networks" { } output "cluster_nodes" { - value = [ + value = concat( + [ { name = "${openstack_compute_instance_v2.compute.*.name}" ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" groups = ["compute"] } ] + ) } From a75a201b504b9fb835836814359abe8280ecc8df Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 12:10:54 +0000 Subject: [PATCH 037/102] Alter cluster_nodes variables. --- outputs.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/outputs.tf b/outputs.tf index 08a579e..9e6c5b4 100644 --- a/outputs.tf +++ b/outputs.tf @@ -57,8 +57,8 @@ output "cluster_nodes" { value = concat( [ { - name = "${openstack_compute_instance_v2.compute.*.name}" - ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" + name = "${compute_hostname}" + ip = "${compute}" groups = ["compute"] } ] From f1c84f9e3dee0d1484646642b8f33be0995c6926 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 12:50:17 +0000 Subject: [PATCH 038/102] create join list to save a loop. --- outputs.tf | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/outputs.tf b/outputs.tf index 9e6c5b4..c2212a2 100644 --- a/outputs.tf +++ b/outputs.tf @@ -54,12 +54,12 @@ resource "local_file" "admin_networks" { } output "cluster_nodes" { - value = concat( - [ + value = join("," , + [ { - name = "${compute_hostname}" - ip = "${compute}" - groups = ["compute"] + name = "${openstack_compute_instance_v2.compute.*.name}" + ip = "${openstack_compute_instance_v2.compute.[0].access_ip_v4}" + groups = ["compute"], } ] ) From 5514ce2908cb4c509874129891e7ab683c634c06 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 12:51:16 +0000 Subject: [PATCH 039/102] amend typo --- outputs.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/outputs.tf b/outputs.tf index c2212a2..f1b5687 100644 --- a/outputs.tf +++ b/outputs.tf @@ -58,7 +58,7 @@ output "cluster_nodes" { [ { name = "${openstack_compute_instance_v2.compute.*.name}" - ip = "${openstack_compute_instance_v2.compute.[0].access_ip_v4}" + ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" groups = ["compute"], } ] From ebd2ae475904870d5a5aa05d5b57269f2c768565 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 13:03:30 +0000 Subject: [PATCH 040/102] Change 'join' formatting. --- outputs.tf | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/outputs.tf b/outputs.tf index f1b5687..36bf657 100644 --- a/outputs.tf +++ b/outputs.tf @@ -57,9 +57,9 @@ output "cluster_nodes" { value = join("," , [ { - name = "${openstack_compute_instance_v2.compute.*.name}" - ip = "${openstack_compute_instance_v2.compute.*.access_ip_v4}" - groups = ["compute"], + name = "${openstack_compute_instance_v2.compute.[*].name}" + ip = "${openstack_compute_instance_v2.compute.[*].access_ip_v4}" + groups = ["compute"] } ] ) From a3bb3e4b119424238347d35e9995bff6594b3ede Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 13:40:44 +0000 Subject: [PATCH 041/102] Created for loop for cluster_nodes definition. --- outputs.tf | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/outputs.tf b/outputs.tf index 36bf657..6bb39ee 100644 --- a/outputs.tf +++ b/outputs.tf @@ -54,19 +54,19 @@ resource "local_file" "admin_networks" { } output "cluster_nodes" { - value = join("," , - [ - { - name = "${openstack_compute_instance_v2.compute.[*].name}" - ip = "${openstack_compute_instance_v2.compute.[*].access_ip_v4}" - groups = ["compute"] - } - ] - ) + description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" + value = flatten([ + for node in openstack_compute_instance_v2.compute: { + name = node.name + ip = node[0].access_ip_v4 + groups = ["compute"] + facts = { + openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" + } + } + ]) } - - resource "local_file" "openstack_inventory" { content = templatefile( "${path.module}/templates/openstack-inventory.tpl", From a1585d523bb26406539705efaafbace3ce364a22 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 13:45:56 +0000 Subject: [PATCH 042/102] removed fact for autherisation. --- outputs.tf | 3 --- 1 file changed, 3 deletions(-) diff --git a/outputs.tf b/outputs.tf index 6bb39ee..a77fa1e 100644 --- a/outputs.tf +++ b/outputs.tf @@ -60,9 +60,6 @@ output "cluster_nodes" { name = node.name ip = node[0].access_ip_v4 groups = ["compute"] - facts = { - openstack_project_id = "${data.openstack_identity_auth_scope_v3.scope.project_id}" - } } ]) } From fbb5968a012296b9e8750da4923435a07c1a113c Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 13:48:38 +0000 Subject: [PATCH 043/102] Remove index notation for IP. --- outputs.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/outputs.tf b/outputs.tf index a77fa1e..38ff8fa 100644 --- a/outputs.tf +++ b/outputs.tf @@ -58,7 +58,7 @@ output "cluster_nodes" { value = flatten([ for node in openstack_compute_instance_v2.compute: { name = node.name - ip = node[0].access_ip_v4 + ip = node.access_ip_v4 groups = ["compute"] } ]) From ca48124839b821caecad02d0e8de9d43f2720172 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 14:21:01 +0000 Subject: [PATCH 044/102] Changed backend type to a variable. --- group_vars/openstack.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 8a7587f..116f6e4 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -3,7 +3,8 @@ terraform_state_key: "cluster/{{ cluster_id }}/tfstate" # Set up the terraform backend # This setup allows us to use the Consul backend when enabled without any changes -terraform_backend_type: 'local' +#terraform_backend_type: 'local' +terraform_backend_type: "{{ 'consul' if 'CONSUL_HTTP_ADDR' in ansible_env else 'local' }}" terraform_backend_config_defaults: consul: path: "{{ terraform_state_key }}" From acd6d1c388418eb5c3cb94b6dda5fa6c74672608 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 15:14:39 +0000 Subject: [PATCH 045/102] Added azimuth ssh key. --- authentication.tf | 2 +- terraform.tfvars.j2 | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/authentication.tf b/authentication.tf index 266e107..0599337 100644 --- a/authentication.tf +++ b/authentication.tf @@ -1,4 +1,4 @@ resource "openstack_compute_keypair_v2" "keypair" { name = var.multinode_keypair - public_key = file(var.ssh_public_key) + public_key = var.ssh_public_key } \ No newline at end of file diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index f2ed58b..38b0db5 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -17,7 +17,7 @@ controller_count = "3" compute_disk_size = 100 controller_disk_size = 100 -ssh_public_key = "{{ playbook_dir }}/ssh_key.pub" +ssh_public_key = "{{ cluster_deploy_ssh_public_key }}" ssh_user = "cloud-user" storage_count = "3" From 0fa648b7d07ce674b454ec3b19d1b96ac72ef6f6 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 15:31:49 +0000 Subject: [PATCH 046/102] Commented out ssh key gen. --- multinode-app.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 3da4ca2..28a46f2 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -6,8 +6,8 @@ debug: msg: "{{ playbook_dir }}" - - name: Generate SSH Key - command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" +# - name: Generate SSH Key +# command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" - name: Template Terraform files into project directory template: From a6b6306c54446633449e97817b2697a7130664c6 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 15:35:49 +0000 Subject: [PATCH 047/102] Change from deploy to user key. --- terraform.tfvars.j2 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 38b0db5..c614e16 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -17,7 +17,7 @@ controller_count = "3" compute_disk_size = 100 controller_disk_size = 100 -ssh_public_key = "{{ cluster_deploy_ssh_public_key }}" +ssh_public_key = "{{ cluster_user_ssh_public_key }}" ssh_user = "cloud-user" storage_count = "3" From 76672b871a78e75bcc32628d380b329a7311734b Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 16:45:15 +0000 Subject: [PATCH 048/102] Set ssh deploy key to be equal to the user ssh key. --- group_vars/openstack.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 116f6e4..d122649 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -35,3 +35,5 @@ tf_files: [] # - versions.tf # - volumes.tf # - terraform.tfvars + +cluster_deploy_ssh_public_key: "{{cluster_user_ssh_public_key}}" \ No newline at end of file From c087cb7d68db384dd23daac6735296e092346591 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 17:20:11 +0000 Subject: [PATCH 049/102] Pass multiple ssh keys. --- compute_instances.tf | 4 +++- terraform.tfvars.j2 | 4 ++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/compute_instances.tf b/compute_instances.tf index a8db2c4..a917b25 100644 --- a/compute_instances.tf +++ b/compute_instances.tf @@ -87,7 +87,9 @@ resource "openstack_compute_instance_v2" "controller" { key_pair = resource.openstack_compute_keypair_v2.keypair.name image_name = var.multinode_image config_drive = true - user_data = file("templates/userdata.cfg.tpl") + #user_data = file("templates/userdata.cfg.tpl") + user_data = "${concat(file("templates/userdata.cfg.tpl"),["ssh_authorized_keys","${ var.ssh_authorized_keys }"])}" + count = var.controller_count network { name = var.multinode_vm_network diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index c614e16..b318fea 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -17,6 +17,10 @@ controller_count = "3" compute_disk_size = 100 controller_disk_size = 100 +ssh_authorized_keys: + - "{{ cluster_deploy_ssh_public_key }}" + - "{{ cluster_user_ssh_public_key }}" + ssh_public_key = "{{ cluster_user_ssh_public_key }}" ssh_user = "cloud-user" From 1de877828c1123c0e0981d65b2011ed6f134031b Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 17:32:06 +0000 Subject: [PATCH 050/102] Amend comment to be able to delete instance. --- compute_instances.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/compute_instances.tf b/compute_instances.tf index a917b25..c5ad3ae 100644 --- a/compute_instances.tf +++ b/compute_instances.tf @@ -87,8 +87,8 @@ resource "openstack_compute_instance_v2" "controller" { key_pair = resource.openstack_compute_keypair_v2.keypair.name image_name = var.multinode_image config_drive = true - #user_data = file("templates/userdata.cfg.tpl") - user_data = "${concat(file("templates/userdata.cfg.tpl"),["ssh_authorized_keys","${ var.ssh_authorized_keys }"])}" + user_data = file("templates/userdata.cfg.tpl") + #user_data = "${concat([file("templates/userdata.cfg.tpl")],["ssh_authorized_keys","${ var.ssh_authorized_keys }"])}" count = var.controller_count network { From 8248634e0afbb25c259835bb81cfd9dd5093d016 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 17:43:22 +0000 Subject: [PATCH 051/102] Converted userdata into a template for ssh keys. --- compute_instances.tf | 2 -- multinode-app.yml | 5 +++++ templates/{userdata.cfg.tpl => userdata.cfg.tpl.j2} | 3 +++ terraform.tfvars.j2 | 4 ---- 4 files changed, 8 insertions(+), 6 deletions(-) rename templates/{userdata.cfg.tpl => userdata.cfg.tpl.j2} (58%) diff --git a/compute_instances.tf b/compute_instances.tf index c5ad3ae..a8db2c4 100644 --- a/compute_instances.tf +++ b/compute_instances.tf @@ -88,8 +88,6 @@ resource "openstack_compute_instance_v2" "controller" { image_name = var.multinode_image config_drive = true user_data = file("templates/userdata.cfg.tpl") - #user_data = "${concat([file("templates/userdata.cfg.tpl")],["ssh_authorized_keys","${ var.ssh_authorized_keys }"])}" - count = var.controller_count network { name = var.multinode_vm_network diff --git a/multinode-app.yml b/multinode-app.yml index 28a46f2..28eaa63 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -13,6 +13,11 @@ template: src: terraform.tfvars.j2 dest: "{{ playbook_dir }}/terraform.tfvars" + + - name: Template Terraform userdata.cfg.tpl files into project template directory + template: + src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" + dest: "{{ playbook_dir }}/userdata.cfg.tpl" # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group diff --git a/templates/userdata.cfg.tpl b/templates/userdata.cfg.tpl.j2 similarity index 58% rename from templates/userdata.cfg.tpl rename to templates/userdata.cfg.tpl.j2 index 63e65db..faf8726 100644 --- a/templates/userdata.cfg.tpl +++ b/templates/userdata.cfg.tpl.j2 @@ -7,3 +7,6 @@ packages: - git - vim - tmux +ssh_authorized_keys: + - "{{ cluster_deploy_ssh_public_key }}" + - "{{ cluster_user_ssh_public_key }}" \ No newline at end of file diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index b318fea..c614e16 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -17,10 +17,6 @@ controller_count = "3" compute_disk_size = 100 controller_disk_size = 100 -ssh_authorized_keys: - - "{{ cluster_deploy_ssh_public_key }}" - - "{{ cluster_user_ssh_public_key }}" - ssh_public_key = "{{ cluster_user_ssh_public_key }}" ssh_user = "cloud-user" From 5aea5ab00eb06fd0c315900dd73b35156da13d44 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 17:47:13 +0000 Subject: [PATCH 052/102] Amend directory typo. --- multinode-app.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index 28eaa63..cdb5351 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -17,7 +17,7 @@ - name: Template Terraform userdata.cfg.tpl files into project template directory template: src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" - dest: "{{ playbook_dir }}/userdata.cfg.tpl" + dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group From 5bdbcdb764800c8ba8666ec9ba49dbe35b80abde Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 8 Jan 2024 17:51:57 +0000 Subject: [PATCH 053/102] Comment out ssh key copy. --- group_vars/openstack.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index d122649..14b71f8 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -36,4 +36,4 @@ tf_files: [] # - volumes.tf # - terraform.tfvars -cluster_deploy_ssh_public_key: "{{cluster_user_ssh_public_key}}" \ No newline at end of file +#cluster_deploy_ssh_public_key: "{{cluster_user_ssh_public_key}}" \ No newline at end of file From 00945476212e0b2f398cc58ca417ae4721768942 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 10:49:29 +0000 Subject: [PATCH 054/102] Create and add ansible ssh key so it can run in runner. --- ansible/vars/defaults.yml | 4 ++-- group_vars/openstack.yml | 3 ++- multinode-app.yml | 11 ++++++++--- templates/userdata.cfg.tpl.j2 | 3 ++- 4 files changed, 14 insertions(+), 7 deletions(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index c61cb2d..e30a21c 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -16,9 +16,9 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" -ssh_key_path: +#ssh_key_path: -vxlan_vni: +#vxlan_vni: root_domain: sms-lab.cloud diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 14b71f8..cd5eb3e 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -36,4 +36,5 @@ tf_files: [] # - volumes.tf # - terraform.tfvars -#cluster_deploy_ssh_public_key: "{{cluster_user_ssh_public_key}}" \ No newline at end of file +# Assign the ansible ssh public key from the ansible runner's generated ssh key +cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', '{{ playbook_dir }}/ssh_key.pub') }}" \ No newline at end of file diff --git a/multinode-app.yml b/multinode-app.yml index cdb5351..a567ff6 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -6,8 +6,9 @@ debug: msg: "{{ playbook_dir }}" -# - name: Generate SSH Key -# command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" + - name: Generate SSH Key + command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" + ssh_key_path: "{{ playbook_dir }}" - name: Template Terraform files into project directory template: @@ -35,4 +36,8 @@ - name: Show Playbook Directory debug: - msg: "{{ playbook_dir }}" \ No newline at end of file + msg: "{{ playbook_dir }}" + +# Import the playbook to start configuring the multi-node hosts. +- name: Configure hosts and deploy ansible + import_playbook: ansible/configure-hosts.yml diff --git a/templates/userdata.cfg.tpl.j2 b/templates/userdata.cfg.tpl.j2 index faf8726..67c70e5 100644 --- a/templates/userdata.cfg.tpl.j2 +++ b/templates/userdata.cfg.tpl.j2 @@ -9,4 +9,5 @@ packages: - tmux ssh_authorized_keys: - "{{ cluster_deploy_ssh_public_key }}" - - "{{ cluster_user_ssh_public_key }}" \ No newline at end of file + - "{{ cluster_user_ssh_public_key }}" + - "{{ cluster_ansible_ssh_public_key }}" \ No newline at end of file From 021d3eb64fd69a2d6662a0776a08584763897d89 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 10:54:03 +0000 Subject: [PATCH 055/102] Correct variable output. --- multinode-app.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index a567ff6..631071a 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -8,7 +8,8 @@ - name: Generate SSH Key command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" - ssh_key_path: "{{ playbook_dir }}" + vars: + ssh_key_path: "{{ playbook_dir }}" - name: Template Terraform files into project directory template: From 4c7f736a4b60a6f39c6f9d4a8273f9805e854a0b Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 11:15:05 +0000 Subject: [PATCH 056/102] Configure the inventory and install ansible galaxy. --- ansible/ansible.cfg | 2 +- multinode-app.yml | 6 +++++- roles/cluster_infra/templates/terraform.tfvars.j2 | 6 ++---- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 39be919..8a8ec35 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -5,7 +5,7 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False -roles_path = ../roles +inventory = inventory.yml [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file diff --git a/multinode-app.yml b/multinode-app.yml index 631071a..4813dff 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -39,6 +39,10 @@ debug: msg: "{{ playbook_dir }}" +# Install the ansible requirements +- name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml + # Import the playbook to start configuring the multi-node hosts. - name: Configure hosts and deploy ansible - import_playbook: ansible/configure-hosts.yml + import_playbook: ansible/configure-hosts.yml \ No newline at end of file diff --git a/roles/cluster_infra/templates/terraform.tfvars.j2 b/roles/cluster_infra/templates/terraform.tfvars.j2 index 0115a10..f63b063 100644 --- a/roles/cluster_infra/templates/terraform.tfvars.j2 +++ b/roles/cluster_infra/templates/terraform.tfvars.j2 @@ -8,7 +8,7 @@ seed_vm_flavor = "general.v1.small" seed_disk_size = 100 multinode_flavor = "general.v1.medium" -multinode_image = "Rocky9-lvm" +multinode_image = "Ubuntu-22.04-lvm" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" @@ -18,7 +18,7 @@ compute_disk_size = 100 controller_disk_size = 100 ssh_public_key = "~/.ssh/id_ed25519.pub" -ssh_user = "cloud-user" +ssh_user = "ubuntu" storage_count = "3" storage_flavor = "general.v1.small" @@ -27,5 +27,3 @@ storage_disk_size = 100 deploy_wazuh = true infra_vm_flavor = "general.v1.small" infra_vm_disk_size = 100 - -EOF \ No newline at end of file From 06fdbd7d5761d712062752a8a49a86422919d836 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 11:32:46 +0000 Subject: [PATCH 057/102] Run command through localhost. --- multinode-app.yml | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 4813dff..b91a198 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -39,9 +39,11 @@ debug: msg: "{{ playbook_dir }}" -# Install the ansible requirements -- name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml +- hosts: localhost + tasks: + # Install the ansible requirements + - name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml # Import the playbook to start configuring the multi-node hosts. - name: Configure hosts and deploy ansible From 3657300fa27745995eb6f6982f0a520e021261e7 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 11:38:06 +0000 Subject: [PATCH 058/102] Merge requirements. --- requirements.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/requirements.yml b/requirements.yml index fb396fb..00553a0 100644 --- a/requirements.yml +++ b/requirements.yml @@ -1,4 +1,8 @@ +--- collections: - name: https://github.com/stackhpc/ansible-collection-terraform type: git - version: 8c7acce4538aab8c0e928972155a2ccb5cb1b2a1 \ No newline at end of file + version: 8c7acce4538aab8c0e928972155a2ccb5cb1b2a1 + - name: cloud.terraform +roles: + - src: mrlesmithjr.manage_lvm \ No newline at end of file From 6a1c393633992c411db20b5a94133a5f2e594f27 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 11:44:20 +0000 Subject: [PATCH 059/102] Move ssh var key definition to main playbook. --- group_vars/openstack.yml | 1 - multinode-app.yml | 1 + 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index cd5eb3e..8e2d5dd 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -37,4 +37,3 @@ tf_files: [] # - terraform.tfvars # Assign the ansible ssh public key from the ansible runner's generated ssh key -cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', '{{ playbook_dir }}/ssh_key.pub') }}" \ No newline at end of file diff --git a/multinode-app.yml b/multinode-app.yml index b91a198..84719a7 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -10,6 +10,7 @@ command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" vars: ssh_key_path: "{{ playbook_dir }}" + cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', '{{ playbook_dir }}/ssh_key.pub') }}" - name: Template Terraform files into project directory template: From 68159d27608532cb8397b4b1bdaf59df4399f218 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 11:56:16 +0000 Subject: [PATCH 060/102] Edit and remove nested template expressions. --- multinode-app.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index 84719a7..922de9c 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -10,7 +10,7 @@ command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" vars: ssh_key_path: "{{ playbook_dir }}" - cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', '{{ playbook_dir }}/ssh_key.pub') }}" + cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', playbook_dir + '/ssh_key.pub') }}" - name: Template Terraform files into project directory template: From dd8874c4832f61a088e8edbd11db2fb56b8539df Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 12:03:09 +0000 Subject: [PATCH 061/102] Make ssh variables for all hosts. --- multinode-app.yml | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 922de9c..d665796 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -8,10 +8,14 @@ - name: Generate SSH Key command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" - vars: - ssh_key_path: "{{ playbook_dir }}" - cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', playbook_dir + '/ssh_key.pub') }}" +- hosts: all + vars: + ssh_key_path: "{{ playbook_dir }}" + cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', playbook_dir + '/ssh_key.pub') }}" + +- hosts: localhost + tasks: - name: Template Terraform files into project directory template: src: terraform.tfvars.j2 @@ -22,6 +26,8 @@ src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" + + # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group - hosts: openstack From e0c9720ab2e339606cbfbdf3b52fb20b5acbd494 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 13:57:03 +0000 Subject: [PATCH 062/102] SSH Key setup for Multinode Ansible. --- ansible/vars/defaults.yml | 2 +- multinode-app.yml | 10 ---------- 2 files changed, 1 insertion(+), 11 deletions(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index e30a21c..34c30a3 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -16,7 +16,7 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" -#ssh_key_path: +ssh_key_path: "{{ cluster_ssh_private_key_file }}" #vxlan_vni: diff --git a/multinode-app.yml b/multinode-app.yml index d665796..4717d20 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -6,16 +6,6 @@ debug: msg: "{{ playbook_dir }}" - - name: Generate SSH Key - command: ssh-keygen -t rsa -b 4096 -f "{{ playbook_dir }}/ssh_key" -q -N "" - -- hosts: all - vars: - ssh_key_path: "{{ playbook_dir }}" - cluster_ansible_ssh_public_key: "{{ lookup('ssh_key', playbook_dir + '/ssh_key.pub') }}" - -- hosts: localhost - tasks: - name: Template Terraform files into project directory template: src: terraform.tfvars.j2 From b15fccbd59aece3eb584a62a18ae0bbf6eaf9c45 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 13:59:46 +0000 Subject: [PATCH 063/102] Variable removal amendment. --- templates/userdata.cfg.tpl.j2 | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/templates/userdata.cfg.tpl.j2 b/templates/userdata.cfg.tpl.j2 index 67c70e5..faf8726 100644 --- a/templates/userdata.cfg.tpl.j2 +++ b/templates/userdata.cfg.tpl.j2 @@ -9,5 +9,4 @@ packages: - tmux ssh_authorized_keys: - "{{ cluster_deploy_ssh_public_key }}" - - "{{ cluster_user_ssh_public_key }}" - - "{{ cluster_ansible_ssh_public_key }}" \ No newline at end of file + - "{{ cluster_user_ssh_public_key }}" \ No newline at end of file From 4f89a78e4a98538fe4199449026cba4e4ed0bca0 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 14:41:09 +0000 Subject: [PATCH 064/102] Changed MN flavour and ssh user username. --- group_vars/openstack.yml | 3 ++- terraform.tfvars.j2 | 4 ++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 8e2d5dd..bdc3759 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -24,7 +24,8 @@ terraform_project_path: "{{ playbook_dir }}" terraform_state: "{{ cluster_state | default('present') }}" # The user that should be used to SSH to the cluster hosts -cluster_ssh_user: cloud-user +cluster_ssh_user: ubuntu +ssh_user: ubuntu tf_files: [] #- outputs.tf diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index c614e16..543452d 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -8,7 +8,7 @@ seed_vm_flavor = "general.v1.small" seed_disk_size = 100 multinode_flavor = "general.v1.medium" -multinode_image = "Rocky9-lvm" +multinode_image = "Ubuntu-22.04-lvm" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" @@ -18,7 +18,7 @@ compute_disk_size = 100 controller_disk_size = 100 ssh_public_key = "{{ cluster_user_ssh_public_key }}" -ssh_user = "cloud-user" +ssh_user = "ubuntu" storage_count = "3" storage_flavor = "general.v1.small" From c0f733a3d780310137074b4899ff6f0bfbf4738f Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 14:49:47 +0000 Subject: [PATCH 065/102] Link some variables back to the previous directory. --- ansible/ansible.cfg | 2 ++ ansible/group_vars | 1 + 2 files changed, 3 insertions(+) create mode 120000 ansible/group_vars diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 8a8ec35..3c4a5d6 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -6,6 +6,8 @@ pipelining = True forks = 30 deprecation_warnings=False inventory = inventory.yml +roles_path = ../roles + [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file diff --git a/ansible/group_vars b/ansible/group_vars new file mode 120000 index 0000000..d90e132 --- /dev/null +++ b/ansible/group_vars @@ -0,0 +1 @@ +group_vars \ No newline at end of file From ea11995965583b577be44ffd3f322b9d8de6f78b Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:02:48 +0000 Subject: [PATCH 066/102] Fix symlink --- ansible/openstack.yml | 1 + 1 file changed, 1 insertion(+) create mode 120000 ansible/openstack.yml diff --git a/ansible/openstack.yml b/ansible/openstack.yml new file mode 120000 index 0000000..7d7fbcb --- /dev/null +++ b/ansible/openstack.yml @@ -0,0 +1 @@ +group_vars/openstack.yml \ No newline at end of file From 4fab3af06fa94955a121fe36f494f001d9411daa Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:08:38 +0000 Subject: [PATCH 067/102] Remove symlinks. --- ansible/group_vars | 1 - ansible/openstack.yml | 1 - 2 files changed, 2 deletions(-) delete mode 120000 ansible/group_vars delete mode 120000 ansible/openstack.yml diff --git a/ansible/group_vars b/ansible/group_vars deleted file mode 120000 index d90e132..0000000 --- a/ansible/group_vars +++ /dev/null @@ -1 +0,0 @@ -group_vars \ No newline at end of file diff --git a/ansible/openstack.yml b/ansible/openstack.yml deleted file mode 120000 index 7d7fbcb..0000000 --- a/ansible/openstack.yml +++ /dev/null @@ -1 +0,0 @@ -group_vars/openstack.yml \ No newline at end of file From a3e7b2da3c641477ec850eedfa70dd65d15fcc78 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:12:49 +0000 Subject: [PATCH 068/102] add ansible_user to vars. --- ansible/vars/defaults.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index 34c30a3..c4440ad 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -17,7 +17,7 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" ssh_key_path: "{{ cluster_ssh_private_key_file }}" - +ansible_user: ubuntu #vxlan_vni: root_domain: sms-lab.cloud From 57756ddcbaeff30953d35eb2e9a77cc0b5109fc0 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:24:30 +0000 Subject: [PATCH 069/102] Variable set with quote marks. --- ansible/vars/defaults.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index c4440ad..4e0237f 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -17,7 +17,7 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" ssh_key_path: "{{ cluster_ssh_private_key_file }}" -ansible_user: ubuntu +ansible_user: 'ubuntu' #vxlan_vni: root_domain: sms-lab.cloud From bde16cd723fc2d7ea352ee4988ebbe38dedea0dc Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:54:21 +0000 Subject: [PATCH 070/102] Giving a host to playbook. --- multinode-app.yml | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 4717d20..f35d399 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -17,31 +17,31 @@ dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" - # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group - hosts: openstack roles: - cluster_infra -# Write the outputs as the final task - hosts: localhost - tasks: + tasks: + # Install the ansible requirements + - name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml + when: cluster_state != "absent" + + # Import the playbook to start configuring the multi-node hosts. + - name: Configure hosts and deploy ansible + import_playbook: ansible/configure-hosts.yml + when: cluster_state != "absent" + - debug: var=outputs vars: outputs: cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" - + when: cluster_state != "absent" + - name: Show Playbook Directory debug: - msg: "{{ playbook_dir }}" - -- hosts: localhost - tasks: - # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml - -# Import the playbook to start configuring the multi-node hosts. -- name: Configure hosts and deploy ansible - import_playbook: ansible/configure-hosts.yml \ No newline at end of file + msg: "{{ playbook_dir }}" + when: cluster_state != "absent" From ab7e9039a5bcbcba22e719748d8ede3a3e5b08f7 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 15:58:59 +0000 Subject: [PATCH 071/102] Create block for tasks. --- multinode-app.yml | 36 +++++++++++++++++------------------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index f35d399..218aa7f 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -25,23 +25,21 @@ - hosts: localhost tasks: - # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml - when: cluster_state != "absent" - - # Import the playbook to start configuring the multi-node hosts. - - name: Configure hosts and deploy ansible - import_playbook: ansible/configure-hosts.yml - when: cluster_state != "absent" - - - debug: var=outputs - vars: - outputs: - cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" - when: cluster_state != "absent" - - - name: Show Playbook Directory - debug: - msg: "{{ playbook_dir }}" + - block: + # Install the ansible requirements + - name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml + + # Import the playbook to start configuring the multi-node hosts. + - name: Configure hosts and deploy ansible + import_playbook: ansible/configure-hosts.yml + + - debug: var=outputs + vars: + outputs: + cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" + + - name: Show Playbook Directory + debug: + msg: "{{ playbook_dir }}" when: cluster_state != "absent" From c8ac2499e7128f302aa10b43a9ef1f486622af1e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 16:03:05 +0000 Subject: [PATCH 072/102] Comment out task test. --- multinode-app.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 218aa7f..1e81d0b 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -31,8 +31,8 @@ command: ansible-galaxy install -r ansible/requirements.yml # Import the playbook to start configuring the multi-node hosts. - - name: Configure hosts and deploy ansible - import_playbook: ansible/configure-hosts.yml +# - name: Configure hosts and deploy ansible +# import_playbook: ansible/configure-hosts.yml - debug: var=outputs vars: From b0f2932d5ec1299da05807f1be8de4ec46def0e1 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 16:11:36 +0000 Subject: [PATCH 073/102] Debug Groups variable. --- multinode-app.yml | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 1e81d0b..a2d1b8f 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -25,21 +25,21 @@ - hosts: localhost tasks: - - block: +# - block: # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml +# - name: Install ansible requirements +# command: ansible-galaxy install -r ansible/requirements.yml - # Import the playbook to start configuring the multi-node hosts. -# - name: Configure hosts and deploy ansible -# import_playbook: ansible/configure-hosts.yml + # Import the playbook to start configuring the multi-node hosts. +#- name: Configure hosts and deploy ansible +# import_playbook: ansible/configure-hosts.yml - - debug: var=outputs - vars: - outputs: - cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" +# - debug: var=outputs +# vars: +# outputs: +# cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" - - name: Show Playbook Directory + - name: Debug groups debug: - msg: "{{ playbook_dir }}" - when: cluster_state != "absent" + msg: "{{ groups | to_yaml }}" +# when: cluster_state != "absent" From 98d6872e134ad6c437d35c6787f9cfe6520c371a Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 16:28:54 +0000 Subject: [PATCH 074/102] Test new group structure. --- multinode-app.yml | 5 +++++ outputs.tf | 21 ++++++++++++++------- 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index a2d1b8f..7c90ecc 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -43,3 +43,8 @@ debug: msg: "{{ groups | to_yaml }}" # when: cluster_state != "absent" + +- hosts: multinode_ansible_control + tasks: + - name: Test hostname + command: hostname \ No newline at end of file diff --git a/outputs.tf b/outputs.tf index 38ff8fa..06cf68b 100644 --- a/outputs.tf +++ b/outputs.tf @@ -55,15 +55,22 @@ resource "local_file" "admin_networks" { output "cluster_nodes" { description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" - value = flatten([ - for node in openstack_compute_instance_v2.compute: { - name = node.name - ip = node.access_ip_v4 - groups = ["compute"] - } - ]) + value = { + name = openstack_compute_instance_v2.ansible_control.name + ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 + groups = ["multinode_ansible_control"] + } } +# flatten([ +# for node in openstack_compute_instance_v2.compute: { +# name = node.name +# ip = node.access_ip_v4 +# groups = ["compute"] +# } +# ]) +# } + resource "local_file" "openstack_inventory" { content = templatefile( "${path.module}/templates/openstack-inventory.tpl", From 17c0ca2b0a45db77626220bfe3a3fba344f533a8 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 16:31:28 +0000 Subject: [PATCH 075/102] Tupple list amend. --- outputs.tf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/outputs.tf b/outputs.tf index 06cf68b..6b8c072 100644 --- a/outputs.tf +++ b/outputs.tf @@ -55,11 +55,11 @@ resource "local_file" "admin_networks" { output "cluster_nodes" { description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" - value = { + value = [{ name = openstack_compute_instance_v2.ansible_control.name ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 groups = ["multinode_ansible_control"] - } + }] } # flatten([ From 69846b4c702d50716200c7e67d5545bf1c8f6239 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 16:59:58 +0000 Subject: [PATCH 076/102] Add command line playbook deployment. --- multinode-app.yml | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 7c90ecc..c7d09a7 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -25,10 +25,13 @@ - hosts: localhost tasks: -# - block: + - block: # Install the ansible requirements -# - name: Install ansible requirements -# command: ansible-galaxy install -r ansible/requirements.yml + - name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml + + - name: Deploy ansible playbook manually + command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml # Import the playbook to start configuring the multi-node hosts. #- name: Configure hosts and deploy ansible @@ -44,7 +47,7 @@ msg: "{{ groups | to_yaml }}" # when: cluster_state != "absent" -- hosts: multinode_ansible_control - tasks: - - name: Test hostname - command: hostname \ No newline at end of file +# - hosts: multinode_ansible_control +# tasks: +# - name: Test hostname +# command: hostname \ No newline at end of file From 1dce1b57a79efdac6069ba71babe858f6e87b5bf Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 17:03:13 +0000 Subject: [PATCH 077/102] Amend indentations --- multinode-app.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index c7d09a7..c4c455a 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -27,8 +27,8 @@ tasks: - block: # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml + - name: Install ansible requirements + command: ansible-galaxy install -r ansible/requirements.yml - name: Deploy ansible playbook manually command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml From 879e67d25f9f98714e01e9f29e0ee5f24e7eb800 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 9 Jan 2024 17:18:01 +0000 Subject: [PATCH 078/102] Provide Terraform Vars for playbook. --- multinode-app.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/multinode-app.yml b/multinode-app.yml index c4c455a..8527e0a 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -32,6 +32,10 @@ - name: Deploy ansible playbook manually command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml + vars: + terraform_binary_directory: "{{ playbook_dir }}/../bin" + terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" + terraform_project_path: "{{ playbook_dir }}" # Import the playbook to start configuring the multi-node hosts. #- name: Configure hosts and deploy ansible From d9d60bd903481cf19486942cd008c81cc0b01379 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 10:55:10 +0000 Subject: [PATCH 079/102] Changed output and converted resources into cluster_nodes output. --- outputs.tf | 137 +++++++++++++++++++++++++++++++++++++---------------- 1 file changed, 96 insertions(+), 41 deletions(-) diff --git a/outputs.tf b/outputs.tf index 6b8c072..e8f5430 100644 --- a/outputs.tf +++ b/outputs.tf @@ -53,19 +53,19 @@ resource "local_file" "admin_networks" { file_permission = "0644" } -output "cluster_nodes" { - description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" - value = [{ - name = openstack_compute_instance_v2.ansible_control.name - ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 - groups = ["multinode_ansible_control"] - }] -} +# output "cluster_nodes" { +# description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" +# value = [{ +# name = openstack_compute_instance_v2.ansible_control.name +# ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 +# groups = ["multinode_ansible_control"] +# }] +# } -# flatten([ -# for node in openstack_compute_instance_v2.compute: { -# name = node.name -# ip = node.access_ip_v4 +# flatten([ +# for node in openstack_compute_instance_v2.compute: { +# name = node.name +# ip = node.access_ip_v4 # groups = ["compute"] # } # ]) @@ -97,38 +97,93 @@ resource "local_file" "deploy_openstack" { file_permission = "0755" } -resource "ansible_host" "control_host" { - name = openstack_compute_instance_v2.ansible_control.access_ip_v4 - groups = ["ansible_control"] +output "cluster_nodes" { + description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" + value = concat( + [ + { + name = openstack_compute_instance_v2.ansible_control.name + ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 + groups = ["ansible_control"] + variables = { + ansible_user = var.ssh_user + } + } + ], + flatten([ + for node in openstack_compute_instance_v2.compute: { + name = node.name + ip = node.access_ip_v4 + groups = ["compute"] + variables = { + ansible_user = var.ssh_user + } + } + ]), + flatten([ + for node in openstack_compute_instance_v2.controller: { + name = node.name + ip = node.access_ip_v4 + groups = ["controllers"] + variables = { + ansible_user = var.ssh_user + } + } + ]), + [{ + name = openstack_compute_instance_v2.seed.name + ip = openstack_compute_instance_v2.seed.access_ip_v4 + groups = ["seed"] + variables = { + ansible_user = var.ssh_user + } + }], + flatten([ + for node in openstack_compute_instance_v2.storage: { + name = node.name + ip = node.access_ip_v4 + groups = ["storage"] + variables = { + ansible_user = var.ssh_user + } + } + ]) + ) } -resource "ansible_host" "compute_host" { - for_each = { for host in openstack_compute_instance_v2.compute : host.name => host.access_ip_v4 } - name = each.value - groups = ["compute"] -} +# For Backup +# resource "ansible_host" "control_host" { +# name = openstack_compute_instance_v2.ansible_control.access_ip_v4 +# groups = ["ansible_control"] +# } -resource "ansible_host" "controllers_hosts" { - for_each = { for host in openstack_compute_instance_v2.controller : host.name => host.access_ip_v4 } - name = each.value - groups = ["controllers"] -} +# resource "ansible_host" "compute_host" { +# for_each = { for host in openstack_compute_instance_v2.compute : host.name => host.access_ip_v4 } +# name = each.value +# groups = ["compute"] +# } -resource "ansible_host" "seed_host" { - name = openstack_compute_instance_v2.seed.access_ip_v4 - groups = ["seed"] -} +# resource "ansible_host" "controllers_hosts" { +# for_each = { for host in openstack_compute_instance_v2.controller : host.name => host.access_ip_v4 } +# name = each.value +# groups = ["controllers"] +# } -resource "ansible_host" "storage" { - for_each = { for host in openstack_compute_instance_v2.storage : host.name => host.access_ip_v4 } - name = each.value - groups = ["storage"] -} +# resource "ansible_host" "seed_host" { +# name = openstack_compute_instance_v2.seed.access_ip_v4 +# groups = ["seed"] +# } -resource "ansible_group" "cluster_group" { - name = "cluster" - children = ["compute", "ansible_control", "controllers", "seed", "storage"] - variables = { - ansible_user = var.ssh_user - } -} +# resource "ansible_host" "storage" { +# for_each = { for host in openstack_compute_instance_v2.storage : host.name => host.access_ip_v4 } +# name = each.value +# groups = ["storage"] +# } + +# resource "ansible_group" "cluster_group" { +# name = "cluster" +# children = ["compute", "ansible_control", "controllers", "seed", "storage"] +# variables = { +# ansible_user = var.ssh_user +# } +# } From 8dc1d58135b7b6f11edcb5ed7c9803d30e3a3b0d Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 10:58:38 +0000 Subject: [PATCH 080/102] Amend playbook vars. --- multinode-app.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 8527e0a..3d649ad 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -32,10 +32,10 @@ - name: Deploy ansible playbook manually command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml - vars: - terraform_binary_directory: "{{ playbook_dir }}/../bin" - terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" - terraform_project_path: "{{ playbook_dir }}" + vars: + terraform_binary_directory: "{{ playbook_dir }}/../bin" + terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" + terraform_project_path: "{{ playbook_dir }}" # Import the playbook to start configuring the multi-node hosts. #- name: Configure hosts and deploy ansible From fa6fffca7012f6915cd99232a0c4f067f5c6e80e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 11:13:10 +0000 Subject: [PATCH 081/102] Change to import playbook. --- multinode-app.yml | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 3d649ad..c65fd74 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -30,16 +30,12 @@ - name: Install ansible requirements command: ansible-galaxy install -r ansible/requirements.yml - - name: Deploy ansible playbook manually - command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml - vars: - terraform_binary_directory: "{{ playbook_dir }}/../bin" - terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" - terraform_project_path: "{{ playbook_dir }}" - - # Import the playbook to start configuring the multi-node hosts. -#- name: Configure hosts and deploy ansible -# import_playbook: ansible/configure-hosts.yml + # - name: Deploy ansible playbook manually + # command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml + # vars: + # terraform_binary_directory: "{{ playbook_dir }}/../bin" + # terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" + # terraform_project_path: "{{ playbook_dir }}" # - debug: var=outputs # vars: @@ -51,6 +47,11 @@ msg: "{{ groups | to_yaml }}" # when: cluster_state != "absent" +# Import the playbook to start configuring the multi-node hosts. +- name: Configure hosts and deploy ansible + import_playbook: ansible/configure-hosts.yml + + # - hosts: multinode_ansible_control # tasks: # - name: Test hostname From c8ba8d0cb8a3dce7ea20ee1ff1ecd92244e52cab Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 11:44:55 +0000 Subject: [PATCH 082/102] Install ansible.posix --- multinode-app.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index c65fd74..053311f 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -28,7 +28,7 @@ - block: # Install the ansible requirements - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml + command: ansible-galaxy collection install ansible.posix && ansible-galaxy install -r ansible/requirements.yml # - name: Deploy ansible playbook manually # command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml From c0dff503ae5abfc759427418c54c99e285a05c22 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 11:53:41 +0000 Subject: [PATCH 083/102] Amended playbook for installing ansible galaxy requirements. --- multinode-app.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/multinode-app.yml b/multinode-app.yml index 053311f..1e0e437 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -28,7 +28,11 @@ - block: # Install the ansible requirements - name: Install ansible requirements - command: ansible-galaxy collection install ansible.posix && ansible-galaxy install -r ansible/requirements.yml + command: ansible-galaxy install -r ansible/requirements.yml + + # Install the ansible requirements + - name: Install ansible requirements + command: ansible-galaxy collection install ansible.posix # - name: Deploy ansible playbook manually # command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml From ceabfe211aba5a9f243568d9a29e4a65d2367f3e Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 12:07:22 +0000 Subject: [PATCH 084/102] Remove Ansible-galaxy install as it should be done by the requirements. --- multinode-app.yml | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index 1e0e437..152210a 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -25,14 +25,19 @@ - hosts: localhost tasks: - - block: - # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy install -r ansible/requirements.yml - - # Install the ansible requirements - - name: Install ansible requirements - command: ansible-galaxy collection install ansible.posix + # - block: + # # Install the ansible requirements + # - name: Install ansible posix + # command: ansible-galaxy collection install ansible.posix + + # # Install the ansible requirements + # - name: Install ansible community general + # command: ansible-galaxy collection install community.general + + # # Install the ansible requirements + # - name: Install ansible requirements + # command: ansible-galaxy install -r ansible/requirements.yml + # - name: Deploy ansible playbook manually # command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml From a40845e63c5663f27777e7aabe42609176b7b316 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 10 Jan 2024 12:08:34 +0000 Subject: [PATCH 085/102] This is a combination of 5 commits. --- ansible/ansible.cfg | 2 +- ansible/vars/defaults.yml | 4 +- group_vars/openstack.yml | 4 +- multinode-app.yml | 35 +++++++++--- requirements.yml | 1 + .../templates/terraform.tfvars.j2 | 2 +- terraform.tfvars.j2 | 4 +- ui-meta/multinode-appliance.yml | 53 +++++++++++++++---- versions.tf | 8 +-- 9 files changed, 83 insertions(+), 30 deletions(-) diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 3c4a5d6..97f42db 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -5,7 +5,7 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False -inventory = inventory.yml +#inventory = inventory.yml roles_path = ../roles diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index 4e0237f..d6f11b4 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -2,7 +2,7 @@ src_directory: "{{ ansible_env.HOME }}/src" kayobe_config_repo: https://github.com/stackhpc/stackhpc-kayobe-config.git -kayobe_config_version: stackhpc/yoga +kayobe_config_version: Azimuth-MN-Workaround #stackhpc/yoga kayobe_config_name: kayobe-config kayobe_config_environment: ci-multinode @@ -17,7 +17,7 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" ssh_key_path: "{{ cluster_ssh_private_key_file }}" -ansible_user: 'ubuntu' + #vxlan_vni: root_domain: sms-lab.cloud diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index bdc3759..5871168 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -24,8 +24,8 @@ terraform_project_path: "{{ playbook_dir }}" terraform_state: "{{ cluster_state | default('present') }}" # The user that should be used to SSH to the cluster hosts -cluster_ssh_user: ubuntu -ssh_user: ubuntu +cluster_ssh_user: cloud-user +ssh_user: cloud-user tf_files: [] #- outputs.tf diff --git a/multinode-app.yml b/multinode-app.yml index 152210a..bec94dd 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -16,7 +16,6 @@ src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" - # Provision the infrastructure # The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group - hosts: openstack @@ -25,6 +24,15 @@ - hosts: localhost tasks: + # Check whether an ans_vlt_pwd variable is defined and if so, save it into a file called '~/vault.password'. If it doesn't exist, create a the '~/vault.password' file with ans_vlt_pwd = "password_not_set" as the password. + - name: Create vault password file + vars: + ans_dflt: 'default_password' + ansible.builtin.copy: + content: "{{ ans_vlt_pwd | default( ans_dflt , true ) }}" + dest: "~/vault.password" + mode: 0600 + # - block: # # Install the ansible requirements # - name: Install ansible posix @@ -51,9 +59,9 @@ # outputs: # cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" - - name: Debug groups - debug: - msg: "{{ groups | to_yaml }}" + # - name: Debug groups + # debug: + # msg: "{{ groups | to_yaml }}" # when: cluster_state != "absent" # Import the playbook to start configuring the multi-node hosts. @@ -61,7 +69,20 @@ import_playbook: ansible/configure-hosts.yml -# - hosts: multinode_ansible_control +- hosts: ansible_control + vars: + ansible_pipelining: true + ansible_ssh_pipelining: true + tasks: + - name: Deploy OpenStack. + ansible.builtin.command: + cmd: "bash ~/deploy-openstack.sh" + +# - hosts: ansible_control +# vars: +# ansible_pipelining: true +# ansible_ssh_pipelining: true # tasks: -# - name: Test hostname -# command: hostname \ No newline at end of file +# - name: Deploy OpenStack. +# ansible.builtin.shell: +# cmd: "./deploy-openstack.sh" diff --git a/requirements.yml b/requirements.yml index 00553a0..71a93fe 100644 --- a/requirements.yml +++ b/requirements.yml @@ -4,5 +4,6 @@ collections: type: git version: 8c7acce4538aab8c0e928972155a2ccb5cb1b2a1 - name: cloud.terraform + - name: ansible.posix roles: - src: mrlesmithjr.manage_lvm \ No newline at end of file diff --git a/roles/cluster_infra/templates/terraform.tfvars.j2 b/roles/cluster_infra/templates/terraform.tfvars.j2 index f63b063..9777cd3 100644 --- a/roles/cluster_infra/templates/terraform.tfvars.j2 +++ b/roles/cluster_infra/templates/terraform.tfvars.j2 @@ -8,7 +8,7 @@ seed_vm_flavor = "general.v1.small" seed_disk_size = 100 multinode_flavor = "general.v1.medium" -multinode_image = "Ubuntu-22.04-lvm" +multinode_image = "rocky9-lvm" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 543452d..1d80a35 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -8,7 +8,7 @@ seed_vm_flavor = "general.v1.small" seed_disk_size = 100 multinode_flavor = "general.v1.medium" -multinode_image = "Ubuntu-22.04-lvm" +multinode_image = "rocky9-lvm" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" @@ -18,7 +18,7 @@ compute_disk_size = 100 controller_disk_size = 100 ssh_public_key = "{{ cluster_user_ssh_public_key }}" -ssh_user = "ubuntu" +ssh_user = "cloud-user" storage_count = "3" storage_flavor = "general.v1.small" diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml index 53c0601..3c212a4 100644 --- a/ui-meta/multinode-appliance.yml +++ b/ui-meta/multinode-appliance.yml @@ -11,14 +11,14 @@ logo:  # A list of parameters to be gathered from the user -parameters: +# parameters: # The name of the Ansible variable that will be populated with the parameter value. # This field is required. - - name: vxlan_vni + # - name: vxlan_vni # A human-readable name for the parameter. Defaults to the name if not given. - label: Set the VXLAN VNI value. + # label: Set the VXLAN VNI value. # An optional short description for the parameter. - description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + # description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. # The kind of the parameter. This field is required. # Valid values are: #  list @@ -44,14 +44,14 @@ parameters: #  The ID of a volume in the target tenancy. #  cloud.cluster #  The ID of another cluster in the target tenancy. - kind: "integer" + # kind: "integer" # Indicates whether the parameter is required. Defaults to true if not given. - required: true + # required: true # The default value value for the parameter. Defaults to null if not given, indicating no default. - default: null + # default: null # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. # Defaults to false if not given. - immutable: true + # immutable: true # Additional options for the parameter. The valid options depend on the kind of the parameter. # list # min_length: An optional minimum length for the list. @@ -63,9 +63,9 @@ parameters: #  pattern: An optional regular expression pattern to validate the string against. #  integer #  number - options: - min: 1 - max: 100000 + # options: + # min: 1 + # max: 100000 #  boolean # permanent: If true, indicates that the parameter cannot become false again once it has #  been set to true. Defaults to false if not given. @@ -82,6 +82,37 @@ parameters: # options: # min_ram: 1024 # min_disk: 10 + # secret: true + # confirm: true + +# A list of parameters to be gathered from the user +parameters: + - name: vxlan_vni + label: Set the VXLAN VNI value. + description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + kind: "integer" + required: true + default: null + immutable: true + options: + min: 1 + max: 100000 + + + - name: ans_vlt_pwd + # A human-readable name for the parameter. Defaults to the name if not given. + label: Provide the Ansible Vault password. + # An optional short description for the parameter. + description: Please provide the Ansible Vault password to enable the deployment of the cluster. + kind: "string" + required: false + #default: "password_not_set" + immutable: false + # Replace the characters of the parameter with asterisks in the UI. + options: + secret: true + confirm: true + #private: true #- name: backend_count # label: Backend node count diff --git a/versions.tf b/versions.tf index 74359a0..94ba957 100644 --- a/versions.tf +++ b/versions.tf @@ -5,9 +5,9 @@ terraform { source = "terraform-provider-openstack/openstack" version = "1.49.0" } - ansible = { - source = "ansible/ansible" - version = "1.1.0" - } + #ansible = { + # source = "ansible/ansible" + # version = "1.1.0" + #} } } From 5a7c94bf080cc91bffcf3c2683b9b0cf5cfdaeb7 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 17 Jan 2024 14:21:24 +0000 Subject: [PATCH 086/102] No Wazuh deploy. --- terraform.tfvars.j2 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 1d80a35..d889855 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -24,6 +24,6 @@ storage_count = "3" storage_flavor = "general.v1.small" storage_disk_size = 100 -deploy_wazuh = true -infra_vm_flavor = "general.v1.small" -infra_vm_disk_size = 100 \ No newline at end of file +deploy_wazuh = false +# infra_vm_flavor = "general.v1.small" +# infra_vm_disk_size = 100 \ No newline at end of file From 4519eab66af415b780f4cb5efaa67ecaf87ffc82 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 18 Jan 2024 17:36:30 +0000 Subject: [PATCH 087/102] Create infrastructure only option. --- multinode-app.yml | 5 +++++ ui-meta/multinode-appliance.yml | 11 +++++++++++ 2 files changed, 16 insertions(+) diff --git a/multinode-app.yml b/multinode-app.yml index bec94dd..a6ad26d 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -64,9 +64,12 @@ # msg: "{{ groups | to_yaml }}" # when: cluster_state != "absent" +# If openstack_deploy is true then continue if not end the playbook. + # Import the playbook to start configuring the multi-node hosts. - name: Configure hosts and deploy ansible import_playbook: ansible/configure-hosts.yml + when: openstack_deploy == true - hosts: ansible_control @@ -77,6 +80,8 @@ - name: Deploy OpenStack. ansible.builtin.command: cmd: "bash ~/deploy-openstack.sh" + when: openstack_deploy == true + # - hosts: ansible_control # vars: diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml index 3c212a4..0f3900c 100644 --- a/ui-meta/multinode-appliance.yml +++ b/ui-meta/multinode-appliance.yml @@ -113,6 +113,17 @@ parameters: secret: true confirm: true #private: true + + - name: openstack_deploy #Idealy I would like to turn this into a checkbox. + # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. + label: Deploy Infrastructure with OpenStack? #(True/False) + description: If you only wish to deploy the infrastructure with OpenStack select this option. + kind: "boolean" + default: false + required: false + options: + permanent: true + #- name: backend_count # label: Backend node count From 232ae60a9fca551fff05f03d1ecf57e556594a66 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 18 Jan 2024 17:43:38 +0000 Subject: [PATCH 088/102] Checkout the main ansible folder so that these changes are solely focused on infrastructure deployment. --- ansible/ansible.cfg | 3 --- ansible/vars/defaults.yml | 6 +++--- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 97f42db..35367c1 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -5,9 +5,6 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False -#inventory = inventory.yml -roles_path = ../roles - [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index d6f11b4..c61cb2d 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -2,7 +2,7 @@ src_directory: "{{ ansible_env.HOME }}/src" kayobe_config_repo: https://github.com/stackhpc/stackhpc-kayobe-config.git -kayobe_config_version: Azimuth-MN-Workaround #stackhpc/yoga +kayobe_config_version: stackhpc/yoga kayobe_config_name: kayobe-config kayobe_config_environment: ci-multinode @@ -16,9 +16,9 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" -ssh_key_path: "{{ cluster_ssh_private_key_file }}" +ssh_key_path: -#vxlan_vni: +vxlan_vni: root_domain: sms-lab.cloud From 6fa2086065ae664eaf4f691b14ae572fdec8aa2b Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 19 Jan 2024 14:57:07 +0000 Subject: [PATCH 089/102] Create a second App UI to deploy just the infrastructure as a test. --- ui-meta/multinode-appliance.yml | 11 -- ui-meta/multinode-infra-appliance.yml | 147 ++++++++++++++++++++++++++ 2 files changed, 147 insertions(+), 11 deletions(-) create mode 100644 ui-meta/multinode-infra-appliance.yml diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml index 0f3900c..3c212a4 100644 --- a/ui-meta/multinode-appliance.yml +++ b/ui-meta/multinode-appliance.yml @@ -113,17 +113,6 @@ parameters: secret: true confirm: true #private: true - - - name: openstack_deploy #Idealy I would like to turn this into a checkbox. - # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. - label: Deploy Infrastructure with OpenStack? #(True/False) - description: If you only wish to deploy the infrastructure with OpenStack select this option. - kind: "boolean" - default: false - required: false - options: - permanent: true - #- name: backend_count # label: Backend node count diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml new file mode 100644 index 0000000..a5af2a1 --- /dev/null +++ b/ui-meta/multinode-infra-appliance.yml @@ -0,0 +1,147 @@ +# The machine-readable name of the appliance +name: "multinode-infra" +# The human-readable label for the appliance +label: "Multinode Infrastructure Deployment" +# A short description of the appliance, rendered as-is +description: An appliance for deploying a multinode cluster on Azimuth with the option of deploying just the Infrastructure. +# The URL of the logo for the appliance +# This should be an HTTPS URL, because plain HTTP URLs will cause content warnings when Azimuth is served over HTTPS +# Alternatively, as shown here, a data URL can be used to encode the image directly +logo:  + +# A list of parameters to be gathered from the user +# parameters: + # The name of the Ansible variable that will be populated with the parameter value. + # This field is required. + # - name: vxlan_vni + # A human-readable name for the parameter. Defaults to the name if not given. + # label: Set the VXLAN VNI value. + # An optional short description for the parameter. + # description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + # The kind of the parameter. This field is required. + # Valid values are: + #  list + # A list of items. + # string + #  A string or something that can be coerced. + #  integer + #  An integer or a string that can be coerced. + #  number + #  Any number, i.e. an integer or a float, or a string that can be coerced. + #  boolean + # A boolean flag. + #  Valid values are: true/false, 1/0, "1"/"0", "true"/"false" and "yes"/"no". + #  choice + # A value from a set of choices. + #  cloud.size + # The ID of a size in the target tenancy. + #  cloud.machine + #  The ID of a machine in the target tenancy. + # cloud.ip + #  The ID of an external IP in the target tenancy. + #  cloud.volume + #  The ID of a volume in the target tenancy. + #  cloud.cluster + #  The ID of another cluster in the target tenancy. + # kind: "integer" + # Indicates whether the parameter is required. Defaults to true if not given. + # required: true + # The default value value for the parameter. Defaults to null if not given, indicating no default. + # default: null + # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. + # Defaults to false if not given. + # immutable: true + # Additional options for the parameter. The valid options depend on the kind of the parameter. + # list + # min_length: An optional minimum length for the list. + #  max_length: An optional maximum length for the list. + # item: An optional item validator, consisting of a kind and some options. + # string + # min_length: An optional minimum length for the string. + # max_length: An optional maximum length for the string. + #  pattern: An optional regular expression pattern to validate the string against. + #  integer + #  number + # options: + # min: 1 + # max: 100000 + #  boolean + # permanent: If true, indicates that the parameter cannot become false again once it has + #  been set to true. Defaults to false if not given. + #  choice + #  choices: The list of valid choices for the parameter. This field is required. + #  cloud.size + #  min_cpus: An optional minimum number of CPUs that the size must have. + #  min_ram: An optional minimum amount of RAM in MB that the size must have. + # min_disk: An optional minimum root disk size in GB that the size must have. + #  cloud.volume + #  min_size: An optional minimum size in GB for the volume. + #  cloud.cluster + # tag: An optional tag that the cluster must have. + # options: + # min_ram: 1024 + # min_disk: 10 + # secret: true + # confirm: true + +# A list of parameters to be gathered from the user +parameters: + - name: vxlan_vni + label: Set the VXLAN VNI value. + description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + kind: "integer" + required: true + default: null + immutable: true + options: + min: 1 + max: 100000 + + + - name: ans_vlt_pwd + # A human-readable name for the parameter. Defaults to the name if not given. + label: Provide the Ansible Vault password. + # An optional short description for the parameter. + description: Please provide the Ansible Vault password to enable the deployment of the cluster. + kind: "string" + required: false + #default: "password_not_set" + immutable: false + # Replace the characters of the parameter with asterisks in the UI. + options: + secret: true + confirm: true + #private: true + + - name: openstack_deploy #Idealy I would like to turn this into a checkbox. + # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. + label: Deploy Infrastructure with OpenStack? #(True/False) + description: If you only wish to deploy the infrastructure with OpenStack select this option. + kind: "boolean" + default: false + required: false + options: + permanent: true + + + #- name: backend_count + # label: Backend node count + # description: The number of backend nodes. + # kind: integer + # options: + # min: 1 + # default: 3 + + #- name: backend_flavor + # label: Backend node size + # description: The size to use for the backend nodes. + # kind: "cloud.size" + # immutable: true + # options: + # min_ram: 1024 + # min_disk: 10 + +# A template describing the usage of the appliance +# This is rendered in the "Cluster details" modal in the Azimuth UI +usage_template: |- + This is a Multinode appliance which deploys a cluster of nodes including the option to deploy the infrastructure with OpenStack. \ No newline at end of file From 00ab6fb4d590d097509917279b18f1729826c8cb Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Mon, 22 Jan 2024 12:39:16 +0000 Subject: [PATCH 090/102] Update meta UI for Infrastructure deployment. --- ui-meta/multinode-infra-appliance.yml | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index a5af2a1..4265092 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -115,11 +115,10 @@ parameters: - name: openstack_deploy #Idealy I would like to turn this into a checkbox. # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. - label: Deploy Infrastructure with OpenStack? #(True/False) - description: If you only wish to deploy the infrastructure with OpenStack select this option. + label: Deploy Infrastructure with OpenStack services? #(True/False) + description: If you wish to deploy OpenStack services in the infrastructure select this option. kind: "boolean" default: false - required: false options: permanent: true From 6bedaf8d31554d0655581dd7595a8f51ad8b9229 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Tue, 23 Jan 2024 13:40:20 +0000 Subject: [PATCH 091/102] Update UI to allow Openstack version select. --- ansible/vars/defaults.yml | 4 ++-- ui-meta/multinode-infra-appliance.yml | 20 ++++++++++++++++++-- 2 files changed, 20 insertions(+), 4 deletions(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index c61cb2d..d506b33 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -2,12 +2,12 @@ src_directory: "{{ ansible_env.HOME }}/src" kayobe_config_repo: https://github.com/stackhpc/stackhpc-kayobe-config.git -kayobe_config_version: stackhpc/yoga +kayobe_config_version: stackhpc/{{ openstack_version | lower }} kayobe_config_name: kayobe-config kayobe_config_environment: ci-multinode kayobe_repo: https://github.com/stackhpc/kayobe.git -kayobe_version: stackhpc/yoga +kayobe_version: stackhpc/{{ openstack_version | lower }} kayobe_name: kayobe openstack_config_repo: https://github.com/stackhpc/openstack-config-multinode diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 4265092..2cff74d 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -113,7 +113,7 @@ parameters: confirm: true #private: true - - name: openstack_deploy #Idealy I would like to turn this into a checkbox. + - name: openstack_deploy # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. label: Deploy Infrastructure with OpenStack services? #(True/False) description: If you wish to deploy OpenStack services in the infrastructure select this option. @@ -121,7 +121,23 @@ parameters: default: false options: permanent: true - + + - name: openstack_version + label: Select the OpenStack version to deploy. + description: Please select the OpenStack version to deploy. + kind: "choice" + options: + choices: + - "Victoria" + - "Wallaby" + - "Xena" + - "Yoga" + - "Zed" + required: true + default: "Yoga" + immutable: true + # when: + # - openstack_deploy == true #- name: backend_count # label: Backend node count From 775b7f1b8b448d7168a35d3d7081534dba522291 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 11:42:55 +0000 Subject: [PATCH 092/102] Try to allow custom input. --- ui-meta/multinode-infra-appliance.yml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 2cff74d..34f5fd8 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -133,6 +133,12 @@ parameters: - "Xena" - "Yoga" - "Zed" + - kind: "string" + label: "Custom" + description: "Please provide the OpenStack version to deploy." + options: + min_length: 1 + max_length: 30 required: true default: "Yoga" immutable: true From 305fc345819959fda046db2c5966ebcf3246661c Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 14:32:52 +0000 Subject: [PATCH 093/102] UI Changes --- terraform.tfvars.j2 | 2 +- ui-meta/multinode-infra-appliance.yml | 103 +++++++++++++++++--------- 2 files changed, 69 insertions(+), 36 deletions(-) diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index d889855..90b2d54 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -1,4 +1,4 @@ -prefix = "TestMN" +prefix = "{{ cluster_name }}" ansible_control_vm_flavor = "general.v1.small" ansible_control_vm_name = "ansible-control" diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 34f5fd8..3a62026 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -123,46 +123,79 @@ parameters: permanent: true - name: openstack_version - label: Select the OpenStack version to deploy. - description: Please select the OpenStack version to deploy. - kind: "choice" - options: - choices: - - "Victoria" - - "Wallaby" - - "Xena" - - "Yoga" - - "Zed" - - kind: "string" - label: "Custom" - description: "Please provide the OpenStack version to deploy." - options: - min_length: 1 - max_length: 30 + label: OpenStack GitHub Branch name. + description: Please provide the OpenStack GitHub Branch name you wish to deploy. + kind: "string" required: true - default: "Yoga" + default: "stackhpc/yoga" immutable: true - # when: - # - openstack_deploy == true + options: + live_check: > + "curl -s --head https://github.com/{{ openstack_version }}" + " | grep 'HTTP/1.1 200 OK' > /dev/null && echo '✅ Valid branch' || echo '❌ Invalid branch'" - #- name: backend_count - # label: Backend node count - # description: The number of backend nodes. - # kind: integer - # options: - # min: 1 - # default: 3 + # - name: openstack_version + # label: Select the OpenStack version to deploy. + # description: Please select the OpenStack version to deploy. + # kind: "choice" + # options: + # choices: + # - "Victoria" + # - "Wallaby" + # - "Xena" + # - "Yoga" + # - "Zed" + # required: true + # default: "Yoga" + # immutable: true - #- name: backend_flavor - # label: Backend node size - # description: The size to use for the backend nodes. - # kind: "cloud.size" - # immutable: true - # options: - # min_ram: 1024 - # min_disk: 10 # A template describing the usage of the appliance # This is rendered in the "Cluster details" modal in the Azimuth UI usage_template: |- - This is a Multinode appliance which deploys a cluster of nodes including the option to deploy the infrastructure with OpenStack. \ No newline at end of file + # METHOD 1 + # Accessing the cluster + + To assess the clusters, use the following ssh commands: + + {% for group in cluster_nodes|groupby('groups') %} + # {{ group.0|upper|bold }} + {% for node in group.1 %} + {% if node.ip is defined %} + {% if node.ip != '' %} + # {{ node.name|bold }} + {% if node.groups[0] == "ansible_control" %} + {% set status = "READY" %} + {% else %} + {% set status = "NOT AVAILABLE" %} + {% endif %} + # Instance name from {{ node.groups[0]|capitalize }} => {{ status|green if status == "READY" else status|red }} -> ssh {{ ssh_user }}@{{ node.ip }} + {% endif %} + {% endif %} + {% else %} + # Web service is not ready yet. + {% endfor %} + {% endfor %} + + # METHOD 2 + # Accessing the cluster + + To assess the clusters, use the following ssh commands: + + {% for group in cluster_nodes|groupby('groups') %} + # {{ group.grouper|upper }} + {% for node in group.list %} + {% if node.ip is defined and node.ip != '' %} + # {{ node.name }} + {% if node.groups[0] == "ansible_control" %} + {% set status = "READY" %} + {% else %} + {% set status = "NOT AVAILABLE" %} + {% endif %} + # Instance name from {{ node.groups[0]|capitalize }} => {{ status }} -> ssh {{ node.variables.ansible_user }}@{{ node.ip }} + {% else %} + # Instance name from {{ node.groups[0]|capitalize }} => NOT AVAILABLE -> ssh {{ node.variables.ansible_user }}@{{ node.ip }} + {% endif %} + {% endfor %} + ________________________________________ + {% endfor %} \ No newline at end of file From cee87a58ef2fd536f9aab97d91413d43bcfa0fe2 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 14:42:10 +0000 Subject: [PATCH 094/102] Given user choice over image. --- ansible/vars/defaults.yml | 4 ++-- group_vars/openstack.yml | 4 ++-- terraform.tfvars.j2 | 16 ++++++++-------- ui-meta/multinode-infra-appliance.yml | 21 +++++++++++++++------ 4 files changed, 27 insertions(+), 18 deletions(-) diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index d506b33..6b2e328 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -2,12 +2,12 @@ src_directory: "{{ ansible_env.HOME }}/src" kayobe_config_repo: https://github.com/stackhpc/stackhpc-kayobe-config.git -kayobe_config_version: stackhpc/{{ openstack_version | lower }} +kayobe_config_version: "{{ openstack_version }}" kayobe_config_name: kayobe-config kayobe_config_environment: ci-multinode kayobe_repo: https://github.com/stackhpc/kayobe.git -kayobe_version: stackhpc/{{ openstack_version | lower }} +kayobe_version: "{{ openstack_version }}" kayobe_name: kayobe openstack_config_repo: https://github.com/stackhpc/openstack-config-multinode diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index 5871168..fd0179a 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -24,8 +24,8 @@ terraform_project_path: "{{ playbook_dir }}" terraform_state: "{{ cluster_state | default('present') }}" # The user that should be used to SSH to the cluster hosts -cluster_ssh_user: cloud-user -ssh_user: cloud-user +cluster_ssh_user: "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" +ssh_user: "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" tf_files: [] #- outputs.tf diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 90b2d54..17996f8 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -2,28 +2,28 @@ prefix = "{{ cluster_name }}" ansible_control_vm_flavor = "general.v1.small" ansible_control_vm_name = "ansible-control" -ansible_control_disk_size = 100 +ansible_control_disk_size = 10 seed_vm_flavor = "general.v1.small" -seed_disk_size = 100 +seed_disk_size = 10 multinode_flavor = "general.v1.medium" -multinode_image = "rocky9-lvm" +# multinode_image = "rocky9-lvm" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" compute_count = "2" controller_count = "3" -compute_disk_size = 100 -controller_disk_size = 100 +compute_disk_size = 10 +controller_disk_size = 10 ssh_public_key = "{{ cluster_user_ssh_public_key }}" -ssh_user = "cloud-user" +# ssh_user = "cloud-user" storage_count = "3" storage_flavor = "general.v1.small" -storage_disk_size = 100 +storage_disk_size = 10 deploy_wazuh = false # infra_vm_flavor = "general.v1.small" -# infra_vm_disk_size = 100 \ No newline at end of file +# infra_vm_disk_size = 10 \ No newline at end of file diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 3a62026..84493e2 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -119,20 +119,29 @@ parameters: description: If you wish to deploy OpenStack services in the infrastructure select this option. kind: "boolean" default: false - options: - permanent: true + required: false + immutable: true - name: openstack_version label: OpenStack GitHub Branch name. description: Please provide the OpenStack GitHub Branch name you wish to deploy. kind: "string" - required: true + required: false default: "stackhpc/yoga" immutable: true + + + - name: multinode_image + label: Select the OpenStack version to deploy. + description: Please select the OpenStack version to deploy. + kind: "choice" options: - live_check: > - "curl -s --head https://github.com/{{ openstack_version }}" - " | grep 'HTTP/1.1 200 OK' > /dev/null && echo '✅ Valid branch' || echo '❌ Invalid branch'" + choices: + - "Ubuntu-22.04-lvm" + - "rocky9-lvm" + required: true + default: "rocky9-lvm" + immutable: true # - name: openstack_version # label: Select the OpenStack version to deploy. From 1cddc5fae3e20b8bb84bba728345cade1fae2889 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 16:27:24 +0000 Subject: [PATCH 095/102] Change the way the ssh command is provided. --- multinode-app.yml | 7 ++++ ui-meta/multinode-infra-appliance.yml | 47 ++++----------------------- 2 files changed, 13 insertions(+), 41 deletions(-) diff --git a/multinode-app.yml b/multinode-app.yml index a6ad26d..28eb4c1 100644 --- a/multinode-app.yml +++ b/multinode-app.yml @@ -91,3 +91,10 @@ # - name: Deploy OpenStack. # ansible.builtin.shell: # cmd: "./deploy-openstack.sh" + +- hosts: localhost + tasks: + - debug: var=outputs + vars: + outputs: + cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" \ No newline at end of file diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 84493e2..f1f9f40 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -167,44 +167,9 @@ usage_template: |- To assess the clusters, use the following ssh commands: - {% for group in cluster_nodes|groupby('groups') %} - # {{ group.0|upper|bold }} - {% for node in group.1 %} - {% if node.ip is defined %} - {% if node.ip != '' %} - # {{ node.name|bold }} - {% if node.groups[0] == "ansible_control" %} - {% set status = "READY" %} - {% else %} - {% set status = "NOT AVAILABLE" %} - {% endif %} - # Instance name from {{ node.groups[0]|capitalize }} => {{ status|green if status == "READY" else status|red }} -> ssh {{ ssh_user }}@{{ node.ip }} - {% endif %} - {% endif %} - {% else %} - # Web service is not ready yet. - {% endfor %} - {% endfor %} - - # METHOD 2 - # Accessing the cluster - - To assess the clusters, use the following ssh commands: - - {% for group in cluster_nodes|groupby('groups') %} - # {{ group.grouper|upper }} - {% for node in group.list %} - {% if node.ip is defined and node.ip != '' %} - # {{ node.name }} - {% if node.groups[0] == "ansible_control" %} - {% set status = "READY" %} - {% else %} - {% set status = "NOT AVAILABLE" %} - {% endif %} - # Instance name from {{ node.groups[0]|capitalize }} => {{ status }} -> ssh {{ node.variables.ansible_user }}@{{ node.ip }} - {% else %} - # Instance name from {{ node.groups[0]|capitalize }} => NOT AVAILABLE -> ssh {{ node.variables.ansible_user }}@{{ node.ip }} - {% endif %} - {% endfor %} - ________________________________________ - {% endfor %} \ No newline at end of file + {% if cluster.outputs.cluster_access_ip %} + {% set status = "READY" %} + {% else %} + {% set status = "NOT READY" %} + {% endif %} + Ansible Control Host => {{ status|green if status == "READY" else status|red }} -> ssh {{ ssh_user }}@{{ cluster.outputs.cluster_access_ip }} \ No newline at end of file From acf6248570564773f6ec986f7b8aed206788a4d3 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 16:39:18 +0000 Subject: [PATCH 096/102] set ssh user after automatically. --- variables.tf | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/variables.tf b/variables.tf index 950c01c..779fd3f 100644 --- a/variables.tf +++ b/variables.tf @@ -6,9 +6,9 @@ variable "ssh_public_key" { type = string } -variable "ssh_user" { - type = string -} +# variable "ssh_user" { +# type = string +# } variable "ansible_control_vm_name" { type = string From f987bd8b933373ff7115dc4f5c10f85fcb3bfce5 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 16:42:25 +0000 Subject: [PATCH 097/102] Change name of app.yaml --- multinode-app.yml => multinode-infra-app.yml | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename multinode-app.yml => multinode-infra-app.yml (100%) diff --git a/multinode-app.yml b/multinode-infra-app.yml similarity index 100% rename from multinode-app.yml rename to multinode-infra-app.yml From 257fdce5bbd8c59269bd4f741a80c0b05c10a72d Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Wed, 24 Jan 2024 17:29:04 +0000 Subject: [PATCH 098/102] Fix ssh user declaration. --- terraform.tfvars.j2 | 17 ++++++++++------- ui-meta/multinode-infra-appliance.yml | 19 ++++++++++++++++--- variables.tf | 6 +++--- 3 files changed, 29 insertions(+), 13 deletions(-) diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 17996f8..ce13a65 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -2,28 +2,31 @@ prefix = "{{ cluster_name }}" ansible_control_vm_flavor = "general.v1.small" ansible_control_vm_name = "ansible-control" -ansible_control_disk_size = 10 +ansible_control_disk_size = 25 seed_vm_flavor = "general.v1.small" -seed_disk_size = 10 +seed_disk_size = 25 multinode_flavor = "general.v1.medium" # multinode_image = "rocky9-lvm" +multinode_image = "{{ multinode_image }}" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" compute_count = "2" controller_count = "3" -compute_disk_size = 10 -controller_disk_size = 10 +compute_disk_size = 25 +controller_disk_size = 25 ssh_public_key = "{{ cluster_user_ssh_public_key }}" # ssh_user = "cloud-user" +ssh_user = "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" + storage_count = "3" storage_flavor = "general.v1.small" -storage_disk_size = 10 +storage_disk_size = 25 deploy_wazuh = false -# infra_vm_flavor = "general.v1.small" -# infra_vm_disk_size = 10 \ No newline at end of file +infra_vm_flavor = "general.v1.small" +infra_vm_disk_size = 25 \ No newline at end of file diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index f1f9f40..b6eab99 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -143,6 +143,20 @@ parameters: default: "rocky9-lvm" immutable: true + # - name: multinode_image + # label: Select the OpenStack version to deploy. + # description: Please select the OpenStack version to deploy. + # kind: "choice" + # options: + # choices: + # - "Ubuntu-22.04-lvm" + # - "rocky9-lvm" + # required: true + # default: "rocky9-lvm" + # immutable: true + + + # - name: openstack_version # label: Select the OpenStack version to deploy. # description: Please select the OpenStack version to deploy. @@ -168,8 +182,7 @@ usage_template: |- To assess the clusters, use the following ssh commands: {% if cluster.outputs.cluster_access_ip %} - {% set status = "READY" %} + Ansible Control Host => READY -> ssh {{ ssh_user }}@{{ cluster.outputs.cluster_access_ip }} {% else %} - {% set status = "NOT READY" %} + Not Available {% endif %} - Ansible Control Host => {{ status|green if status == "READY" else status|red }} -> ssh {{ ssh_user }}@{{ cluster.outputs.cluster_access_ip }} \ No newline at end of file diff --git a/variables.tf b/variables.tf index 779fd3f..950c01c 100644 --- a/variables.tf +++ b/variables.tf @@ -6,9 +6,9 @@ variable "ssh_public_key" { type = string } -# variable "ssh_user" { -# type = string -# } +variable "ssh_user" { + type = string +} variable "ansible_control_vm_name" { type = string From a8bec132d0c4b8e8a6d67ed29b182d8dd5ffd810 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Thu, 25 Jan 2024 15:39:06 +0000 Subject: [PATCH 099/102] Improved UI with ssh username input. --- terraform.tfvars.j2 | 2 +- ui-meta/multinode-infra-appliance.yml | 49 +++++++++++++-------------- 2 files changed, 25 insertions(+), 26 deletions(-) diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index ce13a65..092aa0d 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -20,7 +20,7 @@ controller_disk_size = 25 ssh_public_key = "{{ cluster_user_ssh_public_key }}" # ssh_user = "cloud-user" -ssh_user = "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" +# ssh_user = "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" storage_count = "3" diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index b6eab99..bc96236 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -87,7 +87,7 @@ logo:  # A list of parameters to be gathered from the user parameters: - name: vxlan_vni - label: Set the VXLAN VNI value. + label: Set VXLAN VNI. description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. kind: "integer" required: true @@ -100,7 +100,7 @@ parameters: - name: ans_vlt_pwd # A human-readable name for the parameter. Defaults to the name if not given. - label: Provide the Ansible Vault password. + label: Ansible Vault password. # An optional short description for the parameter. description: Please provide the Ansible Vault password to enable the deployment of the cluster. kind: "string" @@ -123,8 +123,10 @@ parameters: immutable: true - name: openstack_version - label: OpenStack GitHub Branch name. - description: Please provide the OpenStack GitHub Branch name you wish to deploy. + label: OpenStack GitHub Branch. + description: > + Please provide the OpenStack GitHub Branch name you wish to deploy. + i.e. stackhpc/yoga (for https://github.com/stackhpc/stackhpc-kayobe-config/tree/stackhpc/yoga) kind: "string" required: false default: "stackhpc/yoga" @@ -132,30 +134,28 @@ parameters: - name: multinode_image - label: Select the OpenStack version to deploy. - description: Please select the OpenStack version to deploy. - kind: "choice" - options: - choices: - - "Ubuntu-22.04-lvm" - - "rocky9-lvm" + label: Operating system image. + description: > + Please provide the OS you wish to deploy on this multinode infrastructure. + The image must be available in the OpenStack tenancy, two supported images are: + - Ubuntu-22.04-lvm + - rocky9-lvm + kind: "string" required: true default: "rocky9-lvm" immutable: true - # - name: multinode_image - # label: Select the OpenStack version to deploy. - # description: Please select the OpenStack version to deploy. - # kind: "choice" - # options: - # choices: - # - "Ubuntu-22.04-lvm" - # - "rocky9-lvm" - # required: true - # default: "rocky9-lvm" - # immutable: true - - + - name: ssh_user + label: Operating system SSH username. + description: > + Please select the OS username in order to connect to the infrastructure. + Examples are: + - ubuntu (Ubuntu-22.04-lvm) + - cloud_user (rocky9-lvm) + kind: "string" + required: true + default: "cloud_user" + immutable: false # - name: openstack_version # label: Select the OpenStack version to deploy. @@ -176,7 +176,6 @@ parameters: # A template describing the usage of the appliance # This is rendered in the "Cluster details" modal in the Azimuth UI usage_template: |- - # METHOD 1 # Accessing the cluster To assess the clusters, use the following ssh commands: From 6b8eb6fce4c6da39799c8f3723dce1a87200ece1 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 26 Jan 2024 13:43:20 +0000 Subject: [PATCH 100/102] Change description pipe symbol to have multiline outputs. --- ui-meta/multinode-infra-appliance.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index bc96236..3d8fe01 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -124,7 +124,7 @@ parameters: - name: openstack_version label: OpenStack GitHub Branch. - description: > + description: | Please provide the OpenStack GitHub Branch name you wish to deploy. i.e. stackhpc/yoga (for https://github.com/stackhpc/stackhpc-kayobe-config/tree/stackhpc/yoga) kind: "string" @@ -135,7 +135,7 @@ parameters: - name: multinode_image label: Operating system image. - description: > + description: | Please provide the OS you wish to deploy on this multinode infrastructure. The image must be available in the OpenStack tenancy, two supported images are: - Ubuntu-22.04-lvm @@ -147,8 +147,8 @@ parameters: - name: ssh_user label: Operating system SSH username. - description: > - Please select the OS username in order to connect to the infrastructure. + description: | + Please select the OS username in order to connect to the infrastructure. Examples are: - ubuntu (Ubuntu-22.04-lvm) - cloud_user (rocky9-lvm) From b257275a3362ed424f178f77aee4706488b39366 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 26 Jan 2024 14:33:34 +0000 Subject: [PATCH 101/102] Tidy up of the code for the infrastructure deployment. --- group_vars/openstack.yml | 14 -- multinode-infra-app.yml | 51 +----- outputs.tf | 21 +-- roles/cluster_infra/tasks/main.yml | 12 -- .../templates/authentication.tf.j2 | 4 - .../templates/compute_instances.tf.j2 | 160 ------------------ roles/cluster_infra/templates/data.tf.j2 | 8 - roles/cluster_infra/templates/outputs.tf.j2 | 112 ------------ .../templates/terraform.tfvars.j2 | 29 ---- roles/cluster_infra/templates/variables.tf.j2 | 104 ------------ roles/cluster_infra/templates/versions.tf.j2 | 13 -- roles/cluster_infra/templates/volumes.tf.j2 | 11 -- templates/deploy-openstack.tpl | 2 +- terraform.tfvars.j2 | 3 - ui-meta/multinode-appliance.yml | 144 ---------------- ui-meta/multinode-infra-appliance.yml | 15 -- versions.tf | 4 - 17 files changed, 10 insertions(+), 697 deletions(-) delete mode 100644 roles/cluster_infra/templates/authentication.tf.j2 delete mode 100644 roles/cluster_infra/templates/compute_instances.tf.j2 delete mode 100644 roles/cluster_infra/templates/data.tf.j2 delete mode 100644 roles/cluster_infra/templates/outputs.tf.j2 delete mode 100644 roles/cluster_infra/templates/terraform.tfvars.j2 delete mode 100644 roles/cluster_infra/templates/variables.tf.j2 delete mode 100644 roles/cluster_infra/templates/versions.tf.j2 delete mode 100644 roles/cluster_infra/templates/volumes.tf.j2 delete mode 100644 ui-meta/multinode-appliance.yml diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index fd0179a..af1a30a 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -23,18 +23,4 @@ terraform_project_path: "{{ playbook_dir }}" # Valid values are 'present' and 'absent' terraform_state: "{{ cluster_state | default('present') }}" -# The user that should be used to SSH to the cluster hosts -cluster_ssh_user: "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" -ssh_user: "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" -tf_files: [] - #- outputs.tf - #- variables.tf - # - authentication.tf - # - compute_instances.tf - # - data.tf - # - versions.tf - # - volumes.tf - # - terraform.tfvars - -# Assign the ansible ssh public key from the ansible runner's generated ssh key diff --git a/multinode-infra-app.yml b/multinode-infra-app.yml index 28eb4c1..6b6c657 100644 --- a/multinode-infra-app.yml +++ b/multinode-infra-app.yml @@ -16,15 +16,18 @@ src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" -# Provision the infrastructure -# The CaaS puts hosts for accessing the OpenStack API into the 'openstack' group +# Provision the infrastructure The CaaS puts hosts for accessing the OpenStack +# API into the 'openstack' group - hosts: openstack roles: - cluster_infra - hosts: localhost tasks: - # Check whether an ans_vlt_pwd variable is defined and if so, save it into a file called '~/vault.password'. If it doesn't exist, create a the '~/vault.password' file with ans_vlt_pwd = "password_not_set" as the password. + # Check whether an ans_vlt_pwd variable is defined and if so, save it into a + # file called '~/vault.password'. If it doesn't exist, create a the + # '~/vault.password' file with ans_vlt_pwd = "password_not_set" as the + # password. - name: Create vault password file vars: ans_dflt: 'default_password' @@ -33,37 +36,6 @@ dest: "~/vault.password" mode: 0600 - # - block: - # # Install the ansible requirements - # - name: Install ansible posix - # command: ansible-galaxy collection install ansible.posix - - # # Install the ansible requirements - # - name: Install ansible community general - # command: ansible-galaxy collection install community.general - - # # Install the ansible requirements - # - name: Install ansible requirements - # command: ansible-galaxy install -r ansible/requirements.yml - - - # - name: Deploy ansible playbook manually - # command: ansible-playbook -i ansible/inventory.yml ansible/configure-hosts.yml - # vars: - # terraform_binary_directory: "{{ playbook_dir }}/../bin" - # terraform_binary_path: "{{ terraform_binary_directory }}/../terraform" - # terraform_project_path: "{{ playbook_dir }}" - -# - debug: var=outputs -# vars: -# outputs: -# cluster_access_ip: "{{ hostvars[groups['openstack'][0]].cluster_gateway_ip }}" - - # - name: Debug groups - # debug: - # msg: "{{ groups | to_yaml }}" -# when: cluster_state != "absent" - # If openstack_deploy is true then continue if not end the playbook. # Import the playbook to start configuring the multi-node hosts. @@ -82,16 +54,7 @@ cmd: "bash ~/deploy-openstack.sh" when: openstack_deploy == true - -# - hosts: ansible_control -# vars: -# ansible_pipelining: true -# ansible_ssh_pipelining: true -# tasks: -# - name: Deploy OpenStack. -# ansible.builtin.shell: -# cmd: "./deploy-openstack.sh" - +# This is to get the ip of the ansible-controller host. - hosts: localhost tasks: - debug: var=outputs diff --git a/outputs.tf b/outputs.tf index e8f5430..35a0531 100644 --- a/outputs.tf +++ b/outputs.tf @@ -53,24 +53,6 @@ resource "local_file" "admin_networks" { file_permission = "0644" } -# output "cluster_nodes" { -# description = "A list of the cluster nodes and their IP addresses which will be used by the Ansible inventory" -# value = [{ -# name = openstack_compute_instance_v2.ansible_control.name -# ip = openstack_compute_instance_v2.ansible_control.access_ip_v4 -# groups = ["multinode_ansible_control"] -# }] -# } - -# flatten([ -# for node in openstack_compute_instance_v2.compute: { -# name = node.name -# ip = node.access_ip_v4 -# groups = ["compute"] -# } -# ]) -# } - resource "local_file" "openstack_inventory" { content = templatefile( "${path.module}/templates/openstack-inventory.tpl", @@ -151,7 +133,8 @@ output "cluster_nodes" { ) } -# For Backup +# Template of all the hosts' configuration which can be used to generate Ansible varables. + # resource "ansible_host" "control_host" { # name = openstack_compute_instance_v2.ansible_control.access_ip_v4 # groups = ["ansible_control"] diff --git a/roles/cluster_infra/tasks/main.yml b/roles/cluster_infra/tasks/main.yml index c7f24d6..2bcec93 100644 --- a/roles/cluster_infra/tasks/main.yml +++ b/roles/cluster_infra/tasks/main.yml @@ -37,18 +37,6 @@ - cluster_upgrade_system_packages is not defined or not cluster_upgrade_system_packages -- name: Template Terraform files into project directory - template: - src: "{{ item }}.j2" - dest: "{{ terraform_project_path }}/{{ item }}" - loop: "{{ tf_files }}" - -#- name: Copy Terraform files into project directory -# ansible.builtin.copy: -# src: "{{ item }}.tf" -# dest: "{{ terraform_project_path }}/{{ item }}.tf" -# loop: "{{ query('fileglob', '../../../*') }}" - - name: Provision infrastructure include_role: name: stackhpc.terraform.infra \ No newline at end of file diff --git a/roles/cluster_infra/templates/authentication.tf.j2 b/roles/cluster_infra/templates/authentication.tf.j2 deleted file mode 100644 index 266e107..0000000 --- a/roles/cluster_infra/templates/authentication.tf.j2 +++ /dev/null @@ -1,4 +0,0 @@ -resource "openstack_compute_keypair_v2" "keypair" { - name = var.multinode_keypair - public_key = file(var.ssh_public_key) -} \ No newline at end of file diff --git a/roles/cluster_infra/templates/compute_instances.tf.j2 b/roles/cluster_infra/templates/compute_instances.tf.j2 deleted file mode 100644 index a8db2c4..0000000 --- a/roles/cluster_infra/templates/compute_instances.tf.j2 +++ /dev/null @@ -1,160 +0,0 @@ -resource "openstack_compute_instance_v2" "ansible_control" { - name = format("%s-%s", var.prefix, var.ansible_control_vm_name) - flavor_name = var.ansible_control_vm_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - network { - name = var.multinode_vm_network - } - - dynamic "block_device" { - for_each = var.ansible_control_disk_size > 0 ? [1] : [] - content { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.ansible_control_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - } - timeouts { - create = "90m" - } - lifecycle { - ignore_changes = [ - user_data - ] - } -} - -resource "openstack_compute_instance_v2" "seed" { - name = format("%s-seed", var.prefix) - flavor_name = var.seed_vm_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - network { - name = var.multinode_vm_network - } - - dynamic "block_device" { - for_each = var.seed_disk_size > 0 ? [1] : [] - content { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.seed_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - } - timeouts { - create = "90m" - } -} - -resource "openstack_compute_instance_v2" "compute" { - name = format("%s-compute-%02d", var.prefix, count.index + 1) - flavor_name = var.multinode_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - image_name = var.multinode_image - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - count = var.compute_count - network { - name = var.multinode_vm_network - } - dynamic "block_device" { - for_each = var.compute_disk_size > 0 ? [1] : [] - content { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.compute_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - } - timeouts { - create = "90m" - } -} -resource "openstack_compute_instance_v2" "controller" { - name = format("%s-controller-%02d", var.prefix, count.index + 1) - flavor_name = var.multinode_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - image_name = var.multinode_image - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - count = var.controller_count - network { - name = var.multinode_vm_network - } - dynamic "block_device" { - for_each = var.controller_disk_size > 0 ? [1] : [] - content { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.controller_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - } - timeouts { - create = "90m" - } -} - -resource "openstack_compute_instance_v2" "storage" { - name = format("%s-storage-%02d", var.prefix, count.index + 1) - flavor_name = var.storage_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - image_name = var.multinode_image - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - count = var.storage_count - network { - name = var.multinode_vm_network - } - dynamic "block_device" { - for_each = var.storage_disk_size > 0 ? [1] : [] - content { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.storage_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - } - timeouts { - create = "90m" - } -} - -resource "openstack_compute_instance_v2" "wazuh_manager" { - name = format("%s-wazuh-manager-%02d", var.prefix, count.index + 1) - flavor_name = var.infra_vm_flavor - key_pair = resource.openstack_compute_keypair_v2.keypair.name - image_name = var.multinode_image - config_drive = true - user_data = file("templates/userdata.cfg.tpl") - count = var.deploy_wazuh ? 1 : 0 - network { - name = var.multinode_vm_network - } - block_device { - uuid = data.openstack_images_image_v2.multinode_image.id - source_type = "image" - volume_size = var.infra_vm_disk_size - boot_index = 0 - destination_type = "volume" - delete_on_termination = true - } - timeouts { - create = "90m" - } -} diff --git a/roles/cluster_infra/templates/data.tf.j2 b/roles/cluster_infra/templates/data.tf.j2 deleted file mode 100644 index 5c91dc0..0000000 --- a/roles/cluster_infra/templates/data.tf.j2 +++ /dev/null @@ -1,8 +0,0 @@ -data "openstack_images_image_v2" "multinode_image" { - name = var.multinode_image - most_recent = true -} - -data "openstack_networking_subnet_v2" "network" { - name = var.multinode_vm_subnet -} \ No newline at end of file diff --git a/roles/cluster_infra/templates/outputs.tf.j2 b/roles/cluster_infra/templates/outputs.tf.j2 deleted file mode 100644 index aaec76c..0000000 --- a/roles/cluster_infra/templates/outputs.tf.j2 +++ /dev/null @@ -1,112 +0,0 @@ -output "ansible_control_access_ip_v4" { - value = openstack_compute_instance_v2.ansible_control.access_ip_v4 -} - -output "seed_access_ip_v4" { - value = openstack_compute_instance_v2.seed.access_ip_v4 -} - -output "ssh_user" { - value = var.ssh_user -} - -resource "local_file" "hosts" { - content = templatefile( - "${path.module}/templates/hosts.tpl", - { - compute_hostname = openstack_compute_instance_v2.compute.*.name - controller_hostname = openstack_compute_instance_v2.controller.*.name - ansible_control_hostname = openstack_compute_instance_v2.ansible_control.name - storage_hostname = openstack_compute_instance_v2.storage.*.name - seed_hostname = openstack_compute_instance_v2.seed.name - wazuh_manager_hostname = openstack_compute_instance_v2.wazuh_manager.*.name - } - ) - filename = "ansible/files/hosts" - file_permission = "0644" -} - -resource "local_file" "admin_networks" { - content = templatefile( - "${path.module}/templates/admin-oc-networks.tpl", - { - access_cidr = data.openstack_networking_subnet_v2.network.cidr - compute_hostname = openstack_compute_instance_v2.compute.*.name - controller_hostname = openstack_compute_instance_v2.controller.*.name - ansible_control_hostname = openstack_compute_instance_v2.ansible_control.name - ansible_control = openstack_compute_instance_v2.ansible_control.access_ip_v4 - compute = openstack_compute_instance_v2.compute.*.access_ip_v4 - controllers = openstack_compute_instance_v2.controller.*.access_ip_v4 - storage_hostname = openstack_compute_instance_v2.storage.*.name - storage = openstack_compute_instance_v2.storage.*.access_ip_v4 - seed_hostname = openstack_compute_instance_v2.seed.name - seed = openstack_compute_instance_v2.seed.access_ip_v4 - wazuh_manager_hostname = openstack_compute_instance_v2.wazuh_manager.*.name - wazuh_manager = openstack_compute_instance_v2.wazuh_manager.*.access_ip_v4 - } - ) - filename = "ansible/files/admin-oc-networks.yml" - file_permission = "0644" -} - -resource "local_file" "openstack_inventory" { - content = templatefile( - "${path.module}/templates/openstack-inventory.tpl", - { - seed_addr = openstack_compute_instance_v2.seed.access_ip_v4, - ssh_user = var.ssh_user - } - ) - filename = "ansible/files/openstack-inventory" - file_permission = "0644" -} - -resource "local_file" "deploy_openstack" { - content = templatefile( - "${path.module}/templates/deploy-openstack.tpl", - { - seed_addr = openstack_compute_instance_v2.seed.access_ip_v4, - ssh_user = var.ssh_user, - deploy_wazuh = var.deploy_wazuh - controller_hostname = openstack_compute_instance_v2.controller.*.name - } - ) - filename = "ansible/files/deploy-openstack.sh" - file_permission = "0755" -} - -resource "ansible_host" "control_host" { - name = openstack_compute_instance_v2.ansible_control.access_ip_v4 - groups = ["ansible_control"] -} - -resource "ansible_host" "compute_host" { - for_each = { for host in openstack_compute_instance_v2.compute : host.name => host.access_ip_v4 } - name = each.value - groups = ["compute"] -} - -resource "ansible_host" "controllers_hosts" { - for_each = { for host in openstack_compute_instance_v2.controller : host.name => host.access_ip_v4 } - name = each.value - groups = ["controllers"] -} - -resource "ansible_host" "seed_host" { - name = openstack_compute_instance_v2.seed.access_ip_v4 - groups = ["seed"] -} - -resource "ansible_host" "storage" { - for_each = { for host in openstack_compute_instance_v2.storage : host.name => host.access_ip_v4 } - name = each.value - groups = ["storage"] -} - -resource "ansible_group" "cluster_group" { - name = "cluster" - children = ["compute", "ansible_control", "controllers", "seed", "storage"] - variables = { - ansible_user = var.ssh_user - } -} diff --git a/roles/cluster_infra/templates/terraform.tfvars.j2 b/roles/cluster_infra/templates/terraform.tfvars.j2 deleted file mode 100644 index 9777cd3..0000000 --- a/roles/cluster_infra/templates/terraform.tfvars.j2 +++ /dev/null @@ -1,29 +0,0 @@ -prefix = "TestMN" - -ansible_control_vm_flavor = "general.v1.small" -ansible_control_vm_name = "ansible-control" -ansible_control_disk_size = 100 - -seed_vm_flavor = "general.v1.small" -seed_disk_size = 100 - -multinode_flavor = "general.v1.medium" -multinode_image = "rocky9-lvm" -multinode_keypair = "MaxMNKP" -multinode_vm_network = "stackhpc-ipv4-geneve" -multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" -compute_count = "2" -controller_count = "3" -compute_disk_size = 100 -controller_disk_size = 100 - -ssh_public_key = "~/.ssh/id_ed25519.pub" -ssh_user = "ubuntu" - -storage_count = "3" -storage_flavor = "general.v1.small" -storage_disk_size = 100 - -deploy_wazuh = true -infra_vm_flavor = "general.v1.small" -infra_vm_disk_size = 100 diff --git a/roles/cluster_infra/templates/variables.tf.j2 b/roles/cluster_infra/templates/variables.tf.j2 deleted file mode 100644 index 950c01c..0000000 --- a/roles/cluster_infra/templates/variables.tf.j2 +++ /dev/null @@ -1,104 +0,0 @@ -variable "storage_count" { - type = string -} - -variable "ssh_public_key" { - type = string -} - -variable "ssh_user" { - type = string -} - -variable "ansible_control_vm_name" { - type = string -} - -variable "seed_vm_flavor" { - type = string -} - -variable "prefix" { - type = string - default = "kayobe-mn" -} - -variable "compute_count" { - type = string -} - -variable "controller_count" { - type = string -} - -variable "multinode_image" { - type = string -} - -variable "multinode_keypair" { - type = string -} - -variable "ansible_control_vm_flavor" { - type = string -} - -variable "multinode_flavor" { - type = string -} - -variable "storage_flavor" { - type = string -} - -variable "infra_vm_flavor" { - type = string -} - -variable "multinode_vm_network" { - type = string -} - -variable "multinode_vm_subnet" { - type = string -} - -variable "compute_disk_size" { - description = "Block storage root disk size for compute nodes in GB. Set to 0 on baremetal to use physical storage." - type = number -} - -variable "controller_disk_size" { - description = "Block storage root disk size for controller nodes in GB. Set to 0 on baremetal to use physical storage." - type = number -} - -variable "ansible_control_disk_size" { - description = "Block storage root disk size for the ansible control node in GB. Set to 0 on baremetal to use physical storage." - type = number - default = 100 -} - -variable "seed_disk_size" { - description = "Block storage root disk size for the seed node in GB. Set to 0 on baremetal to use physical storage." - type = number - default = 100 -} - -variable "storage_disk_size" { - description = "Block storage root disk size for storage nodes in GB. Set to 0 on baremetal to use physical storage." - type = number - default = 100 -} - -variable "infra_vm_disk_size" { - description = "Block storage root disk size for infrastructure VMs." - type = number - default = 100 -} - -variable "deploy_wazuh" { - description = "Bool, whether or not to deploy Wazuh." - type = bool - default = false -} diff --git a/roles/cluster_infra/templates/versions.tf.j2 b/roles/cluster_infra/templates/versions.tf.j2 deleted file mode 100644 index 74359a0..0000000 --- a/roles/cluster_infra/templates/versions.tf.j2 +++ /dev/null @@ -1,13 +0,0 @@ -terraform { - required_version = ">= 0.14" - required_providers { - openstack = { - source = "terraform-provider-openstack/openstack" - version = "1.49.0" - } - ansible = { - source = "ansible/ansible" - version = "1.1.0" - } - } -} diff --git a/roles/cluster_infra/templates/volumes.tf.j2 b/roles/cluster_infra/templates/volumes.tf.j2 deleted file mode 100644 index f7eaeef..0000000 --- a/roles/cluster_infra/templates/volumes.tf.j2 +++ /dev/null @@ -1,11 +0,0 @@ -resource "openstack_blockstorage_volume_v3" "volumes" { - count = var.storage_count - name = format("%s-osd-%02d", var.prefix, count.index + 1) - size = 40 -} - -resource "openstack_compute_volume_attach_v2" "attachments" { - count = var.storage_count - instance_id = openstack_compute_instance_v2.storage.*.id[count.index] - volume_id = openstack_blockstorage_volume_v3.volumes.*.id[count.index] -} \ No newline at end of file diff --git a/templates/deploy-openstack.tpl b/templates/deploy-openstack.tpl index 65a2961..9b7a59a 100644 --- a/templates/deploy-openstack.tpl +++ b/templates/deploy-openstack.tpl @@ -131,7 +131,7 @@ fi if [[ "$(sudo docker image ls)" == *"kayobe"* ]]; then echo "Image already exists skipping docker build" else - sudo DOCKER_BUILDKIT=1 docker build --network host --build-arg BASE_IMAGE=$$BASE_IMAGE --file $${config_directories[kayobe]}/.automation/docker/kayobe/Dockerfile --tag kayobe:latest $${config_directories[kayobe]} + sudo DOCKER_BUILDKIT=1 docker build --network host --build-arg BASE_IMAGE=$BASE_IMAGE --file $${config_directories[kayobe]}/.automation/docker/kayobe/Dockerfile --tag kayobe:latest $${config_directories[kayobe]} fi set +x diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 092aa0d..6864eef 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -19,9 +19,6 @@ compute_disk_size = 25 controller_disk_size = 25 ssh_public_key = "{{ cluster_user_ssh_public_key }}" -# ssh_user = "cloud-user" -# ssh_user = "{{ 'cloud-user' if multinode_image == 'rocky9-lvm' else 'ubuntu' }}" - storage_count = "3" storage_flavor = "general.v1.small" diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml deleted file mode 100644 index 3c212a4..0000000 --- a/ui-meta/multinode-appliance.yml +++ /dev/null @@ -1,144 +0,0 @@ -# The machine-readable name of the appliance -name: "multinode" -# The human-readable label for the appliance -label: "Multinode Deployment" -# A short description of the appliance, rendered as-is -description: An appliance for deploying a multinode cluster on Azimuth. -# The URL of the logo for the appliance -# This should be an HTTPS URL, because plain HTTP URLs will cause content warnings when Azimuth is served over HTTPS -# Alternatively, as shown here, a data URL can be used to encode the image directly -logo:  - - -# A list of parameters to be gathered from the user -# parameters: - # The name of the Ansible variable that will be populated with the parameter value. - # This field is required. - # - name: vxlan_vni - # A human-readable name for the parameter. Defaults to the name if not given. - # label: Set the VXLAN VNI value. - # An optional short description for the parameter. - # description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. - # The kind of the parameter. This field is required. - # Valid values are: - #  list - # A list of items. - # string - #  A string or something that can be coerced. - #  integer - #  An integer or a string that can be coerced. - #  number - #  Any number, i.e. an integer or a float, or a string that can be coerced. - #  boolean - # A boolean flag. - #  Valid values are: true/false, 1/0, "1"/"0", "true"/"false" and "yes"/"no". - #  choice - # A value from a set of choices. - #  cloud.size - # The ID of a size in the target tenancy. - #  cloud.machine - #  The ID of a machine in the target tenancy. - # cloud.ip - #  The ID of an external IP in the target tenancy. - #  cloud.volume - #  The ID of a volume in the target tenancy. - #  cloud.cluster - #  The ID of another cluster in the target tenancy. - # kind: "integer" - # Indicates whether the parameter is required. Defaults to true if not given. - # required: true - # The default value value for the parameter. Defaults to null if not given, indicating no default. - # default: null - # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. - # Defaults to false if not given. - # immutable: true - # Additional options for the parameter. The valid options depend on the kind of the parameter. - # list - # min_length: An optional minimum length for the list. - #  max_length: An optional maximum length for the list. - # item: An optional item validator, consisting of a kind and some options. - # string - # min_length: An optional minimum length for the string. - # max_length: An optional maximum length for the string. - #  pattern: An optional regular expression pattern to validate the string against. - #  integer - #  number - # options: - # min: 1 - # max: 100000 - #  boolean - # permanent: If true, indicates that the parameter cannot become false again once it has - #  been set to true. Defaults to false if not given. - #  choice - #  choices: The list of valid choices for the parameter. This field is required. - #  cloud.size - #  min_cpus: An optional minimum number of CPUs that the size must have. - #  min_ram: An optional minimum amount of RAM in MB that the size must have. - # min_disk: An optional minimum root disk size in GB that the size must have. - #  cloud.volume - #  min_size: An optional minimum size in GB for the volume. - #  cloud.cluster - # tag: An optional tag that the cluster must have. - # options: - # min_ram: 1024 - # min_disk: 10 - # secret: true - # confirm: true - -# A list of parameters to be gathered from the user -parameters: - - name: vxlan_vni - label: Set the VXLAN VNI value. - description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. - kind: "integer" - required: true - default: null - immutable: true - options: - min: 1 - max: 100000 - - - - name: ans_vlt_pwd - # A human-readable name for the parameter. Defaults to the name if not given. - label: Provide the Ansible Vault password. - # An optional short description for the parameter. - description: Please provide the Ansible Vault password to enable the deployment of the cluster. - kind: "string" - required: false - #default: "password_not_set" - immutable: false - # Replace the characters of the parameter with asterisks in the UI. - options: - secret: true - confirm: true - #private: true - - #- name: backend_count - # label: Backend node count - # description: The number of backend nodes. - # kind: integer - # options: - # min: 1 - # default: 3 - - #- name: backend_flavor - # label: Backend node size - # description: The size to use for the backend nodes. - # kind: "cloud.size" - # immutable: true - # options: - # min_ram: 1024 - # min_disk: 10 - -# A template describing the usage of the appliance -# This is rendered in the "Cluster details" modal in the Azimuth UI -usage_template: |- - This is a Multinode appliance which deploys a cluster of nodes including: - * Root node - * Log node - * Audit node - * Home node - * **tmp** node - * **var** node - * **var_tmp** node \ No newline at end of file diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml index 3d8fe01..be1c989 100644 --- a/ui-meta/multinode-infra-appliance.yml +++ b/ui-meta/multinode-infra-appliance.yml @@ -157,21 +157,6 @@ parameters: default: "cloud_user" immutable: false - # - name: openstack_version - # label: Select the OpenStack version to deploy. - # description: Please select the OpenStack version to deploy. - # kind: "choice" - # options: - # choices: - # - "Victoria" - # - "Wallaby" - # - "Xena" - # - "Yoga" - # - "Zed" - # required: true - # default: "Yoga" - # immutable: true - # A template describing the usage of the appliance # This is rendered in the "Cluster details" modal in the Azimuth UI diff --git a/versions.tf b/versions.tf index 94ba957..8582a8c 100644 --- a/versions.tf +++ b/versions.tf @@ -5,9 +5,5 @@ terraform { source = "terraform-provider-openstack/openstack" version = "1.49.0" } - #ansible = { - # source = "ansible/ansible" - # version = "1.1.0" - #} } } From f649ba794b6d7edadc76b2bcb73a50023c7385f3 Mon Sep 17 00:00:00 2001 From: "Max.Bed4d" Date: Fri, 26 Jan 2024 14:53:52 +0000 Subject: [PATCH 102/102] Importing the changes made to be able to deploy MN. --- ansible/ansible.cfg | 1 + ansible/fix-homedir-ownership.yml | 4 +- ansible/vars/defaults.yml | 8 +- group_vars/openstack.yml | 2 +- multinode-infra-app.yml => multinode-app.yml | 5 +- terraform.tfvars.j2 | 14 +- ui-meta/multinode-appliance.yml | 183 +++++++++++++++++++ ui-meta/multinode-infra-appliance.yml | 172 ----------------- 8 files changed, 201 insertions(+), 188 deletions(-) rename multinode-infra-app.yml => multinode-app.yml (95%) create mode 100644 ui-meta/multinode-appliance.yml delete mode 100644 ui-meta/multinode-infra-appliance.yml diff --git a/ansible/ansible.cfg b/ansible/ansible.cfg index 35367c1..39be919 100644 --- a/ansible/ansible.cfg +++ b/ansible/ansible.cfg @@ -5,6 +5,7 @@ host_key_checking = False pipelining = True forks = 30 deprecation_warnings=False +roles_path = ../roles [ssh_connection] ssh_args = -o ControlMaster=auto -o ControlPersist=60s \ No newline at end of file diff --git a/ansible/fix-homedir-ownership.yml b/ansible/fix-homedir-ownership.yml index 5b08dbf..fa48e94 100644 --- a/ansible/fix-homedir-ownership.yml +++ b/ansible/fix-homedir-ownership.yml @@ -1,6 +1,6 @@ --- - name: Fix Home Directory Ownership - hosts: all + hosts: all, !localhost gather_facts: false vars: # At the time of running this playbook the home directory is not owned by the user. @@ -16,7 +16,7 @@ gather_subset: - user_dir - - name: Ensure homedir is owned by {{ ansible_user }} + - name: Ensure homedir is owned by "{{ ansible_user }}" ansible.builtin.file: dest: "{{ ansible_env.HOME }}" state: directory diff --git a/ansible/vars/defaults.yml b/ansible/vars/defaults.yml index 6b2e328..4655c98 100644 --- a/ansible/vars/defaults.yml +++ b/ansible/vars/defaults.yml @@ -2,12 +2,12 @@ src_directory: "{{ ansible_env.HOME }}/src" kayobe_config_repo: https://github.com/stackhpc/stackhpc-kayobe-config.git -kayobe_config_version: "{{ openstack_version }}" +kayobe_config_version: "{{ kayobe_config_branch | default('stackhpc/yoga')}}" kayobe_config_name: kayobe-config kayobe_config_environment: ci-multinode kayobe_repo: https://github.com/stackhpc/kayobe.git -kayobe_version: "{{ openstack_version }}" +kayobe_version: "{{ kayobe_version_branch | default('stackhpc/yoga') }}" kayobe_name: kayobe openstack_config_repo: https://github.com/stackhpc/openstack-config-multinode @@ -16,9 +16,7 @@ openstack_config_name: openstack-config vault_password_path: "~/vault.password" -ssh_key_path: - -vxlan_vni: +ssh_key_path: "{{ cluster_ssh_private_key_file }}" root_domain: sms-lab.cloud diff --git a/group_vars/openstack.yml b/group_vars/openstack.yml index af1a30a..c1d37d6 100644 --- a/group_vars/openstack.yml +++ b/group_vars/openstack.yml @@ -23,4 +23,4 @@ terraform_project_path: "{{ playbook_dir }}" # Valid values are 'present' and 'absent' terraform_state: "{{ cluster_state | default('present') }}" - +cluster_ssh_user: "{{ ssh_user }}" diff --git a/multinode-infra-app.yml b/multinode-app.yml similarity index 95% rename from multinode-infra-app.yml rename to multinode-app.yml index 6b6c657..f231ef6 100644 --- a/multinode-infra-app.yml +++ b/multinode-app.yml @@ -16,7 +16,10 @@ src: "{{ playbook_dir }}/templates/userdata.cfg.tpl.j2" dest: "{{ playbook_dir }}/templates/userdata.cfg.tpl" -# Provision the infrastructure The CaaS puts hosts for accessing the OpenStack + +# Provision the infrastructure + +# The CaaS puts hosts for accessing the OpenStack # API into the 'openstack' group - hosts: openstack roles: diff --git a/terraform.tfvars.j2 b/terraform.tfvars.j2 index 6864eef..86b6476 100644 --- a/terraform.tfvars.j2 +++ b/terraform.tfvars.j2 @@ -2,28 +2,28 @@ prefix = "{{ cluster_name }}" ansible_control_vm_flavor = "general.v1.small" ansible_control_vm_name = "ansible-control" -ansible_control_disk_size = 25 +ansible_control_disk_size = 100 seed_vm_flavor = "general.v1.small" -seed_disk_size = 25 +seed_disk_size = 100 multinode_flavor = "general.v1.medium" -# multinode_image = "rocky9-lvm" multinode_image = "{{ multinode_image }}" multinode_keypair = "MaxMNKP" multinode_vm_network = "stackhpc-ipv4-geneve" multinode_vm_subnet = "stackhpc-ipv4-geneve-subnet" compute_count = "2" controller_count = "3" -compute_disk_size = 25 -controller_disk_size = 25 +compute_disk_size = 100 +controller_disk_size = 100 ssh_public_key = "{{ cluster_user_ssh_public_key }}" +ssh_user = "{{ ssh_user }}" storage_count = "3" storage_flavor = "general.v1.small" -storage_disk_size = 25 +storage_disk_size = 100 deploy_wazuh = false infra_vm_flavor = "general.v1.small" -infra_vm_disk_size = 25 \ No newline at end of file +infra_vm_disk_size = 100 \ No newline at end of file diff --git a/ui-meta/multinode-appliance.yml b/ui-meta/multinode-appliance.yml new file mode 100644 index 0000000..50d97cc --- /dev/null +++ b/ui-meta/multinode-appliance.yml @@ -0,0 +1,183 @@ +# The machine-readable name of the appliance +name: "multinode-app" +# The human-readable label for the appliance +label: "Multinode Customisable Deployment" +# A short description of the appliance, rendered as-is +description: | + An appliance for deploying a multinode cluster on Azimuth with options to deploy it with a custom version of OpenStack or just the infrastructure. +# The URL of the logo for the appliance +# This should be an HTTPS URL, because plain HTTP URLs will cause content warnings when Azimuth is served over HTTPS +# Alternatively, as shown here, a data URL can be used to encode the image directly +logo:  +# A list of parameters to be gathered from the user +# parameters: + # The name of the Ansible variable that will be populated with the parameter value. + # This field is required. + # - name: vxlan_vni + # A human-readable name for the parameter. Defaults to the name if not given. + # label: Set the VXLAN VNI value. + # An optional short description for the parameter. + # description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + # The kind of the parameter. This field is required. + # Valid values are: + #  list + # A list of items. + # string + #  A string or something that can be coerced. + #  integer + #  An integer or a string that can be coerced. + #  number + #  Any number, i.e. an integer or a float, or a string that can be coerced. + #  boolean + # A boolean flag. + #  Valid values are: true/false, 1/0, "1"/"0", "true"/"false" and "yes"/"no". + #  choice + # A value from a set of choices. + #  cloud.size + # The ID of a size in the target tenancy. + #  cloud.machine + #  The ID of a machine in the target tenancy. + # cloud.ip + #  The ID of an external IP in the target tenancy. + #  cloud.volume + #  The ID of a volume in the target tenancy. + #  cloud.cluster + #  The ID of another cluster in the target tenancy. + # kind: "integer" + # Indicates whether the parameter is required. Defaults to true if not given. + # required: true + # The default value value for the parameter. Defaults to null if not given, indicating no default. + # default: null + # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. + # Defaults to false if not given. + # immutable: true + # Additional options for the parameter. The valid options depend on the kind of the parameter. + # list + # min_length: An optional minimum length for the list. + #  max_length: An optional maximum length for the list. + # item: An optional item validator, consisting of a kind and some options. + # string + # min_length: An optional minimum length for the string. + # max_length: An optional maximum length for the string. + #  pattern: An optional regular expression pattern to validate the string against. + #  integer + #  number + # options: + # min: 1 + # max: 100000 + #  boolean + # permanent: If true, indicates that the parameter cannot become false again once it has + #  been set to true. Defaults to false if not given. + #  choice + #  choices: The list of valid choices for the parameter. This field is required. + #  cloud.size + #  min_cpus: An optional minimum number of CPUs that the size must have. + #  min_ram: An optional minimum amount of RAM in MB that the size must have. + # min_disk: An optional minimum root disk size in GB that the size must have. + #  cloud.volume + #  min_size: An optional minimum size in GB for the volume. + #  cloud.cluster + # tag: An optional tag that the cluster must have. + # options: + # min_ram: 1024 + # min_disk: 10 + # secret: true + # confirm: true + +# A list of parameters to be gathered from the user +parameters: + - name: vxlan_vni + label: Set VXLAN VNI. + description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. + kind: "integer" + required: true + default: null + immutable: true + options: + min: 1 + max: 100000 + + + - name: ans_vlt_pwd + # A human-readable name for the parameter. Defaults to the name if not given. + label: Ansible Vault password. + # An optional short description for the parameter. + description: Please provide the Ansible Vault password to enable the deployment of the cluster. + kind: "string" + required: false + #default: "password_not_set" + immutable: false + # Replace the characters of the parameter with asterisks in the UI. + options: + secret: true + confirm: true + #private: true + + - name: openstack_deploy + # A boolean flag which will be set to true if the user selects the checkbox, + # this will allow the user to decide whether they wish to have the + # infrastructure built with or without OpenStack. + label: Deploy Infrastructure with OpenStack services? #(True/False) + description: If you wish to deploy OpenStack services in the infrastructure select this option. + kind: "boolean" + default: false + required: false + immutable: true + + - name: kayobe_version_branch + label: Kayobe GitHub Branch. + description: | + Please provide the OpenStack GitHub Branch name you wish to deploy. + i.e. stackhpc/yoga (for https://github.com/stackhpc/kayobe/tree/stackhpc/yoga) + kind: "string" + required: false + default: "stackhpc/yoga" + immutable: true + + - name: kayobe_config_branch + label: Kayobe configuration GitHub Branch. + description: | + Please provide the GitHub Branch with the OpenStack configuration you wish to deploy. + i.e. stackhpc/yoga (for https://github.com/stackhpc/stackhpc-kayobe-config/tree/stackhpc/yoga) + kind: "string" + required: false + default: "stackhpc/yoga" + immutable: true + + - name: multinode_image + label: Operating system image. + description: | + Please provide the OS you wish to deploy on this multinode infrastructure. + The image must be available in the OpenStack tenancy, two supported images are: + - Ubuntu-22.04-lvm + - rocky9-lvm + kind: "string" + required: true + default: "rocky9-lvm" + immutable: true + + - name: ssh_user + label: Operating system SSH username. + description: | + Please select the OS username in order to connect to the infrastructure. + Examples are: + - ubuntu (Ubuntu-22.04-lvm) + - cloud_user (rocky9-lvm) + kind: "string" + required: true + default: "cloud_user" + immutable: false + + +# A template describing the usage of the appliance +# This is rendered in the "Cluster details" modal in the Azimuth UI +usage_template: |- + # Accessing the cluster + + To assess the clusters, use the following ssh commands: + + {% if cluster.outputs.cluster_access_ip %} + Ansible Control Host => READY -> ssh {{ ssh_user }}@{{ cluster.outputs.cluster_access_ip }} + {% else %} + Not Available + {% endif %} diff --git a/ui-meta/multinode-infra-appliance.yml b/ui-meta/multinode-infra-appliance.yml deleted file mode 100644 index be1c989..0000000 --- a/ui-meta/multinode-infra-appliance.yml +++ /dev/null @@ -1,172 +0,0 @@ -# The machine-readable name of the appliance -name: "multinode-infra" -# The human-readable label for the appliance -label: "Multinode Infrastructure Deployment" -# A short description of the appliance, rendered as-is -description: An appliance for deploying a multinode cluster on Azimuth with the option of deploying just the Infrastructure. -# The URL of the logo for the appliance -# This should be an HTTPS URL, because plain HTTP URLs will cause content warnings when Azimuth is served over HTTPS -# Alternatively, as shown here, a data URL can be used to encode the image directly -logo:  - -# A list of parameters to be gathered from the user -# parameters: - # The name of the Ansible variable that will be populated with the parameter value. - # This field is required. - # - name: vxlan_vni - # A human-readable name for the parameter. Defaults to the name if not given. - # label: Set the VXLAN VNI value. - # An optional short description for the parameter. - # description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. - # The kind of the parameter. This field is required. - # Valid values are: - #  list - # A list of items. - # string - #  A string or something that can be coerced. - #  integer - #  An integer or a string that can be coerced. - #  number - #  Any number, i.e. an integer or a float, or a string that can be coerced. - #  boolean - # A boolean flag. - #  Valid values are: true/false, 1/0, "1"/"0", "true"/"false" and "yes"/"no". - #  choice - # A value from a set of choices. - #  cloud.size - # The ID of a size in the target tenancy. - #  cloud.machine - #  The ID of a machine in the target tenancy. - # cloud.ip - #  The ID of an external IP in the target tenancy. - #  cloud.volume - #  The ID of a volume in the target tenancy. - #  cloud.cluster - #  The ID of another cluster in the target tenancy. - # kind: "integer" - # Indicates whether the parameter is required. Defaults to true if not given. - # required: true - # The default value value for the parameter. Defaults to null if not given, indicating no default. - # default: null - # Indicates whether the parameter is immutable, i.e. cannot be changed after the initial creation. - # Defaults to false if not given. - # immutable: true - # Additional options for the parameter. The valid options depend on the kind of the parameter. - # list - # min_length: An optional minimum length for the list. - #  max_length: An optional maximum length for the list. - # item: An optional item validator, consisting of a kind and some options. - # string - # min_length: An optional minimum length for the string. - # max_length: An optional maximum length for the string. - #  pattern: An optional regular expression pattern to validate the string against. - #  integer - #  number - # options: - # min: 1 - # max: 100000 - #  boolean - # permanent: If true, indicates that the parameter cannot become false again once it has - #  been set to true. Defaults to false if not given. - #  choice - #  choices: The list of valid choices for the parameter. This field is required. - #  cloud.size - #  min_cpus: An optional minimum number of CPUs that the size must have. - #  min_ram: An optional minimum amount of RAM in MB that the size must have. - # min_disk: An optional minimum root disk size in GB that the size must have. - #  cloud.volume - #  min_size: An optional minimum size in GB for the volume. - #  cloud.cluster - # tag: An optional tag that the cluster must have. - # options: - # min_ram: 1024 - # min_disk: 10 - # secret: true - # confirm: true - -# A list of parameters to be gathered from the user -parameters: - - name: vxlan_vni - label: Set VXLAN VNI. - description: Please provide a VXLAN VNI. A unique value from 1 to 100,000. - kind: "integer" - required: true - default: null - immutable: true - options: - min: 1 - max: 100000 - - - - name: ans_vlt_pwd - # A human-readable name for the parameter. Defaults to the name if not given. - label: Ansible Vault password. - # An optional short description for the parameter. - description: Please provide the Ansible Vault password to enable the deployment of the cluster. - kind: "string" - required: false - #default: "password_not_set" - immutable: false - # Replace the characters of the parameter with asterisks in the UI. - options: - secret: true - confirm: true - #private: true - - - name: openstack_deploy - # A boolean flag which will be set to true if the user selects the checkbox, this will allow the user to decide whether they wish to have the infrastructure built with or without OpenStack. - label: Deploy Infrastructure with OpenStack services? #(True/False) - description: If you wish to deploy OpenStack services in the infrastructure select this option. - kind: "boolean" - default: false - required: false - immutable: true - - - name: openstack_version - label: OpenStack GitHub Branch. - description: | - Please provide the OpenStack GitHub Branch name you wish to deploy. - i.e. stackhpc/yoga (for https://github.com/stackhpc/stackhpc-kayobe-config/tree/stackhpc/yoga) - kind: "string" - required: false - default: "stackhpc/yoga" - immutable: true - - - - name: multinode_image - label: Operating system image. - description: | - Please provide the OS you wish to deploy on this multinode infrastructure. - The image must be available in the OpenStack tenancy, two supported images are: - - Ubuntu-22.04-lvm - - rocky9-lvm - kind: "string" - required: true - default: "rocky9-lvm" - immutable: true - - - name: ssh_user - label: Operating system SSH username. - description: | - Please select the OS username in order to connect to the infrastructure. - Examples are: - - ubuntu (Ubuntu-22.04-lvm) - - cloud_user (rocky9-lvm) - kind: "string" - required: true - default: "cloud_user" - immutable: false - - -# A template describing the usage of the appliance -# This is rendered in the "Cluster details" modal in the Azimuth UI -usage_template: |- - # Accessing the cluster - - To assess the clusters, use the following ssh commands: - - {% if cluster.outputs.cluster_access_ip %} - Ansible Control Host => READY -> ssh {{ ssh_user }}@{{ cluster.outputs.cluster_access_ip }} - {% else %} - Not Available - {% endif %}