node_system_container.yml 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. ---
  2. # system containers create their own service unit files based on templates
  3. # that are part of the container image.
  4. # oc_atomic_container will create a systemd service unit file in
  5. # /etc/systemd/system/origin-node.service (origin) or
  6. # /etc/systemd/system/atomic-openshift-node.service (enterprise)
  7. # TODO: remove when system container is fixed to not include it
  8. - name: Ensure old system path is set
  9. file:
  10. state: directory
  11. path: "{{ item }}"
  12. mode: '0750'
  13. with_items:
  14. - "/etc/origin/openvswitch"
  15. - "/var/lib/kubelet"
  16. - "/opt/cni/bin"
  17. - name: Check status of node image pre-pull
  18. async_status:
  19. jid: "{{ image_prepull.ansible_job_id }}"
  20. register: job_result
  21. until: job_result.finished
  22. when:
  23. - node_image is defined
  24. - node_image.stdout_lines == []
  25. retries: 20
  26. delay: 30
  27. failed_when: false
  28. - name: Copy node container image to ostree storage
  29. command: >
  30. atomic pull --storage=ostree docker:{{ osn_image }}
  31. register: pull_result
  32. retries: 3
  33. delay: 5
  34. until: pull_result.rc == 0
  35. changed_when: "'Pulling layer' in pull_result.stdout"
  36. - name: Install or Update node system container
  37. oc_atomic_container:
  38. name: "{{ openshift_service_type }}-node"
  39. image: "{{ system_osn_image }}"
  40. values:
  41. - "DNS_DOMAIN={{ openshift.common.dns_domain }}"
  42. - "DOCKER_SERVICE={{ openshift_docker_service_name }}.service"
  43. - 'ADDTL_MOUNTS={{ l_node_syscon_add_mounts2 }}'
  44. state: latest
  45. vars:
  46. # We need to evaluate some variables here to ensure
  47. # l_bind_docker_reg_auth is evaluated after registry_auth.yml has been
  48. # processed.
  49. # Determine if we want to include auth credentials mount.
  50. l_node_syscon_auth_mounts_l: "{{ l_bind_docker_reg_auth | ternary(openshift_node_syscon_auth_mounts_l,[]) }}"
  51. # Join any user-provided mounts and auth_mounts into a combined list.
  52. l_node_syscon_add_mounts_l: "{{ openshift_node_syscon_add_mounts_l | union(l_node_syscon_auth_mounts_l) }}"
  53. # We must prepend a ',' here to ensure the value is inserted properly into an
  54. # existing json list in the container's config.json
  55. # lib_utils_oo_l_of_d_to_csv is a custom filter plugin in roles/lib_utils/oo_filters.py
  56. l_node_syscon_add_mounts: ",{{ l_node_syscon_add_mounts_l | lib_utils_oo_l_of_d_to_csv }}"
  57. # if we have just a ',' then both mount lists were empty, we don't want to add
  58. # anything to config.json
  59. l_node_syscon_add_mounts2: "{{ (l_node_syscon_add_mounts != ',') | bool | ternary(l_node_syscon_add_mounts,'') }}"
  60. # TODO: network manager on RHEL is failing to execute 99-origin-dns.sh with signal 13, an immediate
  61. # restart seems to allow the job to configure. Only occurs with system containers.
  62. - name: Restart network manager to ensure networking configuration is in place
  63. systemd:
  64. name: NetworkManager
  65. enabled: yes
  66. state: restarted