2018-02-13 01:08:44 +00:00
|
|
|
---
|
|
|
|
|
2018-06-07 09:25:25 +00:00
|
|
|
- name: NGINX Ingress Controller | Remove legacy addon dir and manifests
|
|
|
|
file:
|
|
|
|
path: "{{ kube_config_dir }}/addons/ingress_nginx"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- inventory_hostname == groups['kube-master'][0]
|
|
|
|
tags:
|
|
|
|
- upgrade
|
|
|
|
|
|
|
|
- name: NGINX Ingress Controller | Remove legacy namespace
|
|
|
|
shell: |
|
|
|
|
{{ bin_dir }}/kubectl delete namespace {{ ingress_nginx_namespace }}
|
|
|
|
ignore_errors: yes
|
|
|
|
when:
|
|
|
|
- inventory_hostname == groups['kube-master'][0]
|
|
|
|
tags:
|
|
|
|
- upgrade
|
|
|
|
|
2018-02-13 01:08:44 +00:00
|
|
|
- name: NGINX Ingress Controller | Create addon dir
|
|
|
|
file:
|
|
|
|
path: "{{ kube_config_dir }}/addons/ingress_nginx"
|
|
|
|
state: directory
|
|
|
|
owner: root
|
|
|
|
group: root
|
|
|
|
mode: 0755
|
2018-06-07 09:25:25 +00:00
|
|
|
when:
|
|
|
|
- inventory_hostname == groups['kube-master'][0]
|
2018-02-13 01:08:44 +00:00
|
|
|
|
2018-08-22 16:16:13 +00:00
|
|
|
- name: NGINX Ingress Controller | Templates list
|
|
|
|
set_fact:
|
|
|
|
ingress_nginx_templates:
|
|
|
|
- { name: 00-namespace, file: 00-namespace.yml, type: ns }
|
|
|
|
- { name: deploy-default-backend, file: deploy-default-backend.yml, type: deploy }
|
|
|
|
- { name: svc-default-backend, file: svc-default-backend.yml, type: svc }
|
|
|
|
- { name: cm-ingress-nginx, file: cm-ingress-nginx.yml, type: cm }
|
|
|
|
- { name: cm-tcp-services, file: cm-tcp-services.yml, type: cm }
|
|
|
|
- { name: cm-udp-services, file: cm-udp-services.yml, type: cm }
|
|
|
|
- { name: sa-ingress-nginx, file: sa-ingress-nginx.yml, type: sa }
|
|
|
|
- { name: clusterrole-ingress-nginx, file: clusterrole-ingress-nginx.yml, type: clusterrole }
|
|
|
|
- { name: clusterrolebinding-ingress-nginx, file: clusterrolebinding-ingress-nginx.yml, type: clusterrolebinding }
|
|
|
|
- { name: role-ingress-nginx, file: role-ingress-nginx.yml, type: role }
|
|
|
|
- { name: rolebinding-ingress-nginx, file: rolebinding-ingress-nginx.yml, type: rolebinding }
|
|
|
|
- { name: ds-ingress-nginx-controller, file: ds-ingress-nginx-controller.yml, type: ds }
|
|
|
|
ingress_nginx_templates_for_psp:
|
|
|
|
- { name: psp-ingress-nginx, file: psp-ingress-nginx.yml, type: podsecuritypolicy }
|
|
|
|
|
|
|
|
- name: NGINX Ingress Controller | Append extra templates to NGINX Ingress Templates list for PodSecurityPolicy
|
|
|
|
set_fact:
|
|
|
|
ingress_nginx_templates: "{{ ingress_nginx_templates_for_psp + ingress_nginx_templates }}"
|
|
|
|
when: podsecuritypolicy_enabled
|
|
|
|
|
2018-02-13 01:08:44 +00:00
|
|
|
- name: NGINX Ingress Controller | Create manifests
|
|
|
|
template:
|
|
|
|
src: "{{ item.file }}.j2"
|
|
|
|
dest: "{{ kube_config_dir }}/addons/ingress_nginx/{{ item.file }}"
|
2018-08-22 16:16:13 +00:00
|
|
|
with_items: "{{ ingress_nginx_templates }}"
|
2018-02-13 01:08:44 +00:00
|
|
|
register: ingress_nginx_manifests
|
|
|
|
when:
|
|
|
|
- inventory_hostname == groups['kube-master'][0]
|
|
|
|
|
|
|
|
- name: NGINX Ingress Controller | Apply manifests
|
|
|
|
kube:
|
|
|
|
name: "{{ item.item.name }}"
|
|
|
|
namespace: "{{ ingress_nginx_namespace }}"
|
|
|
|
kubectl: "{{ bin_dir }}/kubectl"
|
|
|
|
resource: "{{ item.item.type }}"
|
|
|
|
filename: "{{ kube_config_dir }}/addons/ingress_nginx/{{ item.item.file }}"
|
|
|
|
state: "latest"
|
|
|
|
with_items: "{{ ingress_nginx_manifests.results }}"
|
|
|
|
when:
|
|
|
|
- inventory_hostname == groups['kube-master'][0]
|