diff options
| -rw-r--r-- | openshift-ansible.spec | 2 | ||||
| -rw-r--r-- | playbooks/common/openshift-cluster/upgrades/upgrade_control_plane.yml | 17 | ||||
| -rwxr-xr-x | roles/openshift_facts/library/openshift_facts.py | 4 | 
3 files changed, 18 insertions, 5 deletions
| diff --git a/openshift-ansible.spec b/openshift-ansible.spec index 9ed1542cf..4961d23ef 100644 --- a/openshift-ansible.spec +++ b/openshift-ansible.spec @@ -13,7 +13,7 @@ URL:            https://github.com/openshift/openshift-ansible  Source0:        https://github.com/openshift/openshift-ansible/archive/%{commit}/%{name}-%{version}.tar.gz  BuildArch:      noarch -Requires:      ansible >= 2.1.0.0 +Requires:      ansible >= 2.2.0.0-1  Requires:      python2  Requires:      openshift-ansible-docs = %{version}-%{release} diff --git a/playbooks/common/openshift-cluster/upgrades/upgrade_control_plane.yml b/playbooks/common/openshift-cluster/upgrades/upgrade_control_plane.yml index 927d9b4ca..6b567e2e2 100644 --- a/playbooks/common/openshift-cluster/upgrades/upgrade_control_plane.yml +++ b/playbooks/common/openshift-cluster/upgrades/upgrade_control_plane.yml @@ -13,10 +13,23 @@        groups: etcd_hosts_to_backup      with_items: "{{ groups.oo_etcd_to_config if groups.oo_etcd_to_config is defined and groups.oo_etcd_to_config | length > 0 else groups.oo_first_master }}" +# If facts cache were for some reason deleted, this fact may not be set, and if not set +# it will always default to true. This causes problems for the etcd data dir fact detection +# so we must first make sure this is set correctly before attempting the backup. +- name: Set master embedded_etcd fact +  hosts: oo_masters_to_config +  roles: +  - openshift_facts +  tasks: +  - openshift_facts: +      role: master +      local_facts: +        embedded_etcd: "{{ groups.oo_etcd_to_config | length == 0 }}" +  - name: Backup etcd    hosts: etcd_hosts_to_backup    vars: -    embedded_etcd: "{{ hostvars[groups.oo_first_master.0].openshift.master.embedded_etcd }}" +    embedded_etcd: "{{ groups.oo_etcd_to_config | default([]) | length == 0 }}"      timestamp: "{{ lookup('pipe', 'date +%Y%m%d%H%M%S') }}"    roles:    - openshift_facts @@ -57,7 +70,7 @@      when: (embedded_etcd | bool) and (etcd_disk_usage.stdout|int > avail_disk.stdout|int)    - name: Install etcd (for etcdctl) -    action: "{{ ansible_pkg_mgr }} name=etcd state=latest" +    action: "{{ ansible_pkg_mgr }} name=etcd state=installed"      when: not openshift.common.is_atomic | bool    - name: Generate etcd backup diff --git a/roles/openshift_facts/library/openshift_facts.py b/roles/openshift_facts/library/openshift_facts.py index 6d2b81c1f..9754687cf 100755 --- a/roles/openshift_facts/library/openshift_facts.py +++ b/roles/openshift_facts/library/openshift_facts.py @@ -1122,7 +1122,7 @@ def build_controller_args(facts):                      controller_args['cloud-config'] = [cloud_cfg_path + '/openstack.conf']                  if facts['cloudprovider']['kind'] == 'gce':                      controller_args['cloud-provider'] = ['gce'] -                    kubelet_args['cloud-config'] = [cloud_cfg_path + '/gce.conf'] +                    controller_args['cloud-config'] = [cloud_cfg_path + '/gce.conf']          if controller_args != {}:              facts = merge_facts({'master': {'controller_args': controller_args}}, facts, [], [])      return facts @@ -1143,7 +1143,7 @@ def build_api_server_args(facts):                      api_server_args['cloud-config'] = [cloud_cfg_path + '/openstack.conf']                  if facts['cloudprovider']['kind'] == 'gce':                      api_server_args['cloud-provider'] = ['gce'] -                    kubelet_args['cloud-config'] = [cloud_cfg_path + '/gce.conf'] +                    api_server_args['cloud-config'] = [cloud_cfg_path + '/gce.conf']          if api_server_args != {}:              facts = merge_facts({'master': {'api_server_args': api_server_args}}, facts, [], [])      return facts | 
