2017-09-18 12:30:57 +00:00
|
|
|
---
|
|
|
|
- name: Set external kube-apiserver endpoint
|
|
|
|
set_fact:
|
2019-01-16 13:30:50 +00:00
|
|
|
external_apiserver_address: >-
|
2019-01-21 09:27:42 +00:00
|
|
|
{%- if loadbalancer_apiserver is defined and loadbalancer_apiserver.address is defined -%}
|
|
|
|
{{ loadbalancer_apiserver.address }}
|
2017-09-18 12:30:57 +00:00
|
|
|
{%- else -%}
|
2019-01-16 13:30:50 +00:00
|
|
|
{{ kube_apiserver_access_address }}
|
|
|
|
{%- endif -%}
|
|
|
|
external_apiserver_port: >-
|
2019-01-21 11:43:27 +00:00
|
|
|
{%- if loadbalancer_apiserver is defined and loadbalancer_apiserver.address is defined and loadbalancer_apiserver.port is defined -%}
|
2019-01-16 13:30:50 +00:00
|
|
|
{{ loadbalancer_apiserver.port|default(kube_apiserver_port) }}
|
|
|
|
{%- else -%}
|
|
|
|
{{ kube_apiserver_port }}
|
2017-09-18 12:30:57 +00:00
|
|
|
{%- endif -%}
|
2017-10-05 07:43:04 +00:00
|
|
|
tags:
|
|
|
|
- facts
|
2017-09-18 12:30:57 +00:00
|
|
|
|
2019-06-06 09:06:11 +00:00
|
|
|
- name: Create kube config dir for current/ansible become user
|
2017-09-18 12:30:57 +00:00
|
|
|
file:
|
2019-06-06 09:06:11 +00:00
|
|
|
path: "{{ ansible_env.HOME | default('/root') }}/.kube"
|
2017-09-18 12:30:57 +00:00
|
|
|
mode: "0700"
|
|
|
|
state: directory
|
|
|
|
|
2019-06-06 09:06:11 +00:00
|
|
|
- name: Copy admin kubeconfig to current/ansible become user home
|
2017-09-18 12:30:57 +00:00
|
|
|
copy:
|
|
|
|
src: "{{ kube_config_dir }}/admin.conf"
|
2019-06-06 09:06:11 +00:00
|
|
|
dest: "{{ ansible_env.HOME | default('/root') }}/.kube/config"
|
2017-09-18 12:30:57 +00:00
|
|
|
remote_src: yes
|
2018-05-14 09:29:48 +00:00
|
|
|
mode: "0600"
|
2017-09-18 12:30:57 +00:00
|
|
|
backup: yes
|
|
|
|
|
2019-01-28 09:59:15 +00:00
|
|
|
- name: Create kube artifacts dir
|
|
|
|
file:
|
|
|
|
path: "{{ artifacts_dir }}"
|
|
|
|
mode: "0750"
|
|
|
|
state: directory
|
|
|
|
delegate_to: localhost
|
|
|
|
become: no
|
|
|
|
run_once: yes
|
|
|
|
when: kubeconfig_localhost|default(false)
|
|
|
|
|
2019-07-11 06:46:54 +00:00
|
|
|
- name: Wait for k8s apiserver
|
|
|
|
wait_for:
|
|
|
|
host: "{{ kube_apiserver_access_address }}"
|
|
|
|
port: "{{ kube_apiserver_port }}"
|
|
|
|
timeout: 180
|
|
|
|
|
2019-04-19 13:01:54 +00:00
|
|
|
# NOTE(mattymo): Please forgive this workaround
|
2019-01-16 13:30:50 +00:00
|
|
|
- name: Generate admin kubeconfig with external api endpoint
|
|
|
|
shell: >-
|
2019-04-19 13:01:54 +00:00
|
|
|
{% if kubeadm_version is version('v1.14.0', '>=') %}
|
|
|
|
mkdir -p {{ kube_config_dir }}/external_kubeconfig &&
|
2019-01-16 13:30:50 +00:00
|
|
|
{% endif %}
|
2019-04-19 13:01:54 +00:00
|
|
|
{{ bin_dir }}/kubeadm
|
|
|
|
{% if kubeadm_version is version('v1.14.0', '>=') %}
|
|
|
|
init phase
|
|
|
|
{% elif kubeadm_version is version('v1.13.0', '>=') %}
|
|
|
|
alpha
|
|
|
|
{% else %}
|
|
|
|
alpha phase
|
|
|
|
{% endif %}
|
|
|
|
{% if kubeadm_version is version('v1.14.0', '>=') %}
|
|
|
|
kubeconfig admin
|
|
|
|
--kubeconfig-dir {{ kube_config_dir }}/external_kubeconfig
|
|
|
|
{% else %}
|
2019-01-16 13:30:50 +00:00
|
|
|
kubeconfig user
|
|
|
|
--client-name kubernetes-admin
|
|
|
|
--org system:masters
|
2019-04-19 13:01:54 +00:00
|
|
|
{% endif %}
|
2019-05-08 20:38:36 +00:00
|
|
|
--cert-dir {{ kube_cert_dir }}
|
2019-01-16 13:30:50 +00:00
|
|
|
--apiserver-advertise-address {{ external_apiserver_address }}
|
|
|
|
--apiserver-bind-port {{ external_apiserver_port }}
|
2019-04-19 13:01:54 +00:00
|
|
|
{% if kubeadm_version is version('v1.14.0', '>=') %}
|
2019-05-06 10:29:36 +00:00
|
|
|
>/dev/null && cat {{ kube_config_dir }}/external_kubeconfig/admin.conf &&
|
2019-04-19 13:01:54 +00:00
|
|
|
rm -rf {{ kube_config_dir }}/external_kubeconfig
|
|
|
|
{% endif %}
|
2019-03-26 10:03:19 +00:00
|
|
|
environment: "{{ proxy_env }}"
|
2019-01-16 13:30:50 +00:00
|
|
|
run_once: yes
|
|
|
|
register: admin_kubeconfig
|
|
|
|
|
|
|
|
- name: Write admin kubeconfig on ansible host
|
|
|
|
copy:
|
|
|
|
content: "{{ admin_kubeconfig.stdout }}"
|
2017-09-18 12:30:57 +00:00
|
|
|
dest: "{{ artifacts_dir }}/admin.conf"
|
2019-01-16 13:30:50 +00:00
|
|
|
mode: 0640
|
|
|
|
delegate_to: localhost
|
|
|
|
become: no
|
2017-09-18 12:30:57 +00:00
|
|
|
run_once: yes
|
|
|
|
when: kubeconfig_localhost|default(false)
|
|
|
|
|
|
|
|
- name: Copy kubectl binary to ansible host
|
2019-08-22 09:40:32 +00:00
|
|
|
synchronize:
|
2017-09-18 12:30:57 +00:00
|
|
|
src: "{{ bin_dir }}/kubectl"
|
2018-04-09 10:19:26 +00:00
|
|
|
dest: "{{ artifacts_dir }}/kubectl"
|
2017-09-18 12:30:57 +00:00
|
|
|
become: no
|
|
|
|
run_once: yes
|
|
|
|
when: kubectl_localhost|default(false)
|
2018-02-16 12:53:35 +00:00
|
|
|
|
|
|
|
- name: create helper script kubectl.sh on ansible host
|
|
|
|
copy:
|
|
|
|
content: |
|
|
|
|
#!/bin/bash
|
2019-07-16 09:23:25 +00:00
|
|
|
./kubectl --kubeconfig=${BASH_SOURCE%/*}/admin.conf $@
|
2018-02-16 12:53:35 +00:00
|
|
|
dest: "{{ artifacts_dir }}/kubectl.sh"
|
|
|
|
mode: 0755
|
|
|
|
become: no
|
|
|
|
run_once: yes
|
|
|
|
delegate_to: localhost
|
|
|
|
when: kubectl_localhost|default(false) and kubeconfig_localhost|default(false)
|