package_crio.yml 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. ---
  2. - name: Fail if Atomic Host since this is an rpm request
  3. fail: msg='Cannot use CRI-O as a package on Atomic Host'
  4. when:
  5. - openshift_is_atomic | bool
  6. - include_tasks: common/pre.yml
  7. - name: Check that overlay is in the kernel
  8. shell: lsmod | grep overlay
  9. register: l_has_overlay_in_kernel
  10. ignore_errors: yes
  11. failed_when: false
  12. - when: l_has_overlay_in_kernel.rc != 0
  13. block:
  14. - name: Add overlay to modprobe.d
  15. template:
  16. dest: /etc/modules-load.d/overlay.conf
  17. src: overlay.conf.j2
  18. backup: yes
  19. - name: Manually modprobe overlay into the kernel
  20. command: modprobe overlay
  21. - name: Enable and start systemd-modules-load
  22. service:
  23. name: systemd-modules-load
  24. enabled: yes
  25. state: restarted
  26. - name: Install cri-o
  27. package:
  28. name: "cri-o"
  29. state: present
  30. register: result
  31. until: result is succeeded
  32. - name: Remove CRI-O default configuration files
  33. file:
  34. path: "{{ item }}"
  35. state: absent
  36. with_items:
  37. - /etc/cni/net.d/200-loopback.conf
  38. - /etc/cni/net.d/100-crio-bridge.conf
  39. - name: Create the CRI-O configuration
  40. template:
  41. dest: /etc/crio/crio.conf
  42. src: crio.conf.j2
  43. backup: yes
  44. - name: Ensure CNI configuration directory exists
  45. file:
  46. path: /etc/cni/net.d/
  47. state: directory
  48. - name: setup firewall for CRI-O
  49. import_tasks: crio_firewall.yml
  50. - name: Configure the CNI network
  51. template:
  52. dest: /etc/cni/net.d/openshift-sdn.conf
  53. src: 80-openshift-sdn.conf.j2
  54. - name: Create /etc/sysconfig/crio-network
  55. template:
  56. dest: /etc/sysconfig/crio-network
  57. src: crio-network.j2
  58. - name: Fixup SELinux permissions for docker
  59. shell: |
  60. semanage fcontext -a -e /var/lib/docker/overlay2 /var/lib/containers/overlay2
  61. restorecon -R -v /var/lib/containers/overlay2
  62. - name: Start the CRI-O service
  63. systemd:
  64. name: "cri-o"
  65. enabled: yes
  66. state: restarted
  67. daemon_reload: yes
  68. register: start_result
  69. # If we are using crio only, docker.service might not be available for
  70. # 'docker login'
  71. - include_tasks: common/post.yml
  72. vars:
  73. openshift_docker_alternative_creds: "{{ (openshift_use_crio_only | bool) or (openshift_docker_use_system_container | bool) }}"