diff options
| author | Thomas Wiest <twiest@users.noreply.github.com> | 2015-04-20 17:25:57 -0400 | 
|---|---|---|
| committer | Thomas Wiest <twiest@users.noreply.github.com> | 2015-04-20 17:25:57 -0400 | 
| commit | 96dd0ab929b7f391eee9b23209aa377537114b72 (patch) | |
| tree | d1f9aa5becd04097213fe56aa4982bd35830df10 /playbooks/gce/openshift-node | |
| parent | 0722304b2f9c94a2f70054e0a3c7feceaedb195c (diff) | |
| parent | dbb252bc04a6488c1fde05dbc325b246fd4a651e (diff) | |
| download | openshift-96dd0ab929b7f391eee9b23209aa377537114b72.tar.gz openshift-96dd0ab929b7f391eee9b23209aa377537114b72.tar.bz2 openshift-96dd0ab929b7f391eee9b23209aa377537114b72.tar.xz openshift-96dd0ab929b7f391eee9b23209aa377537114b72.zip | |
Merge pull request #139 from detiber/configUpdatesMaster
Massive refactor, deployment-type support, config updates, reduce duplication
Diffstat (limited to 'playbooks/gce/openshift-node')
| -rw-r--r-- | playbooks/gce/openshift-node/config.yml | 106 | ||||
| -rw-r--r-- | playbooks/gce/openshift-node/launch.yml | 6 | ||||
| -rw-r--r-- | playbooks/gce/openshift-node/terminate.yml | 11 | ||||
| -rw-r--r-- | playbooks/gce/openshift-node/vars.yml | 3 | 
4 files changed, 22 insertions, 104 deletions
| diff --git a/playbooks/gce/openshift-node/config.yml b/playbooks/gce/openshift-node/config.yml index 771cc3a94..5b1601176 100644 --- a/playbooks/gce/openshift-node/config.yml +++ b/playbooks/gce/openshift-node/config.yml @@ -1,100 +1,24 @@  --- -- name: node/config.yml, populate oo_nodes_to_config host group if needed +- name: Populate oo_nodes_to_config and oo_first_master host groups    hosts: localhost    gather_facts: no    tasks: -  - name: Evaluate oo_host_group_exp -    add_host: "name={{ item }} groups=oo_nodes_to_config" -    with_items: "{{ oo_host_group_exp | default('') }}" -    when: oo_host_group_exp is defined -  - add_host: +  - name: Evaluate oo_nodes_to_config +    add_host: +      name: "{{ item }}" +      groups: oo_nodes_to_config +      ansible_ssh_user: root +    with_items: oo_host_group_exp | default([]) +  - name: Evaluate oo_first_master +    add_host:        name: "{{ groups['tag_env-host-type-' ~ cluster_id ~ '-openshift-master'][0] }}"        groups: oo_first_master -    when: oo_host_group_exp is defined +      ansible_ssh_user: root -- name: Gather and set facts for hosts to configure -  hosts: oo_nodes_to_config -  roles: -  - openshift_facts -  tasks: -  # Since the master is registering the nodes before they are configured, we -  # need to make sure to set the node properties beforehand if we do not want -  # the defaults -  - openshift_facts: -      role: "{{ item.role }}" -      local_facts: "{{ item.local_facts }}" -    with_items: -    - role: common -      local_facts: -        hostname: "{{ gce_private_ip }}" -    - role: node -      local_facts: -        external_id: "{{ openshift_node_external_id | default(None) }}" -        resources_cpu: "{{ openshfit_node_resources_cpu | default(None) }}" -        resources_memory: "{{ openshfit_node_resources_memory | default(None) }}" -        pod_cidr: "{{ openshfit_node_pod_cidr | default(None) }}" -        labels: "{{ openshfit_node_labels | default(None) }}" -        annotations: "{{ openshfit_node_annotations | default(None) }}" - - -- name: Register nodes -  hosts: oo_first_master -  vars: -    openshift_nodes: "{{ hostvars -          | oo_select_keys(groups['oo_nodes_to_config']) }}" -  roles: -  - openshift_register_nodes -  tasks: -  - name: Create local temp directory for syncing certs -    local_action: command /usr/bin/mktemp -d /tmp/openshift-ansible-XXXXXXX -    register: mktemp - -  - name: Sync master certs to localhost -    synchronize: -      mode: pull -      checksum: yes -      src: /var/lib/openshift/openshift.local.certificates -      dest: "{{ mktemp.stdout }}" - -- name: Configure instances -  hosts: oo_nodes_to_config -  vars_files: -  - vars.yml +- include: ../../common/openshift-node/config.yml    vars: -    sync_tmpdir: "{{ hostvars[groups['oo_first_master'][0]].mktemp.stdout }}" -    cert_parent_rel_path: openshift.local.certificates -    cert_rel_path: "{{ cert_parent_rel_path }}/node-{{ openshift.common.hostname }}" -    cert_base_path: /var/lib/openshift -    cert_parent_path: "{{ cert_base_path }}/{{ cert_parent_rel_path }}" -    cert_path: "{{ cert_base_path }}/{{ cert_rel_path }}" -  pre_tasks: -  - name: Ensure certificate directories exists -    file: -      path: "{{ item }}" -      state: directory -    with_items: -    - "{{ cert_path }}" -    - "{{ cert_parent_path }}/ca" - -  # TODO: notify restart openshift-node and/or restart openshift-sdn-node, -  # possibly test service started time against certificate/config file -  # timestamps in openshift-node or openshift-sdn-node to trigger notify -  - name: Sync certs to nodes -    synchronize: -      checksum: yes -      src: "{{ item.src }}" -      dest: "{{ item.dest }}" -      owner: no -      group: no -    with_items: -    - src: "{{ sync_tmpdir }}/{{ cert_rel_path }}" -      dest: "{{ cert_parent_path }}" -    - src: "{{ sync_tmpdir }}/{{ cert_parent_rel_path }}/ca/cert.crt" -      dest: "{{ cert_parent_path }}/ca/cert.crt" -  - local_action: file name={{ sync_tmpdir }} state=absent -    run_once: true -  roles: -    - openshift_node -    - os_env_extras -    - os_env_extras_node +    openshift_cluster_id: "{{ cluster_id }}" +    openshift_debug_level: 4 +    openshift_deployment_type: "{{ deployment_type }}" +    openshift_hostname: "{{ gce_private_ip }}" diff --git a/playbooks/gce/openshift-node/launch.yml b/playbooks/gce/openshift-node/launch.yml index 73d0478ab..086ba58bc 100644 --- a/playbooks/gce/openshift-node/launch.yml +++ b/playbooks/gce/openshift-node/launch.yml @@ -8,14 +8,12 @@    connection: local    gather_facts: no +# TODO: modify image based on deployment_type    vars:      inst_names: "{{ oo_new_inst_names }}"      machine_type: n1-standard-1      image: libra-rhel7 -  vars_files: -      - vars.yml -    tasks:      - name: Launch instances        gce: @@ -37,7 +35,7 @@        with_items: gce.instance_data      - name: Wait for ssh -      wait_for: "port=22 host={{ item.public_ip }}" +      wait_for: port=22 host={{ item.public_ip }}        with_items: gce.instance_data      - name: Wait for root user setup diff --git a/playbooks/gce/openshift-node/terminate.yml b/playbooks/gce/openshift-node/terminate.yml index 7d71dfcab..357e0c295 100644 --- a/playbooks/gce/openshift-node/terminate.yml +++ b/playbooks/gce/openshift-node/terminate.yml @@ -3,10 +3,9 @@    hosts: localhost    gather_facts: no    tasks: -    - name: Evaluate oo_host_group_exp if it's set -      add_host: "name={{ item }} groups=oo_nodes_to_terminate" -      with_items: "{{ oo_host_group_exp | default('') }}" -      when: oo_host_group_exp is defined +    - name: Evaluate oo_nodes_to_terminate +      add_host: name={{ item }} groups=oo_nodes_to_terminate +      with_items: oo_host_group_exp | default([])  - name: Terminate node instances    hosts: localhost @@ -22,6 +21,7 @@          instance_names: "{{ groups['oo_nodes_to_terminate'] }}"          disks: "{{ groups['oo_nodes_to_terminate'] }}"        register: gce +      when: "'oo_nodes_to_terminate' in groups"      - name: Remove disks of instances        gce_pd: @@ -32,5 +32,4 @@          zone: "{{ gce.zone }}"          state: absent        with_items: gce.instance_names - - +      when: "'oo_nodes_to_terminate' in groups" diff --git a/playbooks/gce/openshift-node/vars.yml b/playbooks/gce/openshift-node/vars.yml deleted file mode 100644 index c196b2fca..000000000 --- a/playbooks/gce/openshift-node/vars.yml +++ /dev/null @@ -1,3 +0,0 @@ ---- -openshift_debug_level: 4 -openshift_cluster_id: "{{ cluster_id }}" | 
