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.

85 lines
3.1 KiB

  1. apiVersion: kubeadm.k8s.io/v1alpha1
  2. kind: MasterConfiguration
  3. api:
  4. advertiseAddress: {{ ip | default(ansible_default_ipv4.address) }}
  5. bindPort: {{ kube_apiserver_port }}
  6. etcd:
  7. endpoints:
  8. {% for endpoint in etcd_access_addresses.split(',') %}
  9. - {{ endpoint }}
  10. {% endfor %}
  11. caFile: {{ kube_config_dir }}/ssl/etcd/ca.pem
  12. certFile: {{ kube_config_dir }}/ssl/etcd/node-{{ inventory_hostname }}.pem
  13. keyFile: {{ kube_config_dir }}/ssl/etcd/node-{{ inventory_hostname }}-key.pem
  14. networking:
  15. dnsDomain: {{ dns_domain }}
  16. serviceSubnet: {{ kube_service_addresses }}
  17. podSubnet: {{ kube_pods_subnet }}
  18. kubernetesVersion: {{ kube_version }}
  19. {% if cloud_provider is defined and cloud_provider != "gce" %}
  20. cloudProvider: {{ cloud_provider }}
  21. {% endif %}
  22. {% if kube_proxy_mode == 'ipvs' %}
  23. kubeProxy:
  24. config:
  25. featureGates: SupportIPVSProxyMode=true
  26. mode: ipvs
  27. {% endif %}
  28. authorizationModes:
  29. {% for mode in authorization_modes %}
  30. - {{ mode }}
  31. {% endfor %}
  32. selfHosted: false
  33. apiServerExtraArgs:
  34. bind-address: {{ kube_apiserver_bind_address }}
  35. insecure-bind-address: {{ kube_apiserver_insecure_bind_address }}
  36. insecure-port: "{{ kube_apiserver_insecure_port }}"
  37. admission-control: {{ kube_apiserver_admission_control | join(',') }}
  38. apiserver-count: "{{ kube_apiserver_count }}"
  39. service-node-port-range: {{ kube_apiserver_node_port_range }}
  40. {% if kube_basic_auth|default(true) %}
  41. basic-auth-file: {{ kube_users_dir }}/known_users.csv
  42. {% endif %}
  43. {% if kube_oidc_auth|default(false) and kube_oidc_url is defined and kube_oidc_client_id is defined %}
  44. oidc-issuer-url: {{ kube_oidc_url }}
  45. oidc-client-id: {{ kube_oidc_client_id }}
  46. {% if kube_oidc_ca_file is defined %}
  47. oidc-ca-file: {{ kube_oidc_ca_file }}
  48. {% endif %}
  49. {% if kube_oidc_username_claim is defined %}
  50. oidc-username-claim: {{ kube_oidc_username_claim }}
  51. {% endif %}
  52. {% if kube_oidc_groups_claim is defined %}
  53. oidc-groups-claim: {{ kube_oidc_groups_claim }}
  54. {% endif %}
  55. {% endif %}
  56. storage-backend: {{ kube_apiserver_storage_backend }}
  57. {% if kube_api_runtime_config is defined %}
  58. runtime-config: {{ kube_api_runtime_config | join(',') }}
  59. {% endif %}
  60. allow-privileged: "true"
  61. {% for key in kube_kubeadm_apiserver_extra_args %}
  62. {{ key }}: {{ kube_kubeadm_apiserver_extra_args[key] }}
  63. {% endfor %}
  64. controllerManagerExtraArgs:
  65. node-monitor-grace-period: {{ kube_controller_node_monitor_grace_period }}
  66. node-monitor-period: {{ kube_controller_node_monitor_period }}
  67. pod-eviction-timeout: {{ kube_controller_pod_eviction_timeout }}
  68. {% if kube_feature_gates %}
  69. feature-gates: {{ kube_feature_gates|join(',') }}
  70. {% endif %}
  71. {% for key in kube_kubeadm_controller_extra_args %}
  72. {{ key }}: {{ kube_kubeadm_controller_extra_args[key] }}
  73. {% endfor %}
  74. {% if kube_kubeadm_scheduler_extra_args|length > 0 %}
  75. schedulerExtraArgs:
  76. {% for key in kube_kubeadm_scheduler_extra_args %}
  77. {{ key }}: {{ kube_kubeadm_scheduler_extra_args[key] }}
  78. {% endfor %}
  79. {% endif %}
  80. apiServerCertSANs:
  81. {% for san in apiserver_sans.split(' ') | unique %}
  82. - {{ san }}
  83. {% endfor %}
  84. certificatesDir: {{ kube_config_dir }}/ssl
  85. unifiedControlPlaneImage: "{{ hyperkube_image_repo }}:{{ hyperkube_image_tag }}"