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.

126 lines
6.5 KiB

9 years ago
9 years ago
9 years ago
9 years ago
  1. # logging to stderr means we get it in the systemd journal
  2. KUBE_LOGTOSTDERR="--logtostderr=true"
  3. KUBE_LOG_LEVEL="--v={{ kube_log_level }}"
  4. # The address for the info server to serve on (set to 0.0.0.0 or "" for all interfaces)
  5. KUBELET_ADDRESS="--address={{ kubelet_bind_address }} --node-ip={{ kubelet_address }}"
  6. # The port for the info server to serve on
  7. # KUBELET_PORT="--port=10250"
  8. {% if kube_override_hostname|default('') %}
  9. # You may leave this blank to use the actual hostname
  10. KUBELET_HOSTNAME="--hostname-override={{ kube_override_hostname }}"
  11. {% endif %}
  12. {# Base kubelet args #}
  13. {% set kubelet_args_base %}
  14. --pod-manifest-path={{ kube_manifest_dir }} \
  15. --cadvisor-port={{ kube_cadvisor_port }} \
  16. --pod-infra-container-image={{ pod_infra_image_repo }}:{{ pod_infra_image_tag }} \
  17. --node-status-update-frequency={{ kubelet_status_update_frequency }} \
  18. --docker-disable-shared-pid={{ kubelet_disable_shared_pid }} \
  19. --client-ca-file={{ kube_cert_dir }}/ca.pem \
  20. --tls-cert-file={{ kube_cert_dir }}/node-{{ inventory_hostname }}.pem \
  21. --tls-private-key-file={{ kube_cert_dir }}/node-{{ inventory_hostname }}-key.pem \
  22. --anonymous-auth=false \
  23. --read-only-port={{ kube_read_only_port }} \
  24. {% if kube_version | version_compare('v1.6', '>=') %}
  25. {# flag got removed with 1.7.0 #}
  26. {% if kube_version | version_compare('v1.7', '<') %}
  27. --enable-cri={{ kubelet_enable_cri }} \
  28. {% endif %}
  29. --cgroup-driver={{ kubelet_cgroup_driver|default(kubelet_cgroup_driver_detected) }} \
  30. --cgroups-per-qos={{ kubelet_cgroups_per_qos }} \
  31. --max-pods={{ kubelet_max_pods }} \
  32. {% if kube_version | version_compare('v1.8', '<') %}
  33. --experimental-fail-swap-on={{ kubelet_fail_swap_on|default(true)}} \
  34. {% else %}
  35. --fail-swap-on={{ kubelet_fail_swap_on|default(true)}} \
  36. {% endif %}
  37. {% if kubelet_authentication_token_webhook %}
  38. --authentication-token-webhook \
  39. {% endif %}
  40. {% if kubelet_authorization_mode_webhook %}
  41. --authorization-mode=Webhook \
  42. {% endif %}
  43. --enforce-node-allocatable={{ kubelet_enforce_node_allocatable }} {% endif %}{% endset %}
  44. {# DNS settings for kubelet #}
  45. {% if dns_mode in ['kubedns', 'coredns'] %}
  46. {% set kubelet_args_cluster_dns %}--cluster-dns={{ skydns_server }}{% endset %}
  47. {% elif dns_mode == 'coredns_dual' %}
  48. {% set kubelet_args_cluster_dns %}--cluster-dns={{ skydns_server }},{{ skydns_server_secondary }}{% endset %}
  49. {% elif dns_mode == 'dnsmasq_kubedns' %}
  50. {% set kubelet_args_cluster_dns %}--cluster-dns={{ dnsmasq_dns_server }}{% endset %}
  51. {% elif dns_mode == 'manual' %}
  52. {% set kubelet_args_cluster_dns %}--cluster-dns={{ manual_dns_server }}{% endset %}
  53. {% else %}
  54. {% set kubelet_args_cluster_dns %}{% endset %}
  55. {% endif %}
  56. {% set kubelet_args_dns %}{{ kubelet_args_cluster_dns }} --cluster-domain={{ dns_domain }} --resolv-conf={{ kube_resolv_conf }}{% endset %}
  57. {# Location of the apiserver #}
  58. {% if kube_version | version_compare('v1.8', '<') %}
  59. {% set kubelet_args_kubeconfig %}--kubeconfig={{ kube_config_dir}}/node-kubeconfig.yaml --require-kubeconfig{% endset %}
  60. {% else %}
  61. {% set kubelet_args_kubeconfig %}--kubeconfig={{ kube_config_dir}}/node-kubeconfig.yaml{% endset %}
  62. {% endif %}
  63. {% if standalone_kubelet|bool %}
  64. {# We are on a master-only host. Make the master unschedulable in this case. #}
  65. {% if kube_version | version_compare('v1.6', '>=') %}
  66. {# Set taints on the master so that it's unschedulable by default. Use node-role.kubernetes.io/master taint like kubeadm. #}
  67. {% set kubelet_args_kubeconfig %}{{ kubelet_args_kubeconfig }} --register-with-taints=node-role.kubernetes.io/master=:NoSchedule{% endset %}
  68. {% else %}
  69. {# --register-with-taints was added in 1.6 so just register unschedulable if Kubernetes < 1.6 #}
  70. {% set kubelet_args_kubeconfig %}{{ kubelet_args_kubeconfig }} --register-schedulable=false{% endset %}
  71. {% endif %}
  72. {% endif %}
  73. {# Node reserved CPU/memory #}
  74. {% if is_kube_master|bool %}
  75. {% set kube_reserved %}--kube-reserved cpu={{ kube_master_cpu_reserved }},memory={{ kube_master_memory_reserved|regex_replace('Mi', 'M') }}{% endset %}
  76. {% else %}
  77. {% set kube_reserved %}--kube-reserved cpu={{ kube_cpu_reserved }},memory={{ kube_memory_reserved|regex_replace('Mi', 'M') }}{% endset %}
  78. {% endif %}
  79. {# Kubelet node labels #}
  80. {% set role_node_labels = [] %}
  81. {% if inventory_hostname in groups['kube-master'] %}
  82. {% set dummy = role_node_labels.append('node-role.kubernetes.io/master=true') %}
  83. {% if not standalone_kubelet|bool %}
  84. {% set dummy = role_node_labels.append('node-role.kubernetes.io/node=true') %}
  85. {% endif %}
  86. {% else %}
  87. {% set dummy = role_node_labels.append('node-role.kubernetes.io/node=true') %}
  88. {% endif %}
  89. {% if inventory_hostname in groups['kube-ingress']|default([]) %}
  90. {% set dummy = role_node_labels.append('node-role.kubernetes.io/ingress=true') %}
  91. {% endif %}
  92. {% set inventory_node_labels = [] %}
  93. {% if node_labels is defined %}
  94. {% for labelname, labelvalue in node_labels.iteritems() %}
  95. {% set dummy = inventory_node_labels.append('%s=%s'|format(labelname, labelvalue)) %}
  96. {% endfor %}
  97. {% endif %}
  98. {% set all_node_labels = role_node_labels + inventory_node_labels %}
  99. KUBELET_ARGS="{{ kubelet_args_base }} {{ kubelet_args_dns }} {{ kubelet_args_kubeconfig }} {{ kube_reserved }} --node-labels={{ all_node_labels | join(',') }} {% if kube_feature_gates %} --feature-gates={{ kube_feature_gates|join(',') }} {% endif %} {% if kubelet_custom_flags is string %} {{kubelet_custom_flags}} {% else %}{% for flag in kubelet_custom_flags %} {{flag}} {% endfor %}{% endif %}"
  100. {% if kube_network_plugin is defined and kube_network_plugin in ["calico", "canal", "flannel", "weave", "contiv", "cilium"] %}
  101. KUBELET_NETWORK_PLUGIN="--network-plugin=cni --cni-conf-dir=/etc/cni/net.d --cni-bin-dir=/opt/cni/bin"
  102. {% elif kube_network_plugin is defined and kube_network_plugin == "weave" %}
  103. DOCKER_SOCKET="--docker-endpoint=unix:/var/run/weave/weave.sock"
  104. {% elif kube_network_plugin is defined and kube_network_plugin == "cloud" %}
  105. KUBELET_NETWORK_PLUGIN="--hairpin-mode=promiscuous-bridge --network-plugin=kubenet"
  106. {% endif %}
  107. KUBELET_VOLUME_PLUGIN="--volume-plugin-dir={{ kubelet_flexvolumes_plugins_dir }}"
  108. # Should this cluster be allowed to run privileged docker containers
  109. KUBE_ALLOW_PRIV="--allow-privileged=true"
  110. {% if cloud_provider is defined and cloud_provider in ["openstack", "azure", "vsphere"] %}
  111. KUBELET_CLOUDPROVIDER="--cloud-provider={{ cloud_provider }} --cloud-config={{ kube_config_dir }}/cloud_config"
  112. {% elif cloud_provider is defined and cloud_provider == "aws" %}
  113. KUBELET_CLOUDPROVIDER="--cloud-provider={{ cloud_provider }}"
  114. {% else %}
  115. KUBELET_CLOUDPROVIDER=""
  116. {% endif %}
  117. PATH={{ bin_dir }}:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin