diff --git a/roles/container-engine/docker/defaults/main.yml b/roles/container-engine/docker/defaults/main.yml
index 5f376b03e29303fb67e38b8b2e48e76830a19b74..d4d7e53b2f352869f714cd217ae3cc09f501f1c7 100644
--- a/roles/container-engine/docker/defaults/main.yml
+++ b/roles/container-engine/docker/defaults/main.yml
@@ -33,6 +33,10 @@ docker_remove_packages_yum:
   - docker-logrotate
   - docker-engine-selinux.noarch
 
+# remove podman to avoid containerd.io confliction
+podman_remove_packages_yum:
+  - podman
+
 docker_remove_packages_apt:
   - docker
   - docker-engine
diff --git a/roles/container-engine/docker/tasks/pre-upgrade.yml b/roles/container-engine/docker/tasks/pre-upgrade.yml
index 85c1819a01e9c7958d4d68c3d61d048218c357f4..f346b46deaf69e99db4926dd51ce47a9b64494a4 100644
--- a/roles/container-engine/docker/tasks/pre-upgrade.yml
+++ b/roles/container-engine/docker/tasks/pre-upgrade.yml
@@ -15,6 +15,17 @@
     - ansible_os_family == 'Debian'
     - (docker_versioned_pkg[docker_version | string] is search('docker-ce'))
 
+
+- name: Ensure podman not installed. | RedHat
+  package:
+    name: '{{ podman_remove_packages_yum }}'
+    state: absent
+  when:
+    - ansible_os_family == 'RedHat'
+    - (docker_versioned_pkg[docker_version | string] is search('docker-ce'))
+    - not is_ostree
+
+
 - name: Ensure old versions of Docker are not installed. | RedHat
   package:
     name: '{{ docker_remove_packages_yum }}'