uninstall.yml 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. # This deletes *ALL* Origin, Atomic Enterprise Platform and OpenShift
  2. # Enterprise content installed by ansible. This includes:
  3. #
  4. # configuration
  5. # containers
  6. # example templates and imagestreams
  7. # images
  8. # RPMs
  9. ---
  10. - hosts:
  11. - OSEv3:children
  12. become: yes
  13. tasks:
  14. - name: Detecting Operating System
  15. shell: ls /run/ostree-booted
  16. ignore_errors: yes
  17. failed_when: false
  18. register: ostree_output
  19. # Since we're not calling openshift_facts we'll do this for now
  20. - set_fact:
  21. is_atomic: "{{ ostree_output.rc == 0 }}"
  22. - set_fact:
  23. is_containerized: "{{ is_atomic or containerized | default(false) | bool }}"
  24. - name: Remove br0 interface
  25. shell: ovs-vsctl del-br br0
  26. changed_when: False
  27. failed_when: False
  28. - name: Stop services
  29. service: name={{ item }} state=stopped
  30. with_items:
  31. - atomic-enterprise-master
  32. - atomic-enterprise-node
  33. - atomic-openshift-master
  34. - atomic-openshift-master-api
  35. - atomic-openshift-master-controllers
  36. - atomic-openshift-node
  37. - etcd
  38. - haproxy
  39. - openshift-master
  40. - openshift-master-api
  41. - openshift-master-controllers
  42. - openshift-node
  43. - openvswitch
  44. - origin-master
  45. - origin-master-api
  46. - origin-master-controllers
  47. - origin-node
  48. - pcsd
  49. failed_when: false
  50. - name: unmask services
  51. command: systemctl unmask "{{ item }}"
  52. changed_when: False
  53. failed_when: False
  54. with_items:
  55. - etcd
  56. - firewalld
  57. - atomic-openshift-master
  58. - name: Stop additional atomic services
  59. service: name={{ item }} state=stopped
  60. when: is_containerized | bool
  61. with_items:
  62. - etcd_container
  63. failed_when: false
  64. - name: Remove packages
  65. action: "{{ ansible_pkg_mgr }} name={{ item }} state=absent"
  66. when: not is_atomic | bool
  67. with_items:
  68. - atomic-enterprise
  69. - atomic-enterprise-master
  70. - atomic-enterprise-node
  71. - atomic-enterprise-sdn-ovs
  72. - atomic-openshift
  73. - atomic-openshift-clients
  74. - atomic-openshift-master
  75. - atomic-openshift-node
  76. - atomic-openshift-sdn-ovs
  77. - cockpit-bridge
  78. - cockpit-docker
  79. - cockpit-shell
  80. - cockpit-ws
  81. - corosync
  82. - etcd
  83. - haproxy
  84. - kubernetes-client
  85. - openshift
  86. - openshift-master
  87. - openshift-node
  88. - openshift-sdn
  89. - openshift-sdn-ovs
  90. - openvswitch
  91. - origin
  92. - origin-clients
  93. - origin-master
  94. - origin-node
  95. - origin-sdn-ovs
  96. - pacemaker
  97. - pcs
  98. - tuned-profiles-atomic-enterprise-node
  99. - tuned-profiles-atomic-openshift-node
  100. - tuned-profiles-openshift-node
  101. - tuned-profiles-origin-node
  102. - name: Remove linux interfaces
  103. shell: ip link del "{{ item }}"
  104. changed_when: False
  105. failed_when: False
  106. with_items:
  107. - lbr0
  108. - vlinuxbr
  109. - vovsbr
  110. - shell: systemctl reset-failed
  111. changed_when: False
  112. - shell: systemctl daemon-reload
  113. changed_when: False
  114. - shell: find /var/lib/origin/openshift.local.volumes -type d -exec umount {} \; 2>/dev/null || true
  115. changed_when: False
  116. - shell: find /var/lib/atomic-enterprise/openshift.local.volumes -type d -exec umount {} \; 2>/dev/null || true
  117. changed_when: False
  118. - shell: find /var/lib/openshift/openshift.local.volumes -type d -exec umount {} \; 2>/dev/null || true
  119. changed_when: False
  120. - shell: docker rm -f "{{ item }}"-master "{{ item }}"-node
  121. changed_when: False
  122. failed_when: False
  123. with_items:
  124. - openshift-enterprise
  125. - atomic-enterprise
  126. - origin
  127. - shell: docker ps -a | grep Exited | egrep "{{ item }}" | awk '{print $1}'
  128. changed_when: False
  129. failed_when: False
  130. register: exited_containers_to_delete
  131. with_items:
  132. - aep3.*/aep
  133. - aep3.*/node
  134. - aep3.*/openvswitch
  135. - openshift3/ose
  136. - openshift3/node
  137. - openshift3/openvswitch
  138. - openshift/origin
  139. - shell: "docker rm {{ item.stdout_lines | join(' ') }}"
  140. changed_when: False
  141. failed_when: False
  142. with_items: "{{ exited_containers_to_delete.results }}"
  143. - shell: docker images | egrep {{ item }} | awk '{ print $3 }'
  144. changed_when: False
  145. failed_when: False
  146. register: images_to_delete
  147. with_items:
  148. - registry\.access\..*redhat\.com/openshift3
  149. - registry\.access\..*redhat\.com/aep3
  150. - registry\.qe\.openshift\.com/.*
  151. - registry\.access\..*redhat\.com/rhel7/etcd
  152. - docker.io/openshift
  153. - shell: "docker rmi -f {{ item.stdout_lines | join(' ') }}"
  154. changed_when: False
  155. failed_when: False
  156. with_items: "{{ images_to_delete.results }}"
  157. - name: Remove sdn drop files
  158. file:
  159. path: /run/openshift-sdn
  160. state: absent
  161. - name: restart docker
  162. service:
  163. name: docker
  164. state: restarted
  165. - name: Remove remaining files
  166. file: path={{ item }} state=absent
  167. with_items:
  168. - "~{{ ansible_ssh_user }}/.kube"
  169. - /etc/ansible/facts.d/openshift.fact
  170. - /etc/atomic-enterprise
  171. - /etc/corosync
  172. - /etc/etcd
  173. - /etc/openshift
  174. - /etc/openshift-sdn
  175. - /etc/origin
  176. - /etc/systemd/system/atomic-openshift-master.service
  177. - /etc/systemd/system/atomic-openshift-master-api.service
  178. - /etc/systemd/system/atomic-openshift-master-controllers.service
  179. - /etc/systemd/system/atomic-openshift-node.service
  180. - /etc/systemd/system/atomic-openshift-node-dep.service
  181. - /etc/systemd/system/etcd_container.service
  182. - /etc/systemd/system/openvswitch.service
  183. - /etc/sysconfig/atomic-enterprise-master
  184. - /etc/sysconfig/atomic-enterprise-master-api
  185. - /etc/sysconfig/atomic-enterprise-master-controllers
  186. - /etc/sysconfig/atomic-enterprise-node
  187. - /etc/sysconfig/atomic-openshift-master
  188. - /etc/sysconfig/atomic-openshift-master-api
  189. - /etc/sysconfig/atomic-openshift-master-controllers
  190. - /etc/sysconfig/atomic-openshift-node
  191. - /etc/sysconfig/openshift-master
  192. - /etc/sysconfig/openshift-node
  193. - /etc/sysconfig/openshift-node
  194. - /etc/sysconfig/openvswitch
  195. - /etc/sysconfig/origin-master
  196. - /etc/sysconfig/origin-master-api
  197. - /etc/sysconfig/origin-master-controllers
  198. - /etc/sysconfig/origin-node
  199. - /etc/systemd/system/atomic-openshift-node.service.wants
  200. - /root/.kube
  201. - /run/openshift-sdn
  202. - /usr/share/openshift/examples
  203. - /var/lib/atomic-enterprise
  204. - /var/lib/etcd
  205. - /var/lib/openshift
  206. - /var/lib/origin
  207. - /var/lib/pacemaker
  208. - /usr/lib/systemd/system/atomic-openshift-master-api.service
  209. - /usr/lib/systemd/system/atomic-openshift-master-controllers.service
  210. - /usr/lib/systemd/system/origin-master-api.service
  211. - /usr/lib/systemd/system/origin-master-controllers.service
  212. - /usr/local/bin/openshift
  213. - /usr/local/bin/oadm
  214. - /usr/local/bin/oc
  215. - /usr/local/bin/kubectl
  216. - /etc/NetworkManager/dispatcher.d/99-origin-dns.sh
  217. - /etc/dnsmasq.d/origin-dns.conf
  218. - /etc/dnsmasq.d/origin-upstream-dns.conf
  219. # Since we are potentially removing the systemd unit files for separated
  220. # master-api and master-controllers services, so we need to reload the
  221. # systemd configuration manager
  222. - name: Reload systemd manager configuration
  223. command: systemctl daemon-reload
  224. - hosts: nodes
  225. become: yes
  226. tasks:
  227. - name: restart docker
  228. service: name=docker state=restarted
  229. - name: restart NetworkManager
  230. service: name=NetworkManager state=restarted