diff options
Diffstat (limited to 'playbooks')
4 files changed, 71 insertions, 64 deletions
| diff --git a/playbooks/common/openshift-cluster/upgrades/files/ensure_system_units_have_version.sh b/playbooks/common/openshift-cluster/upgrades/files/ensure_system_units_have_version.sh deleted file mode 100644 index 239f43314..000000000 --- a/playbooks/common/openshift-cluster/upgrades/files/ensure_system_units_have_version.sh +++ /dev/null @@ -1,51 +0,0 @@ -#!/bin/bash -set -e - -SERVICE_TYPE=$1 -DEPLOYMENT_TYPE=$2 -VERSION="v${3}" - -add_image_version_to_sysconfig () { -    unit_name=$2 -    sysconfig_file=/etc/sysconfig/${unit_name} - -    if ! grep IMAGE_VERSION ${sysconfig_file}; then -        sed -i "/CONFIG_FILE/a IMAGE_VERSION=${1}" ${sysconfig_file} -    else -        sed -i "s/\(IMAGE_VERSION=\).*/\1${1}/" ${sysconfig_file} -    fi -} - -add_image_version_to_unit () { -    deployment_type=$1 -    unit_file=$2 - -    if ! grep IMAGE_VERSION $unit_file; then -        image_namespace="openshift/" -        if [ $deployment_type == "atomic-enterprise" ]; then -            image_namespace="aep3/" -        elif [ $deployment_type == "openshift-enterprise" ]; then -            image_namespace="openshift3/" -        fi - -        sed -i "s|\(${image_namespace}[a-zA-Z0-9]\+\)|\1:\${IMAGE_VERSION}|" $unit_file -    fi -} - -for unit_file in $(ls /etc/systemd/system/${SERVICE_TYPE}*.service); do -    unit_name=$(basename -s .service ${unit_file}) -    add_image_version_to_sysconfig $VERSION $unit_name -    add_image_version_to_unit $DEPLOYMENT_TYPE $unit_file -done - -if [ -e /etc/sysconfig/openvswitch ]; then -    add_image_version_to_sysconfig $VERSION openvswitch -else -    echo IMAGE_VERSION=${VERSION} > /etc/sysconfig/openvswitch -fi  -if ! grep EnvironmentFile /etc/systemd/system/openvswitch.service > /dev/null; then -    sed -i "/Service/a EnvironmentFile=/etc/sysconfig/openvswitch" /etc/systemd/system/openvswitch.service -fi -add_image_version_to_unit $DEPLOYMENT_TYPE /etc/systemd/system/openvswitch.service - -systemctl daemon-reload diff --git a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/containerized_upgrade.yml b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/containerized_upgrade.yml index 696994688..cc587bfa1 100644 --- a/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/containerized_upgrade.yml +++ b/playbooks/common/openshift-cluster/upgrades/v3_1_to_v3_2/containerized_upgrade.yml @@ -1,8 +1,10 @@ -- name: Update system_units -  script: ../files/ensure_system_units_have_version.sh {{ openshift.common.service_type }} {{ openshift.common.deployment_type }} {{ g_new_version }} +- include_vars: ../../../../../roles/openshift_node/vars/main.yml + +- name: Update systemd units +  include: ../../../../../roles/openshift_node/tasks/systemd_units.yml openshift_version=g_aos_versions.avail_version  - name: Verifying the correct version was configured -  command: grep {{ verify_upgrade_version }} {{ item }} +  shell: grep {{ verify_upgrade_version }} {{ item }}    with_items:      - /etc/sysconfig/openvswitch      - /etc/sysconfig/{{ openshift.common.service_type }}* 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 668a80996..d491575f8 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 @@ -47,32 +47,34 @@  - name: Verify upgrade can proceed    hosts: oo_masters_to_config -  vars: -    openshift_master_ha: "{{ groups.oo_masters_to_config | length > 1 }}" +  roles: +  - openshift_facts    tasks:    - name: Ensure Master is running      service:        name: "{{ openshift.common.service_type }}-master"        state: started        enabled: yes -    when: not openshift_master_ha | bool and openshift.common.is_containerized | bool +    when: openshift.master.ha is defined and not openshift.master.ha | bool and openshift.common.is_containerized | bool    - name: Ensure HA Master is running      service:        name: "{{ openshift.common.service_type }}-master-api"        state: started        enabled: yes -    when: openshift_master_ha | bool and openshift.common.is_containerized | bool +    when: openshift.master.ha is defined and openshift.master.ha | bool and openshift.common.is_containerized | bool    - name: Ensure HA Master is running      service:        name: "{{ openshift.common.service_type }}-master-controllers"        state: started        enabled: yes -    when: openshift_master_ha | bool and openshift.common.is_containerized | bool +    when: openshift.master.ha is defined and openshift.master.ha | bool and openshift.common.is_containerized | bool  - name: Verify upgrade can proceed    hosts: oo_nodes_to_config +  roles: +  - openshift_facts    tasks:    - name: Ensure Node is running      service: @@ -85,6 +87,9 @@    hosts: oo_masters_to_config:oo_nodes_to_config    vars:      target_version: "{{ '1.2' if deployment_type == 'origin' else '3.1.1.900' }}" +  handlers: +  - include: ../../../../../roles/openshift_master/handlers/main.yml +  - include: ../../../../../roles/openshift_node/handlers/main.yml    roles:    - openshift_cli    tasks: @@ -130,9 +135,19 @@        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 +    when: inventory_hostname in groups.oo_masters_to_config +    - name: Update systemd units -    script: ../files/ensure_system_units_have_version.sh {{ openshift.common.service_type }} {{ openshift.common.deployment_type }} {{ g_aos_versions.curr_version }} -    when: openshift.common.is_containerized | bool +    include: ../../../../../roles/openshift_master/tasks/systemd_units.yml openshift_version=g_aos_versions.curr_version +    when: inventory_hostname in groups.oo_masters_to_config + +  - include_vars: ../../../../../roles/openshift_node/vars/main.yml +    when: inventory_hostname in groups.oo_nodes_to_config + +  - name: Update systemd units +    include: ../../../../../roles/openshift_node/tasks/systemd_units.yml openshift_version=g_aos_versions.curr_version +    when: inventory_hostname in groups.oo_nodes_to_config    # Note: the version number is hardcoded here in hopes of catching potential    # bugs in how g_aos_versions.curr_version is set @@ -143,6 +158,13 @@        - /etc/sysconfig/{{ openshift.common.service_type }}*      when: verify_upgrade_version is defined +  - name: Verifying the image version is used in the systemd unit +    shell: grep IMAGE_VERSION {{ item }} +    with_items: +      - /etc/systemd/system/openvswitch.service +      - /etc/systemd/system/{{ openshift.common.service_type }}*.service +    when: openshift.common.is_containerized | bool +    - fail:        msg: This playbook requires Origin 1.1 or later      when: deployment_type == 'origin' and g_aos_versions.curr_version | version_compare('1.1','<') 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 d84d9f674..481d8e67a 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,4 +1,33 @@  --- +# 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.  ############################################################################### @@ -16,14 +45,18 @@  ###############################################################################  - name: Upgrade master    hosts: oo_masters_to_config +  handlers: +  - include: ../../../../../roles/openshift_master/handlers/main.yml    roles:    - openshift_facts    tasks:    - include: rpm_upgrade.yml component=master      when: not openshift.common.is_containerized | bool -  - include: containerized_upgrade.yml -    when: openshift.common.is_containerized | bool +  - include_vars: ../../../../../roles/openshift_master/vars/main.yml + +  - name: Update systemd units +    include: ../../../../../roles/openshift_master/tasks/systemd_units.yml openshift_version=g_aos_versions.avail_version   #  - name: Upgrade master configuration  #    openshift_upgrade_config: @@ -63,6 +96,8 @@    hosts: oo_nodes_to_config    roles:    - openshift_facts +  handlers: +  - include: ../../../../../roles/openshift_node/handlers/main.yml    tasks:    - include: rpm_upgrade.yml      vars: @@ -108,7 +143,6 @@    vars:      origin_reconcile_bindings: "{{ deployment_type == 'origin' and g_new_version | version_compare('1.0.6', '>') }}"      ent_reconcile_bindings: true -    openshift_master_ha: "{{ groups.oo_masters_to_config | length > 1 }}"    tasks:    - name: Verifying the correct commandline tools are available      shell: grep {{ verify_upgrade_version }} {{ openshift.common.admin_binary}} | 
