systemcontainer_docker.yml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. ---
  2. - set_fact:
  3. l_openshift_image_tag: "{{ openshift_image_tag | string }}"
  4. when: openshift_image_tag is defined
  5. - set_fact:
  6. l_openshift_image_tag: "latest"
  7. when:
  8. - openshift_image_tag is not defined
  9. - openshift_release == "latest"
  10. - set_fact:
  11. l_openshift_image_tag: "{{ openshift_release | string }}"
  12. when:
  13. - openshift_image_tag is not defined
  14. - openshift_release != "latest"
  15. # If docker_options are provided we should fail. We should not install docker and ignore
  16. # the users configuration. NOTE: docker_options == inventory:openshift_docker_options
  17. - name: Fail quickly if openshift_docker_options are set
  18. assert:
  19. that:
  20. - docker_options is defined
  21. - docker_options != ""
  22. msg: |
  23. Docker via System Container does not allow for the use of the openshift_docker_options
  24. variable. If you want to use openshift_docker_options you will need to use the
  25. traditional docker package install. Otherwise, comment out openshift_docker_options
  26. in your inventory file.
  27. - name: Ensure container-selinux is installed
  28. package:
  29. name: container-selinux
  30. state: present
  31. when: not openshift.common.is_atomic | bool
  32. # Used to pull and install the system container
  33. - name: Ensure atomic is installed
  34. package:
  35. name: atomic
  36. state: present
  37. when: not openshift.common.is_atomic | bool
  38. # At the time of writing the atomic command requires runc for it's own use. This
  39. # task is here in the even that the atomic package ever removes the dependency.
  40. - name: Ensure runc is installed
  41. package:
  42. name: runc
  43. state: present
  44. when: not openshift.common.is_atomic | bool
  45. # Make sure Docker is installed so we are able to use the client
  46. - name: Install Docker so we can use the client
  47. package: name=docker{{ '-' + docker_version if docker_version is defined else '' }} state=present
  48. when: not openshift.common.is_atomic | bool
  49. # Make sure docker is disabled. Errors are ignored.
  50. - name: Disable Docker
  51. systemd:
  52. name: docker
  53. enabled: no
  54. state: stopped
  55. daemon_reload: yes
  56. ignore_errors: True
  57. register: r_docker_systemcontainer_docker_stop_result
  58. until: not r_docker_systemcontainer_docker_stop_result | failed
  59. retries: 3
  60. delay: 30
  61. - name: Ensure proxies are in the atomic.conf
  62. include_role:
  63. name: openshift_atomic
  64. tasks_from: proxy
  65. - block:
  66. - name: Set to default prepend
  67. set_fact:
  68. l_docker_image_prepend: "gscrivano"
  69. l_docker_image_tag: "latest"
  70. - name: Set container engine image tag
  71. set_fact:
  72. l_docker_image_tag: "{{ l_openshift_image_tag }}"
  73. when:
  74. - openshift_deployment_type == 'openshift-enterprise'
  75. - name: Use Red Hat Registry for image when distribution is Red Hat
  76. set_fact:
  77. l_docker_image_prepend: "registry.access.redhat.com/openshift3"
  78. when: ansible_distribution == 'RedHat'
  79. - name: Use Fedora Registry for image when distribution is Fedora
  80. set_fact:
  81. l_docker_image_prepend: "registry.fedoraproject.org/f25"
  82. when: ansible_distribution == 'Fedora'
  83. - name: Set the full image name
  84. set_fact:
  85. l_docker_image: "{{ l_docker_image_prepend }}/{{ openshift.docker.service_name }}:{{ l_docker_image_tag }}"
  86. # For https://github.com/openshift/openshift-ansible/pull/5354#issuecomment-328552959
  87. - name: Use a specific image if requested
  88. set_fact:
  89. l_docker_image: "{{ openshift_docker_systemcontainer_image_override }}"
  90. when:
  91. - openshift_docker_systemcontainer_image_override is defined
  92. - openshift_docker_systemcontainer_image_override != ""
  93. # Be nice and let the user see the variable result
  94. - debug:
  95. var: l_docker_image
  96. # NOTE: no_proxy added as a workaround until https://github.com/projectatomic/atomic/pull/999 is released
  97. - name: Pre-pull Container Engine System Container image
  98. command: "atomic pull --storage ostree {{ l_docker_image }}"
  99. changed_when: false
  100. environment:
  101. NO_PROXY: "{{ openshift.common.no_proxy | default('') }}"
  102. - name: Ensure container-engine.service.d directory exists
  103. file:
  104. path: "{{ container_engine_systemd_dir }}"
  105. state: directory
  106. - name: Ensure /etc/docker directory exists
  107. file:
  108. path: "{{ docker_conf_dir }}"
  109. state: directory
  110. - name: Install Container Engine System Container
  111. oc_atomic_container:
  112. name: "{{ openshift.docker.service_name }}"
  113. image: "{{ l_docker_image }}"
  114. state: latest
  115. - name: Configure Container Engine Service File
  116. template:
  117. dest: "{{ container_engine_systemd_dir }}/custom.conf"
  118. src: systemcontainercustom.conf.j2
  119. # Set local versions of facts that must be in json format for container-daemon.json
  120. # NOTE: When jinja2.9+ is used the container-daemon.json file can move to using tojson
  121. - set_fact:
  122. l_docker_insecure_registries: "{{ l2_docker_insecure_registries | default([]) | to_json }}"
  123. l_docker_log_options: "{{ docker_log_options | default({}) | to_json }}"
  124. l_docker_additional_registries: "{{ l2_docker_additional_registries | default([]) | to_json }}"
  125. l_docker_blocked_registries: "{{ l2_docker_blocked_registries | default([]) | to_json }}"
  126. l_docker_selinux_enabled: "{{ docker_selinux_enabled | default(true) | to_json }}"
  127. # Configure container-engine using the container-daemon.json file
  128. # NOTE: daemon.json and container-daemon.json have been seperated to avoid
  129. # collision.
  130. - name: Configure Container Engine
  131. template:
  132. dest: "{{ docker_conf_dir }}/container-daemon.json"
  133. src: daemon.json
  134. # Enable and start the container-engine service
  135. - name: Start the Container Engine service
  136. systemd:
  137. name: "{{ openshift.docker.service_name }}"
  138. enabled: yes
  139. state: started
  140. daemon_reload: yes
  141. register: r_docker_systemcontainer_docker_start_result
  142. until: not r_docker_systemcontainer_docker_start_result | failed
  143. retries: 3
  144. delay: 30
  145. - set_fact:
  146. docker_service_status_changed: "{{ r_docker_systemcontainer_docker_start_result | changed }}"
  147. - meta: flush_handlers
  148. # Since docker is running as a system container, docker login will fail to create
  149. # credentials. Use alternate method if requiring authenticated registries.
  150. - include: registry_auth.yml
  151. vars:
  152. openshift_docker_alternative_creds: True