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.

88 lines
3.0 KiB

  1. ---
  2. - name: check resolvconf
  3. shell: which resolvconf
  4. register: resolvconf
  5. ignore_errors: yes
  6. changed_when: false
  7. - set_fact:
  8. resolvconf: >-
  9. {%- if resolvconf.rc == 0 -%}true{%- else -%}false{%- endif -%}
  10. - set_fact:
  11. private_domains: |-
  12. {% for d in [ 'default.svc.' + dns_domain, 'svc.' + dns_domain ] + searchdomains|default([]) -%}
  13. {{dns_domain}}.{{d}}./{{d}}.{{d}}./com.{{d}}./
  14. {%- endfor %}
  15. default_resolver: >-
  16. {%- if cloud_provider is defined and cloud_provider == 'gce' -%}169.254.169.254{%- else -%}8.8.8.8{%- endif -%}
  17. - name: check kubelet
  18. stat:
  19. path: "{{ bin_dir }}/kubelet"
  20. register: kubelet
  21. changed_when: false
  22. - name: check if early DNS configuration stage
  23. set_fact:
  24. dns_early: >-
  25. {%- if kubelet.stat.exists -%}false{%- else -%}true{%- endif -%}
  26. - name: target resolv.conf files
  27. set_fact:
  28. resolvconffile: /etc/resolv.conf
  29. base: >-
  30. {%- if resolvconf|bool -%}/etc/resolvconf/resolv.conf.d/base{%- endif -%}
  31. head: >-
  32. {%- if resolvconf|bool -%}/etc/resolvconf/resolv.conf.d/head{%- endif -%}
  33. when: ansible_os_family != "CoreOS"
  34. - name: target temporary resolvconf cloud init file (CoreOS)
  35. set_fact: resolvconffile=/tmp/resolveconf_cloud_init_conf
  36. when: ansible_os_family == "CoreOS"
  37. - name: target dhclient conf/hook files for Red Hat family
  38. set_fact:
  39. dhclientconffile: /etc/dhclient.conf
  40. dhclienthookfile: /etc/dhcp/dhclient.d/zdnsupdate.sh
  41. when: ansible_os_family == "RedHat"
  42. - name: target dhclient conf/hook files for Debian family
  43. set_fact:
  44. dhclientconffile: /etc/dhcp/dhclient.conf
  45. dhclienthookfile: /etc/dhcp/dhclient-exit-hooks.d/zdnsupdate
  46. when: ansible_os_family == "Debian"
  47. - name: generate search domains to resolvconf
  48. set_fact:
  49. searchentries:
  50. search {{ ([ 'default.svc.' + dns_domain, 'svc.' + dns_domain ] + searchdomains|default([])) | join(' ') }}
  51. domainentry:
  52. domain {{ dns_domain }}
  53. supersede_search:
  54. supersede domain-search "{{ ([ 'default.svc.' + dns_domain, 'svc.' + dns_domain ] + searchdomains|default([])) | join('", "') }}";
  55. supersede_domain:
  56. supersede domain-name "{{ dns_domain }}";
  57. - name: decide on dns server IP
  58. set_fact:
  59. dns_server_real: >-
  60. {%- if dns_early|bool -%}{{default_resolver}}{%- else -%}{{dns_server}}{%- endif -%}
  61. - name: pick dnsmasq cluster IP or default resolver
  62. set_fact:
  63. dnsmasq_server: |-
  64. {%- if skip_dnsmasq|bool and not dns_early|bool -%}
  65. {{ [ skydns_server ] + upstream_dns_servers|default([]) }}
  66. {%- elif dns_early|bool -%}
  67. {{ [ dns_server_real ] + upstream_dns_servers|default([]) }}
  68. {%- else -%}
  69. {{ [ dns_server ] }}
  70. {%- endif -%}
  71. - name: generate nameservers to resolvconf
  72. set_fact:
  73. nameserverentries:
  74. nameserver {{( dnsmasq_server|default([]) + nameservers|default([])) | join(',nameserver ')}}
  75. prepend_nameserver:
  76. prepend domain-name-servers {{( dnsmasq_server|default([]) + nameservers|default([])) | join(', ') }};