24 lines
1.2 KiB
YAML
24 lines
1.2 KiB
YAML
# FXIME: add persistent routing rule
|
|
- hosts: kube-master
|
|
tasks:
|
|
- name: Get kube service net
|
|
shell: grep KUBE_SERVICE_ADDRESSES /etc/kubernetes/kube-apiserver.env | grep -oE "\b([0-9]{1,3}\.){3}[0-9]{1,3}/[0-9]{1,2}\b"
|
|
register: kube_service_addresses
|
|
run_once: true
|
|
- hosts: all
|
|
tasks:
|
|
- name: Get local IP
|
|
shell: "calicoctl status | grep IP: | awk '{print $2}'"
|
|
register: local_ip
|
|
- name: Get route
|
|
shell: ip ro ls | grep "^{{ hostvars[groups['kube-master'][0]]['kube_service_addresses']['stdout'] }}" || echo ""
|
|
register: local_route
|
|
- name: Clean up route
|
|
shell: ip ro del {{ hostvars[groups['kube-master'][0]]['kube_service_addresses']['stdout'] }} || true
|
|
when: local_route.stdout.find('{{ local_ip.stdout }}') == -1
|
|
- name: Setup route
|
|
shell: ip ro add {{ hostvars[groups['kube-master'][0]]['kube_service_addresses']['stdout'] }} via {{ local_ip.stdout }}
|
|
when: local_route.stdout.find('{{ local_ip.stdout }}') == -1
|
|
- name: Add openstack namespace to resolv.conf
|
|
shell: grep openstack.svc.cluster.local /etc/resolv.conf || sed '/^search / s/$/ openstack.svc.cluster.local/' -i /etc/resolv.conf
|
|
|