Local connection to remote Grafana can fail

Following deployment of Grafana, a check is made to ensure that the
login page is accessible. If the Grafana container has been deployed
to a remote host, but is not directly accessible over the deployment
network then the check will fail because the task is set to run with
connection: local. For example, if Ansible is using a different
network to the network on which grafana is exposed to connect to the
remote host then the task may fail. A similar problem exists for the
remaining two tasks in the post_config file.

Further to this, if Grafana is not accessible, the ansible uri
module does not return a status field, so no retry attempts are made
and the task fails with an obscure message:

TASK [grafana : Wait for grafana application ready] *****************
fatal: [some_remote_node]: FAILED! => {"failed": true, "msg": "The
conditional check 'result.status == 200' failed. The error was: error
while evaluating conditional (result.status == 200): 'dict object' has
no attribute 'status'"}

$ ansible --version
ansible 2.3.2.0
  config file = /etc/ansible/ansible.cfg
  configured module search path = Default w/o overrides
  python version = 2.7.5 (default, Aug 4 2017, 00:39:18) [GCC 4.8.5 20150623
(Red Hat 4.8.5-16)]

Change-Id: I77e2129b4a1c5f2f0802fb92eb03395ff72cf5f3
Closes-Bug: #1742501
This commit is contained in:
Doug Szumski 2018-01-10 17:47:45 +00:00
parent 68aaad6c5d
commit 2854671018

View File

@ -4,11 +4,10 @@
url: "{{ internal_protocol }}://{{ kolla_internal_vip_address }}:{{ grafana_server_port }}/login" url: "{{ internal_protocol }}://{{ kolla_internal_vip_address }}:{{ grafana_server_port }}/login"
status_code: 200 status_code: 200
register: result register: result
until: result.status == 200 until: result | failed or result.status == 200
retries: 10 retries: 10
delay: 2 delay: 2
run_once: true run_once: true
connection: local
- name: Enable grafana datasources - name: Enable grafana datasources
uri: uri:
@ -22,7 +21,6 @@
status_code: 200, 409 status_code: 200, 409
register: response register: response
run_once: True run_once: True
connection: local
changed_when: response.status == 200 changed_when: response.status == 200
failed_when: response.status not in [200, 409] or failed_when: response.status not in [200, 409] or
response.status == 409 and ("Data source with same name already exists" not in response.json.message|default("")) response.status == 409 and ("Data source with same name already exists" not in response.json.message|default(""))
@ -40,5 +38,4 @@
register: grafana_response register: grafana_response
changed_when: grafana_response.status == 200 changed_when: grafana_response.status == 200
run_once: true run_once: true
connection: local
when: grafana_custom_dashboard_file.stat.exists when: grafana_custom_dashboard_file.stat.exists