diff options
| author | Michael Gugino <mgugino@redhat.com> | 2017-09-29 15:03:09 -0400 | 
|---|---|---|
| committer | Michael Gugino <mgugino@redhat.com> | 2017-10-02 11:34:49 -0400 | 
| commit | 614dc4ff5a975be8438c9e034c84dba3410c0a20 (patch) | |
| tree | 8cf7d7e2d60562e7d1834b55e8d6fcce7bdf8b2c /playbooks/aws/openshift-cluster | |
| parent | e54cb2611e86c43650512ee3afee2c6ce846b064 (diff) | |
| download | openshift-614dc4ff5a975be8438c9e034c84dba3410c0a20.tar.gz openshift-614dc4ff5a975be8438c9e034c84dba3410c0a20.tar.bz2 openshift-614dc4ff5a975be8438c9e034c84dba3410c0a20.tar.xz openshift-614dc4ff5a975be8438c9e034c84dba3410c0a20.zip | |
Make provisioning steps more reusable
Reorganizing and making some of the plays more
reusable.
Diffstat (limited to 'playbooks/aws/openshift-cluster')
| -rw-r--r-- | playbooks/aws/openshift-cluster/build_ami.yml | 70 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/install.yml | 63 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/provision.yml | 2 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/provision_instance.yml | 12 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/provision_sec_group.yml | 13 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/provision_ssh_keypair.yml | 12 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/provision_vpc.yml | 10 | ||||
| -rw-r--r-- | playbooks/aws/openshift-cluster/seal_ami.yml | 12 | 
8 files changed, 81 insertions, 113 deletions
| diff --git a/playbooks/aws/openshift-cluster/build_ami.yml b/playbooks/aws/openshift-cluster/build_ami.yml index 1e54f0467..1ab1e8041 100644 --- a/playbooks/aws/openshift-cluster/build_ami.yml +++ b/playbooks/aws/openshift-cluster/build_ami.yml @@ -17,35 +17,17 @@      - name: openshift_aws_region        msg: "openshift_aws_region={{ openshift_aws_region | default('us-east-1') }}" -  - name: create an instance and prepare for ami -    include_role: -      name: openshift_aws -      tasks_from: build_ami.yml -    vars: -      openshift_aws_node_group_type: compute +- include: provision_vpc.yml -  - name: fetch newly created instances -    ec2_remote_facts: -      region: "{{ openshift_aws_region | default('us-east-1') }}" -      filters: -        "tag:Name": "{{ openshift_aws_base_ami_name | default('ami_base') }}" -        instance-state-name: running -    register: instancesout -    retries: 20 -    delay: 3 -    until: instancesout.instances|length > 0 +- include: provision_ssh_keypair.yml -  - name: wait for ssh to become available -    wait_for: -      port: 22 -      host: "{{ instancesout.instances[0].public_ip_address }}" -      timeout: 300 -      search_regex: OpenSSH +- include: provision_sec_group.yml +  vars: +    openshift_aws_node_group_type: compute -  - name: add host to nodes -    add_host: -      groups: nodes -      name: "{{ instancesout.instances[0].public_dns_name }}" +- include: provision_instance.yml +  vars: +    openshift_aws_node_group_type: compute  - hosts: nodes    gather_facts: False @@ -54,34 +36,10 @@      set_fact:        ansible_ssh_user: "{{ openshift_aws_build_ami_ssh_user | default('root') }}" -- name: normalize groups -  include: ../../byo/openshift-cluster/initialize_groups.yml +# This is the part that installs all of the software and configs for the instance +# to become a node. +- include: ../../common/openshift-node/image_prep.yml -- name: run the std_include -  include: ../../common/openshift-cluster/evaluate_groups.yml - -- name: run the std_include -  include: ../../common/openshift-cluster/initialize_facts.yml - -- name: run the std_include -  include: ../../common/openshift-cluster/initialize_openshift_repos.yml - -- name: run node config setup -  include: ../../common/openshift-node/setup.yml - -- name: run node config -  include: ../../common/openshift-node/configure_nodes.yml - -- name: Re-enable excluders -  include: ../../common/openshift-node/enable_excluders.yml - -- hosts: localhost -  connection: local -  become: no -  tasks: -  - name: seal the ami -    include_role: -      name: openshift_aws -      tasks_from: seal_ami.yml -    vars: -      openshift_aws_ami_name: "openshift-gi-{{ lookup('pipe', 'date +%Y%m%d%H%M')}}" +- include: seal_ami.yml +  vars: +    openshift_aws_ami_name: "openshift-gi-{{ lookup('pipe', 'date +%Y%m%d%H%M')}}" diff --git a/playbooks/aws/openshift-cluster/install.yml b/playbooks/aws/openshift-cluster/install.yml index 86d58a68e..4d0bf9531 100644 --- a/playbooks/aws/openshift-cluster/install.yml +++ b/playbooks/aws/openshift-cluster/install.yml @@ -1,68 +1,19 @@  --- -- name: Setup the vpc and the master node group +- name: Setup the master node group    hosts: localhost    tasks: -  - name: Alert user to variables needed - clusterid -    debug: -      msg: "openshift_aws_clusterid={{ openshift_aws_clusterid | default('default') }}" - -  - name: Alert user to variables needed - region -    debug: -      msg: "openshift_aws_region={{ openshift_aws_region | default('us-east-1') }}" - -  - name: fetch newly created instances -    ec2_remote_facts: -      region: "{{ openshift_aws_region | default('us-east-1') }}" -      filters: -        "tag:clusterid": "{{ openshift_aws_clusterid | default('default') }}" -        "tag:host-type": master -        instance-state-name: running -    register: instancesout -    retries: 20 -    delay: 3 -    until: instancesout.instances|length > 0 - -  - name: add new master to masters group -    add_host: -      groups: "masters,etcd,nodes" -      name: "{{ item.public_ip_address }}" -      hostname: "{{ openshift_aws_clusterid | default('default') }}-master-{{ item.id[:-5] }}" -    with_items: "{{ instancesout.instances }}" - -  - name: wait for ssh to become available -    wait_for: -      port: 22 -      host: "{{ item.public_ip_address }}" -      timeout: 300 -      search_regex: OpenSSH -    with_items: "{{ instancesout.instances }}" +  - include_role: +      name: openshift_aws +      tasks_from: setup_master_group.yml  - name: set the master facts for hostname to elb    hosts: masters    gather_facts: no    remote_user: root    tasks: -  - name: fetch elbs -    ec2_elb_facts: -      region: "{{ openshift_aws_region | default('us-east-1') }}" -      names: -      - "{{ item }}" -    with_items: -    - "{{ openshift_aws_clusterid | default('default') }}-master-external" -    - "{{ openshift_aws_clusterid | default('default') }}-master-internal" -    delegate_to: localhost -    register: elbs - -  - debug: var=elbs - -  - name: set fact -    set_fact: -      openshift_master_cluster_hostname: "{{ elbs.results[1].elbs[0].dns_name }}" -      osm_custom_cors_origins: -      - "{{ elbs.results[1].elbs[0].dns_name }}" -      - "console.{{ openshift_aws_clusterid | default('default') }}.openshift.com" -      - "api.{{ openshift_aws_clusterid | default('default') }}.openshift.com" -    with_items: "{{ groups['masters'] }}" +  - include_role: +      name: openshift_aws +      tasks_from: master_facts.yml  - name: normalize groups    include: ../../byo/openshift-cluster/initialize_groups.yml diff --git a/playbooks/aws/openshift-cluster/provision.yml b/playbooks/aws/openshift-cluster/provision.yml index 8f018abd0..4b5bd22ea 100644 --- a/playbooks/aws/openshift-cluster/provision.yml +++ b/playbooks/aws/openshift-cluster/provision.yml @@ -1,5 +1,5 @@  --- -- name: Setup the vpc and the master node group +- name: Setup the elb and the master node group    hosts: localhost    tasks: diff --git a/playbooks/aws/openshift-cluster/provision_instance.yml b/playbooks/aws/openshift-cluster/provision_instance.yml new file mode 100644 index 000000000..6e843453c --- /dev/null +++ b/playbooks/aws/openshift-cluster/provision_instance.yml @@ -0,0 +1,12 @@ +--- +# If running this play directly, be sure the variable +# 'openshift_aws_node_group_type' is set correctly for your usage. +# See build_ami.yml for an example. +- hosts: localhost +  connection: local +  gather_facts: no +  tasks: +  - name: create an instance and prepare for ami +    include_role: +      name: openshift_aws +      tasks_from: provision_instance.yml diff --git a/playbooks/aws/openshift-cluster/provision_sec_group.yml b/playbooks/aws/openshift-cluster/provision_sec_group.yml new file mode 100644 index 000000000..039357adb --- /dev/null +++ b/playbooks/aws/openshift-cluster/provision_sec_group.yml @@ -0,0 +1,13 @@ +--- +# If running this play directly, be sure the variable +# 'openshift_aws_node_group_type' is set correctly for your usage. +# See build_ami.yml for an example. +- hosts: localhost +  connection: local +  gather_facts: no +  tasks: +  - name: create an instance and prepare for ami +    include_role: +      name: openshift_aws +      tasks_from: security_group.yml +    when: openshift_aws_create_security_groups | default(True) | bool diff --git a/playbooks/aws/openshift-cluster/provision_ssh_keypair.yml b/playbooks/aws/openshift-cluster/provision_ssh_keypair.yml new file mode 100644 index 000000000..3ec683958 --- /dev/null +++ b/playbooks/aws/openshift-cluster/provision_ssh_keypair.yml @@ -0,0 +1,12 @@ +--- +- hosts: localhost +  connection: local +  gather_facts: no +  tasks: +  - name: create an instance and prepare for ami +    include_role: +      name: openshift_aws +      tasks_from: ssh_keys.yml +    vars: +      openshift_aws_node_group_type: compute +    when: openshift_aws_users | default([]) | length  > 0 diff --git a/playbooks/aws/openshift-cluster/provision_vpc.yml b/playbooks/aws/openshift-cluster/provision_vpc.yml new file mode 100644 index 000000000..0a23a6d32 --- /dev/null +++ b/playbooks/aws/openshift-cluster/provision_vpc.yml @@ -0,0 +1,10 @@ +--- +- hosts: localhost +  connection: local +  gather_facts: no +  tasks: +  - name: create a vpc +    include_role: +      name: openshift_aws +      tasks_from: vpc.yml +    when: openshift_aws_create_vpc | default(True) | bool diff --git a/playbooks/aws/openshift-cluster/seal_ami.yml b/playbooks/aws/openshift-cluster/seal_ami.yml new file mode 100644 index 000000000..8239a64fb --- /dev/null +++ b/playbooks/aws/openshift-cluster/seal_ami.yml @@ -0,0 +1,12 @@ +--- +# If running this play directly, be sure the variable +# 'openshift_aws_ami_name' is set correctly for your usage. +# See build_ami.yml for an example. +- hosts: localhost +  connection: local +  become: no +  tasks: +  - name: seal the ami +    include_role: +      name: openshift_aws +      tasks_from: seal_ami.yml | 
