You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

229 lines
8.4 KiB

6 years ago
  1. ---
  2. - name: Set os_family fact for other redhat-based operating systems
  3. set_fact:
  4. ansible_os_family: "RedHat"
  5. ansible_distribution_major_version: "8"
  6. when: ansible_distribution in redhat_os_family_extensions
  7. tags:
  8. - facts
  9. - name: Check resolvconf
  10. command: which resolvconf
  11. register: resolvconf
  12. failed_when: false
  13. changed_when: false
  14. check_mode: false
  15. - name: Check existence of /etc/resolvconf/resolv.conf.d
  16. stat:
  17. path: /etc/resolvconf/resolv.conf.d
  18. get_attributes: false
  19. get_checksum: false
  20. get_mime: false
  21. failed_when: false
  22. register: resolvconfd_path
  23. - name: Check status of /etc/resolv.conf
  24. stat:
  25. path: /etc/resolv.conf
  26. follow: false
  27. get_attributes: false
  28. get_checksum: false
  29. get_mime: false
  30. failed_when: false
  31. register: resolvconf_stat
  32. - name: Fetch resolvconf
  33. when: resolvconf_stat.stat.exists is defined and resolvconf_stat.stat.exists
  34. block:
  35. - name: Get content of /etc/resolv.conf
  36. slurp:
  37. src: /etc/resolv.conf
  38. register: resolvconf_slurp
  39. - name: Get currently configured nameservers
  40. set_fact:
  41. configured_nameservers: "{{ resolvconf_slurp.content | b64decode | regex_findall('^nameserver\\s*(\\S*)', multiline=True) | ansible.utils.ipaddr }}"
  42. when: resolvconf_slurp.content is defined
  43. - name: Stop if /etc/resolv.conf not configured nameservers
  44. assert:
  45. that: configured_nameservers | length>0
  46. fail_msg: "nameserver should not empty in /etc/resolv.conf"
  47. when:
  48. - not ignore_assert_errors
  49. - configured_nameservers is defined
  50. - not (upstream_dns_servers is defined and upstream_dns_servers | length > 0)
  51. - not (disable_host_nameservers | default(false))
  52. - dns_mode in ['coredns', 'coredns_dual']
  53. - name: NetworkManager | Check if host has NetworkManager
  54. # noqa command-instead-of-module - Should we use service_facts for this?
  55. command: systemctl is-active --quiet NetworkManager.service
  56. register: networkmanager_enabled
  57. failed_when: false
  58. changed_when: false
  59. check_mode: false
  60. - name: Check systemd-resolved
  61. # noqa command-instead-of-module - Should we use service_facts for this?
  62. command: systemctl is-active systemd-resolved
  63. register: systemd_resolved_enabled
  64. failed_when: false
  65. changed_when: false
  66. check_mode: false
  67. - name: Set default dns if remove_default_searchdomains is false
  68. set_fact:
  69. default_searchdomains: ["default.svc.{{ dns_domain }}", "svc.{{ dns_domain }}"]
  70. when: not remove_default_searchdomains | default() | bool or (remove_default_searchdomains | default() | bool and searchdomains | default([]) | length==0)
  71. - name: Set dns facts
  72. set_fact:
  73. resolvconf: >-
  74. {%- if resolvconf.rc == 0 and resolvconfd_path.stat.isdir is defined and resolvconfd_path.stat.isdir -%}true{%- else -%}false{%- endif -%}
  75. bogus_domains: |-
  76. {% for d in default_searchdomains | default([]) + searchdomains | default([]) -%}
  77. {{ dns_domain }}.{{ d }}./{{ d }}.{{ d }}./com.{{ d }}./
  78. {%- endfor %}
  79. cloud_resolver: "{{ ['169.254.169.254'] if cloud_provider is defined and cloud_provider == 'gce' else
  80. ['169.254.169.253'] if cloud_provider is defined and cloud_provider == 'aws' else
  81. [] }}"
  82. - name: Check if kubelet is configured
  83. stat:
  84. path: "{{ kube_config_dir }}/kubelet.env"
  85. get_attributes: false
  86. get_checksum: false
  87. get_mime: false
  88. register: kubelet_configured
  89. changed_when: false
  90. - name: Check if early DNS configuration stage
  91. set_fact:
  92. dns_early: "{{ not kubelet_configured.stat.exists }}"
  93. - name: Target resolv.conf files
  94. set_fact:
  95. resolvconffile: /etc/resolv.conf
  96. base: >-
  97. {%- if resolvconf | bool -%}/etc/resolvconf/resolv.conf.d/base{%- endif -%}
  98. head: >-
  99. {%- if resolvconf | bool -%}/etc/resolvconf/resolv.conf.d/head{%- endif -%}
  100. when: not ansible_os_family in ["Flatcar", "Flatcar Container Linux by Kinvolk"] and not is_fedora_coreos
  101. - name: Target temporary resolvconf cloud init file (Flatcar Container Linux by Kinvolk / Fedora CoreOS)
  102. set_fact:
  103. resolvconffile: /tmp/resolveconf_cloud_init_conf
  104. when: ansible_os_family in ["Flatcar", "Flatcar Container Linux by Kinvolk"] or is_fedora_coreos
  105. - name: Check if /etc/dhclient.conf exists
  106. stat:
  107. path: /etc/dhclient.conf
  108. get_attributes: false
  109. get_checksum: false
  110. get_mime: false
  111. register: dhclient_stat
  112. - name: Target dhclient conf file for /etc/dhclient.conf
  113. set_fact:
  114. dhclientconffile: /etc/dhclient.conf
  115. when: dhclient_stat.stat.exists
  116. - name: Check if /etc/dhcp/dhclient.conf exists
  117. stat:
  118. path: /etc/dhcp/dhclient.conf
  119. get_attributes: false
  120. get_checksum: false
  121. get_mime: false
  122. register: dhcp_dhclient_stat
  123. - name: Target dhclient conf file for /etc/dhcp/dhclient.conf
  124. set_fact:
  125. dhclientconffile: /etc/dhcp/dhclient.conf
  126. when: dhcp_dhclient_stat.stat.exists
  127. - name: Target dhclient hook file for Red Hat family
  128. set_fact:
  129. dhclienthookfile: /etc/dhcp/dhclient.d/zdnsupdate.sh
  130. when: ansible_os_family == "RedHat"
  131. - name: Target dhclient hook file for Debian family
  132. set_fact:
  133. dhclienthookfile: /etc/dhcp/dhclient-exit-hooks.d/zdnsupdate
  134. when: ansible_os_family == "Debian"
  135. - name: Generate search domains to resolvconf
  136. set_fact:
  137. searchentries:
  138. search {{ (default_searchdomains | default([]) + searchdomains | default([])) | join(' ') }}
  139. domainentry:
  140. domain {{ dns_domain }}
  141. supersede_search:
  142. supersede domain-search "{{ (default_searchdomains | default([]) + searchdomains | default([])) | join('", "') }}";
  143. supersede_domain:
  144. supersede domain-name "{{ dns_domain }}";
  145. - name: Pick coredns cluster IP or default resolver
  146. set_fact:
  147. coredns_server: |-
  148. {%- if dns_mode == 'coredns' and not dns_early | bool -%}
  149. {{ [skydns_server] }}
  150. {%- elif dns_mode == 'coredns_dual' and not dns_early | bool -%}
  151. {{ [skydns_server] + [skydns_server_secondary] }}
  152. {%- elif dns_mode == 'manual' and not dns_early | bool -%}
  153. {{ (manual_dns_server.split(',') | list) }}
  154. {%- elif dns_mode == 'none' and not dns_early | bool -%}
  155. []
  156. {%- elif dns_early | bool -%}
  157. {{ upstream_dns_servers | default([]) }}
  158. {%- endif -%}
  159. # This task should only run after cluster/nodelocal DNS is up, otherwise all DNS lookups will timeout
  160. - name: Generate nameservers for resolvconf, including cluster DNS
  161. set_fact:
  162. nameserverentries: |-
  163. {{ (([nodelocaldns_ip] if enable_nodelocaldns else []) + (coredns_server | d([]) if not enable_nodelocaldns else []) + nameservers | d([]) + cloud_resolver | d([]) + (configured_nameservers | d([]) if not disable_host_nameservers | d() | bool else [])) | unique | join(',') }}
  164. dhclient_supersede_nameserver_entries_list: |-
  165. {{ (([nodelocaldns_ip] if enable_nodelocaldns else []) + (coredns_server | d([]) if not enable_nodelocaldns else []) + nameservers | d([]) + cloud_resolver | d([]) + (configured_nameservers | d([]) if not disable_host_nameservers | d() | bool else [])) | unique }}
  166. when: not dns_early or dns_late
  167. # This task should run instead of the above task when cluster/nodelocal DNS hasn't
  168. # been deployed yet (like scale.yml/cluster.yml) or when it's down (reset.yml)
  169. - name: Generate nameservers for resolvconf, not including cluster DNS
  170. set_fact:
  171. nameserverentries: |-
  172. {{ (nameservers | d([]) + cloud_resolver | d([]) + configured_nameservers | d([])) | unique | join(',') }}
  173. dhclient_supersede_nameserver_entries_list: |-
  174. {{ (nameservers | d([]) + cloud_resolver | d([])) | unique }}
  175. when: dns_early and not dns_late
  176. - name: Generate supersede_nameserver from dhclient_supersede_nameserver_entries_list
  177. set_fact:
  178. supersede_nameserver: |-
  179. {%- if dhclient_supersede_nameserver_entries_list | length > 0 -%}
  180. supersede domain-name-servers {{ dhclient_supersede_nameserver_entries_list | join(', ') }};
  181. {%- endif -%}
  182. - name: Set etcd vars if using kubeadm mode
  183. set_fact:
  184. etcd_cert_dir: "{{ kube_cert_dir }}"
  185. kube_etcd_cacert_file: "etcd/ca.crt"
  186. kube_etcd_cert_file: "apiserver-etcd-client.crt"
  187. kube_etcd_key_file: "apiserver-etcd-client.key"
  188. when:
  189. - etcd_deployment_type == "kubeadm"
  190. - name: Check /usr readonly
  191. stat:
  192. path: "/usr"
  193. get_attributes: false
  194. get_checksum: false
  195. get_mime: false
  196. register: usr
  197. - name: Set alternate flexvolume path
  198. set_fact:
  199. kubelet_flexvolumes_plugins_dir: /var/lib/kubelet/volumeplugins
  200. when: not usr.stat.writeable