Fix ceph deployment for CentOS 7

Since centos dropped pyhton-pip from their repos, we should use
epel now to get pip2 and install required for ceph libraries (ie PyYAML)

Change-Id: I9d0bc341de4ebcd89df6c3c8c5ce3cd5cd6e5b26
This commit is contained in:
Dmitriy Rabotyagov 2020-07-21 21:11:43 +03:00 committed by Dmitriy Rabotyagov (noonedeadpunk)
parent 8fa414e1f8
commit 39a4622ef7

View File

@ -25,7 +25,7 @@
#TODO: mgariepy, revisit to use include_role when https://github.com/ansible/ansible/issues/20077 is fixed #TODO: mgariepy, revisit to use include_role when https://github.com/ansible/ansible/issues/20077 is fixed
- name: Ensure Ansible can work with SELinux - name: Ensure Ansible can work with SELinux
package: package:
name: libselinux-python name: libselinux-python3
state: present state: present
when: when:
- ansible_pkg_mgr in ['yum', 'dnf'] - ansible_pkg_mgr in ['yum', 'dnf']
@ -51,11 +51,48 @@
state: present state: present
# Rescue is mainly for CentOS 7 # Rescue is mainly for CentOS 7
rescue: rescue:
- name: Download EPEL gpg keys
get_url:
url: "{{ centos_epel_key | default('http://download.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-7') }}"
dest: /etc/pki/rpm-gpg
register: _get_yum_keys
until: _get_yum_keys is success
retries: 5
delay: 2
when:
- ansible_os_family | lower == 'redhat'
- ansible_distribution_major_version is version('7', '=')
- name: Install EPEL gpg keys
rpm_key:
key: "/etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7"
state: present
when:
- ansible_os_family | lower == 'redhat'
- ansible_distribution_major_version is version('7', '=')
- name: Install the EPEL repository
yum_repository:
name: epel-ceph
baseurl: "{{ centos_epel_mirror | default('http://download.fedoraproject.org/pub/epel') ~ '/' ~ ansible_distribution_major_version ~ '/' ~ ansible_architecture }}"
description: 'Extra Packages for Enterprise Linux 7 - $basearch'
gpgcheck: yes
enabled: yes
state: present
includepkgs: 'python2-pip'
register: install_epel_repo
until: install_epel_repo is success
retries: 5
delay: 2
when:
- ansible_os_family | lower == 'redhat'
- ansible_distribution_major_version is version('7', '=')
# Installing both pip's not to fail # Installing both pip's not to fail
- name: Installing pip - name: Installing pip
package: package:
name: name:
- python-pip - "{{ (ansible_os_family | lower == 'redhat' and ansible_distribution_major_version is version('8', '<')) | ternary('python2-pip', 'python-pip') }}"
- python3-pip - python3-pip
state: present state: present