diff options
Diffstat (limited to 'playbooks/common')
3 files changed, 34 insertions, 41 deletions
| 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..eb12fcabe 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.  ############################################################################### @@ -40,6 +11,20 @@    - include: docker_upgrade.yml      when: not openshift.common.is_atomic | bool +# The cli image is used by openshift_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: +  - openshift_facts +  tasks: +  - name: Pull Images +    command: > +      docker pull {{ item }}:latest +    with_items: +    - "{{ openshift.common.cli_image }}" +  ###############################################################################  # Upgrade Masters  ############################################################################### | 
