diff options
Diffstat (limited to 'playbooks/openstack')
5 files changed, 150 insertions, 12 deletions
| diff --git a/playbooks/openstack/openshift-cluster/files/heat_stack.yaml b/playbooks/openstack/openshift-cluster/files/heat_stack.yaml index a15ec749c..d53884e0d 100644 --- a/playbooks/openstack/openshift-cluster/files/heat_stack.yaml +++ b/playbooks/openstack/openshift-cluster/files/heat_stack.yaml @@ -16,8 +16,13 @@ parameters:    num_nodes:      type: number -    label: Number of nodes -    description: Number of nodes +    label: Number of compute nodes +    description: Number of compute nodes + +  num_infra: +    type: number +    label: Number of infrastructure nodes +    description: Number of infrastructure nodes    cidr:      type: string @@ -55,7 +60,12 @@ parameters:    node_image:      type: string      label: Node image -    description: Name of the image for the node servers +    description: Name of the image for the compute node servers + +  infra_image: +    type: string +    label: Infra image +    description: Name of the image for the infra node servers    master_flavor:      type: string @@ -65,7 +75,12 @@ parameters:    node_flavor:      type: string      label: Node flavor -    description: Flavor of the node servers +    description: Flavor of the compute node servers + +  infra_flavor: +    type: string +    label: Infra flavor +    description: Flavor of the infra node servers  outputs: @@ -83,15 +98,27 @@ outputs:    node_names:      description: Name of the nodes -    value: { get_attr: [ nodes, name ] } +    value: { get_attr: [ compute_nodes, name ] }    node_ips:      description: IPs of the nodes -    value: { get_attr: [ nodes, private_ip ] } +    value: { get_attr: [ compute_nodes, private_ip ] }    node_floating_ips:      description: Floating IPs of the nodes -    value: { get_attr: [ nodes, floating_ip ] } +    value: { get_attr: [ compute_nodes, floating_ip ] } + +  infra_names: +    description: Name of the nodes +    value: { get_attr: [ infra_nodes, name ] } + +  infra_ips: +    description: IPs of the nodes +    value: { get_attr: [ infra_nodes, private_ip ] } + +  infra_floating_ips: +    description: Floating IPs of the nodes +    value: { get_attr: [ infra_nodes, floating_ip ] }  resources: @@ -218,6 +245,29 @@ resources:            remote_mode: remote_group_id            remote_group_id: { get_resource: master-secgrp } +  infra-secgrp: +    type: OS::Neutron::SecurityGroup +    properties: +      name: +        str_replace: +          template: openshift-ansible-cluster_id-infra-secgrp +          params: +            cluster_id: { get_param: cluster_id } +      description: +        str_replace: +          template: Security group for cluster_id OpenShift infrastructure cluster nodes +          params: +            cluster_id: { get_param: cluster_id } +      rules: +        - direction: ingress +          protocol: tcp +          port_range_min: 80 +          port_range_max: 80 +        - direction: ingress +          protocol: tcp +          port_range_min: 443 +          port_range_max: 443 +    masters:      type: OS::Heat::ResourceGroup      properties: @@ -248,7 +298,7 @@ resources:                  cluster_id: { get_param: cluster_id }      depends_on: interface -  nodes: +  compute_nodes:      type: OS::Heat::ResourceGroup      properties:        count: { get_param: num_nodes } @@ -257,12 +307,14 @@ resources:          properties:            name:              str_replace: -              template: cluster_id-k8s_type-%index% +              template: cluster_id-k8s_type-sub_host_type-%index%                params:                  cluster_id: { get_param: cluster_id }                  k8s_type: node +                sub_host_type: compute            cluster_id: { get_param: cluster_id }            type:       node +          subtype:    compute            image:      { get_param: node_image }            flavor:     { get_param: node_flavor }            key_name:   { get_resource: keypair } @@ -277,3 +329,36 @@ resources:                params:                  cluster_id: { get_param: cluster_id }      depends_on: interface + +  infra_nodes: +    type: OS::Heat::ResourceGroup +    properties: +      count: { get_param: num_infra } +      resource_def: +        type: heat_stack_server.yaml +        properties: +          name: +            str_replace: +              template: cluster_id-k8s_type-sub_host_type-%index% +              params: +                cluster_id: { get_param: cluster_id } +                k8s_type: node +                sub_host_type: infra +          cluster_id: { get_param: cluster_id } +          type:       node +          subtype:    infra +          image:      { get_param: infra_image } +          flavor:     { get_param: infra_flavor } +          key_name:   { get_resource: keypair } +          net:        { get_resource: net } +          subnet:     { get_resource: subnet } +          secgrp: +            - { get_resource: node-secgrp } +            - { get_resource: infra-secgrp } +          floating_network: { get_param: external_net } +          net_name: +            str_replace: +              template: openshift-ansible-cluster_id-net +              params: +                cluster_id: { get_param: cluster_id } +    depends_on: interface diff --git a/playbooks/openstack/openshift-cluster/files/heat_stack_server.yaml b/playbooks/openstack/openshift-cluster/files/heat_stack_server.yaml index 55f64211a..9dcab3e60 100644 --- a/playbooks/openstack/openshift-cluster/files/heat_stack_server.yaml +++ b/playbooks/openstack/openshift-cluster/files/heat_stack_server.yaml @@ -19,6 +19,12 @@ parameters:      label: Type      description: Type master or node +  subtype: +    type: string +    label: Sub-type +    description: Sub-type compute or infra for nodes, default otherwise +    default: default +    key_name:      type: string      label: Key name @@ -102,11 +108,12 @@ resources:          env: { get_param: cluster_id }          host-type: { get_param: type }          env-host-type: -          str_template: +          str_replace:              template: cluster_id-openshift-type              params:                cluster_id: { get_param: cluster_id }                type:       { get_param: type } +        sub-host-type:    { get_param: subtype }    port:      type: OS::Neutron::Port diff --git a/playbooks/openstack/openshift-cluster/launch.yml b/playbooks/openstack/openshift-cluster/launch.yml index 3cdd2ae4d..d36bdbf26 100644 --- a/playbooks/openstack/openshift-cluster/launch.yml +++ b/playbooks/openstack/openshift-cluster/launch.yml @@ -27,10 +27,13 @@               -P ssh_incoming={{ openstack_ssh_access_from }}               -P num_masters={{ num_masters }}               -P num_nodes={{ num_nodes }} +             -P num_infra={{ num_infra }}               -P master_image={{ deployment_vars[deployment_type].image }}               -P node_image={{ deployment_vars[deployment_type].image }} +             -P infra_image={{ deployment_vars[deployment_type].image }}               -P master_flavor={{ openstack_flavor["master"] }}               -P node_flavor={{ openstack_flavor["node"] }} +             -P infra_flavor={{ openstack_flavor["infra"] }}               -P ssh_public_key="{{ openstack_ssh_public_key }}"               openshift-ansible-{{ cluster_id }}-stack'      when: stack_show_result.rc == 1 @@ -43,10 +46,13 @@               -P ssh_incoming={{ openstack_ssh_access_from }}               -P num_masters={{ num_masters }}               -P num_nodes={{ num_nodes }} +             -P num_infra={{ num_infra }}               -P master_image={{ deployment_vars[deployment_type].image }}               -P node_image={{ deployment_vars[deployment_type].image }} +             -P infra_image={{ deployment_vars[deployment_type].image }}               -P master_flavor={{ openstack_flavor["master"] }}               -P node_flavor={{ openstack_flavor["node"] }} +             -P infra_flavor={{ openstack_flavor["infra"] }}               -P ssh_public_key="{{ openstack_ssh_public_key }}"               openshift-ansible-{{ cluster_id }}-stack'      when: stack_show_result.rc == 0 @@ -72,7 +78,7 @@        ansible_ssh_host: '{{ item[2] }}'        ansible_ssh_user: "{{ deployment_vars[deployment_type].ssh_user }}"        ansible_sudo: "{{ deployment_vars[deployment_type].sudo }}" -      groups: 'tag_env_{{ cluster_id }}, tag_host-type_master, tag_env-host-type_{{ cluster_id }}-openshift-master' +      groups: 'tag_env_{{ cluster_id }}, tag_host-type_master, tag_env-host-type_{{ cluster_id }}-openshift-master, tag_sub-host-type_default'      with_together:        - parsed_outputs.master_names        - parsed_outputs.master_ips @@ -84,12 +90,24 @@        ansible_ssh_host: '{{ item[2] }}'        ansible_ssh_user: "{{ deployment_vars[deployment_type].ssh_user }}"        ansible_sudo: "{{ deployment_vars[deployment_type].sudo }}" -      groups: 'tag_env_{{ cluster_id }}, tag_host-type_node, tag_env-host-type_{{ cluster_id }}-openshift-node' +      groups: 'tag_env_{{ cluster_id }}, tag_host-type_node, tag_env-host-type_{{ cluster_id }}-openshift-node, tag_sub-host-type_compute'      with_together:        - parsed_outputs.node_names        - parsed_outputs.node_ips        - parsed_outputs.node_floating_ips +  - name: Add new infra instances groups and variables +    add_host: +      hostname: '{{ item[0] }}' +      ansible_ssh_host: '{{ item[2] }}' +      ansible_ssh_user: "{{ deployment_vars[deployment_type].ssh_user }}" +      ansible_sudo: "{{ deployment_vars[deployment_type].sudo }}" +      groups: 'tag_env_{{ cluster_id }}, tag_host-type_node, tag_env-host-type_{{ cluster_id }}-openshift-node, tag_sub-host-type_infra' +    with_together: +      - parsed_outputs.infra_names +      - parsed_outputs.infra_ips +      - parsed_outputs.infra_floating_ips +    - name: Wait for ssh      wait_for:        host: '{{ item }}' @@ -97,6 +115,7 @@      with_flattened:        - parsed_outputs.master_floating_ips        - parsed_outputs.node_floating_ips +      - parsed_outputs.infra_floating_ips    - name: Wait for user setup      command: 'ssh -o StrictHostKeyChecking=no -o PasswordAuthentication=no -o ConnectTimeout=10 -o UserKnownHostsFile=/dev/null {{ deployment_vars[deployment_type].ssh_user }}@{{ item }} echo {{ deployment_vars[deployment_type].ssh_user }} user is setup' @@ -107,6 +126,7 @@      with_flattened:        - parsed_outputs.master_floating_ips        - parsed_outputs.node_floating_ips +      - parsed_outputs.infra_floating_ips  - include: update.yml diff --git a/playbooks/openstack/openshift-cluster/terminate.yml b/playbooks/openstack/openshift-cluster/terminate.yml index fc4ec3c88..62df2be73 100644 --- a/playbooks/openstack/openshift-cluster/terminate.yml +++ b/playbooks/openstack/openshift-cluster/terminate.yml @@ -5,6 +5,31 @@    vars_files:    - vars.yml    tasks: +  - set_fact: cluster_group=tag_env_{{ cluster_id }} +  - add_host: +      name: "{{ item }}" +      groups: oo_hosts_to_terminate +      ansible_ssh_user: "{{ deployment_vars[deployment_type].ssh_user }}" +      ansible_sudo: "{{ deployment_vars[deployment_type].sudo }}" +    with_items: groups[cluster_group] | default([]) + +- name: Unsubscribe VMs +  hosts: oo_hosts_to_terminate +  vars_files: +  - vars.yml +  roles: +  - role: rhel_unsubscribe +    when: deployment_type == "enterprise" and +          ansible_distribution == "RedHat" and +          lookup('oo_option', 'rhel_skip_subscription') | default(rhsub_skip, True) | +            default('no', True) | lower in ['no', 'false'] + +- hosts: localhost +  connection: local +  gather_facts: no +  vars_files: +  - vars.yml +  tasks:    - name: Delete the OpenStack Stack      command: 'heat stack-delete openshift-ansible-{{ cluster_id }}-stack'      register: stack_delete_result diff --git a/playbooks/openstack/openshift-cluster/vars.yml b/playbooks/openstack/openshift-cluster/vars.yml index d077a6ced..43e25f2e6 100644 --- a/playbooks/openstack/openshift-cluster/vars.yml +++ b/playbooks/openstack/openshift-cluster/vars.yml @@ -19,6 +19,7 @@ openstack_ssh_access_from:      "{{ lookup('oo_option', 'ssh_from')          |                                      default('0.0.0.0/0',                     True) }}"  openstack_flavor:    master: "{{ lookup('oo_option', 'master_flavor'    ) | default('m1.small',  True) }}" +  infra:  "{{ lookup('oo_option', 'infra_flavor'     ) | default('m1.small',  True) }}"    node:   "{{ lookup('oo_option', 'node_flavor'      ) | default('m1.medium', True) }}"  deployment_vars: | 
