--- # Workaround to retry a block of tasks, ansible doesn't have a direct way to do it, # you can follow the block loop request in: https://github.com/ansible/ansible/issues/46203 - block: - name: Set the retry count set_fact: retry_count: "{{ 0 if retry_count is undefined else retry_count|int + 1 }}" - name: Calico | Set label for route reflector # noqa 301 305 shell: "{{ bin_dir }}/calicoctl.sh label node {{ inventory_hostname }} calico-rr-id={{ calico_rr_id }} --overwrite" changed_when: false register: calico_rr_id_label until: calico_rr_id_label is succeeded delay: "{{ retry_stagger | random + 3 }}" retries: 10 when: calico_rr_id is defined - name: Calico-rr | Fetch current node object command: "{{ bin_dir }}/calicoctl.sh get node {{ inventory_hostname }} -ojson" changed_when: false register: calico_rr_node until: calico_rr_node is succeeded delay: "{{ retry_stagger | random + 3 }}" retries: 10 - name: Calico-rr | Set route reflector cluster ID set_fact: calico_rr_node_patched: >- {{ calico_rr_node.stdout | from_json | combine({ 'spec': { 'bgp': { 'routeReflectorClusterID': cluster_id }}}, recursive=True) }} - name: Calico-rr | Configure route reflector # noqa 301 305 shell: "{{ bin_dir }}/calicoctl.sh replace -f-" args: stdin: "{{ calico_rr_node_patched | to_json }}" rescue: - name: Fail if retry limit is reached fail: msg: Ended after 10 retries when: retry_count|int == 10 - name: Retrying node configuration debug: msg: "Failed to configure route reflector - Retrying..." - name: Retry node configuration include_tasks: update-node.yml