diff options
Diffstat (limited to 'playbooks/common')
6 files changed, 51 insertions, 44 deletions
| diff --git a/playbooks/common/openshift-cluster/additional_config.yml b/playbooks/common/openshift-cluster/additional_config.yml index 1ac78468a..44bf962c9 100644 --- a/playbooks/common/openshift-cluster/additional_config.yml +++ b/playbooks/common/openshift-cluster/additional_config.yml @@ -49,8 +49,6 @@      openshift_serviceaccounts_namespace: default      openshift_serviceaccounts_sccs:      - privileged -  - role: openshift_router -    when: deploy_infra | bool    - role: openshift_registry      registry_volume_claim: "{{ openshift.hosted.registry.storage.volume.name }}-claim"      when: deploy_infra | bool and attach_registry_volume | bool diff --git a/playbooks/common/openshift-cluster/config.yml b/playbooks/common/openshift-cluster/config.yml index 2411e7360..6f908fa7f 100644 --- a/playbooks/common/openshift-cluster/config.yml +++ b/playbooks/common/openshift-cluster/config.yml @@ -34,3 +34,5 @@  - include: additional_config.yml  - include: ../openshift-node/config.yml + +- include: openshift_hosted.yml diff --git a/playbooks/common/openshift-cluster/openshift_hosted.yml b/playbooks/common/openshift-cluster/openshift_hosted.yml new file mode 100644 index 000000000..1cbc0f544 --- /dev/null +++ b/playbooks/common/openshift-cluster/openshift_hosted.yml @@ -0,0 +1,5 @@ +- name: Create Hosted Resources +  hosts: oo_first_master +  roles: +  - role: openshift_hosted +    openshift_hosted_router_registryurl: "{{ hostvars[groups.oo_first_master.0].openshift.master.registry_url }}" diff --git a/playbooks/common/openshift-cluster/upgrades/files/openshift_container_versions.sh b/playbooks/common/openshift-cluster/upgrades/files/openshift_container_versions.sh index 7a1edf38f..96944a78b 100644 --- a/playbooks/common/openshift-cluster/upgrades/files/openshift_container_versions.sh +++ b/playbooks/common/openshift-cluster/upgrades/files/openshift_container_versions.sh @@ -3,19 +3,19 @@  # Here we don't really care if this is a master, api, controller or node image.  # We just need to know the version of one of them.  unit_file=$(ls /etc/systemd/system/${1}*.service | head -n1) -installed_container_name=$(basename -s .service ${unit_file}) -installed=$(docker exec ${installed_container_name} openshift version 2> /dev/null | grep openshift | awk '{ print $2 }' | cut -f1 -d"-" | tr -d 'v')  if [ ${1} == "origin" ]; then      image_name="openshift/origin"  elif grep aep $unit_file 2>&1 > /dev/null; then -    image_name="aep3/aep" +    image_name="aep3/node"  elif grep openshift3 $unit_file 2>&1 > /dev/null; then -    image_name="openshift3/ose" +    image_name="openshift3/node"  fi +installed=$(docker run --rm --entrypoint=/bin/openshift ${image_name} version 2> /dev/null | grep openshift | awk '{ print $2 }' | cut -f1 -d"-" | tr -d 'v') +  docker pull ${image_name} 2>&1 > /dev/null -available=$(docker run --rm ${image_name} version 2> /dev/null | grep openshift | awk '{ print $2 }' | cut -f1 -d"-" | tr -d 'v') +available=$(docker run --rm --entrypoint=/bin/openshift ${image_name} version 2> /dev/null | grep openshift | awk '{ print $2 }' | cut -f1 -d"-" | tr -d 'v')  echo "---"  echo "curr_version: ${installed}" diff --git a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/pre.yml b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/pre.yml index 6e6f31195..21480ba55 100644 --- a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/pre.yml +++ b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/pre.yml @@ -38,7 +38,7 @@        msg: >          This upgrade does not support Pacemaker:          https://docs.openshift.{{ g_pacemaker_upgrade_url_segment }}/install_config/upgrading/pacemaker_to_native_ha.html -    when: openshift.master.cluster_method == 'pacemaker' +    when: openshift.master.cluster_method is defined and openshift.master.cluster_method == 'pacemaker'    - fail:        msg: > @@ -57,6 +57,11 @@    roles:    - openshift_facts    tasks: +  - openshift_facts: +      role: master +      local_facts: +        ha: "{{ groups.oo_masters_to_config | length > 1 }}" +    - name: Ensure Master is running      service:        name: "{{ openshift.common.service_type }}-master" @@ -77,11 +82,6 @@        state: started        enabled: yes      when: openshift.master.ha is defined and openshift.master.ha | bool and openshift.common.is_containerized | bool -  post_tasks: -  - openshift_facts: -      role: master -      local_facts: -        ha: "{{ groups.oo_masters_to_config | length > 1 }}"  - name: Verify upgrade can proceed    hosts: oo_nodes_to_config @@ -105,8 +105,12 @@    - include: ../../../../../roles/openshift_master/handlers/main.yml    - include: ../../../../../roles/openshift_node/handlers/main.yml    roles: +  # We want the cli role to evaluate so that the containerized oc/oadm wrappers +  # are modified to use the correct image tag.  However, this can trigger a +  # docker restart if new configuration is laid down which would immediately +  # pull the latest image and defeat the purpose of these tasks.    - openshift_cli -  tasks: +  pre_tasks:    - name: Clean package cache      command: "{{ ansible_pkg_mgr }} clean all"      when: not openshift.common.is_atomic | bool @@ -147,6 +151,10 @@    - fail:        msg: Verifying the correct version was found +    when: g_aos_versions.curr_version == "" + +  - fail: +      msg: Verifying the correct version was found      when: verify_upgrade_version is defined and g_new_version != verify_upgrade_version    - include_vars: ../../../../../roles/openshift_master/vars/main.yml diff --git a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/upgrade.yml b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/upgrade.yml index 041ad5a9a..8852bb8de 100644 --- a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/upgrade.yml +++ b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/upgrade.yml @@ -1,33 +1,4 @@  --- -# This is a workaround for authenticated registries -- name: Download new images -  hosts: oo_nodes_to_config -  roles: -  - openshift_facts -  tasks: -  - name: Pull Images -    command: > -      docker pull {{ item }}:v{{ g_new_version }} -    with_items: -    - "{{ openshift.node.node_image }}" -    - "{{ openshift.node.ovs_image }}" -    - "{{ openshift.common.pod_image }}" -    - "{{ openshift.common.router_image }}" -    - "{{ openshift.common.registry_image }}" -    - "{{ openshift.common.deployer_image }}" - -# This is a workaround for authenticated registries -- name: Download new images -  hosts: oo_masters_to_config -  roles: -  - openshift_facts -  tasks: -  - name: Pull Images -    command: > -      docker pull {{ item }}:v{{ g_new_version }} -    with_items: -    - "{{ openshift.master.master_image }}" -  ###############################################################################  # The restart playbook should be run after this playbook completes.  ############################################################################### @@ -39,6 +10,29 @@    tasks:    - include: docker_upgrade.yml      when: not openshift.common.is_atomic | bool +  - name: Set post docker install facts +    openshift_facts: +      role: "{{ item.role }}" +      local_facts: "{{ item.local_facts }}" +    with_items: +    - role: docker +      local_facts: +        openshift_image_tag: "v{{ g_new_version }}" +        openshift_version: "{{ g_new_version }}" + +# The cli image is used by openshift_docker_facts to determine the currently installed +# version.  We need to explicitly pull the latest image to handle cases where +# the locally cached 'latest' tag is older the g_new_version. +- name: Download cli image +  hosts: oo_masters_to_config:oo_nodes_to_config +  roles: +  - { role: openshift_docker_facts } +  tasks: +  - name: Pull Images +    command: > +      docker pull {{ item }}:latest +    with_items: +    - "{{ openshift.common.cli_image }}"  ###############################################################################  # Upgrade Masters @@ -139,7 +133,7 @@  - name: Reconcile Cluster Roles and Cluster Role Bindings and Security Context Constraints    hosts: oo_masters_to_config    roles: -  - { role: openshift_cli, openshift_image_tag: "v{{ g_new_version }}"  } +  - { role: openshift_cli, openshift_image_tag: "v{{ g_new_version }}" }    vars:      origin_reconcile_bindings: "{{ deployment_type == 'origin' and g_new_version | version_compare('1.0.6', '>') }}"      ent_reconcile_bindings: true | 
