ad91d5773e
This change makes it possible for a deployer to modify the set of indexes and weights assosiated with them. If modified, the local facts will be automatically updated. Change-Id: Iaea1f22d8aad2abdd02801dd9acad5f969b78d0e Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
105 lines
3.3 KiB
YAML
105 lines
3.3 KiB
YAML
---
|
|
# Copyright 2018, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
- name: Ensure local facts directory exists
|
|
file:
|
|
dest: "/etc/ansible/facts.d"
|
|
state: directory
|
|
group: "root"
|
|
owner: "root"
|
|
mode: "0755"
|
|
recurse: no
|
|
|
|
- name: Initialize local facts
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/elastic.fact"
|
|
section: "retention"
|
|
option: cacheable
|
|
value: true
|
|
|
|
- name: Refresh local facts
|
|
setup:
|
|
filter: ansible_local
|
|
gather_subset: "!all"
|
|
tags:
|
|
- always
|
|
|
|
- name: Retention storage block
|
|
block:
|
|
- name: Query es storage
|
|
uri:
|
|
url: "http://{{ coordination_nodes[0] }}/_nodes/{{ (data_nodes | map('extract', hostvars, 'ansible_host') | list) | join(',') }}/stats/fs"
|
|
method: GET
|
|
register: elk_data
|
|
environment:
|
|
no_proxy: "{{ coordination_nodes[0].split(':')[0] }}"
|
|
until:
|
|
- elk_data is success and elk_data['json'] is defined
|
|
retries: 5
|
|
delay: 30
|
|
run_once: true
|
|
|
|
- name: Set retention keys fact
|
|
set_fact:
|
|
es_storage_json: "{{ elk_data['json'] }}"
|
|
|
|
- name: Load retention algo variables
|
|
include_vars: "calculate_index_retention_{{ elastic_index_retention_algorithm }}.yml"
|
|
tags:
|
|
- always
|
|
|
|
- name: Set storage fact
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/elastic.fact"
|
|
section: "retention"
|
|
option: "cluster_nodes"
|
|
value: "{{ groups['elastic-logstash'] | length }}"
|
|
|
|
- name: Set retention policy keys fact
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/elastic.fact"
|
|
section: "retention"
|
|
option: "elastic_beat_retention_policy_keys"
|
|
value: "{{ elastic_beat_retention_policy_hosts.keys() | list | sort }}"
|
|
|
|
- name: Set size fact
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/elastic.fact"
|
|
section: "retention"
|
|
option: "elastic_{{ item.key }}_size"
|
|
value: "{{ item.value }}"
|
|
with_dict: "{{ es_storage_per_index }}"
|
|
|
|
- name: Set retention fact
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/elastic.fact"
|
|
section: "retention"
|
|
option: "elastic_{{ item.key }}_retention"
|
|
value: "{{ item.value }}"
|
|
with_dict: "{{ es_days_per_index }}"
|
|
|
|
- name: Refresh local facts
|
|
setup:
|
|
filter: ansible_local
|
|
gather_subset: "!all"
|
|
tags:
|
|
- always
|
|
when:
|
|
- (ansible_local['elastic']['retention']['cluster_nodes'] is undefined) or
|
|
((groups['elastic-logstash'] | length) != (ansible_local['elastic']['retention']['cluster_nodes'] | int)) or
|
|
((ansible_local['elastic']['retention']['elastic_beat_retention_policy_keys'] is defined) and
|
|
((ansible_local['elastic']['retention']['elastic_beat_retention_policy_keys'] | from_yaml) != (elastic_beat_retention_policy_hosts.keys() | list | sort))) or
|
|
(elastic_retention_refresh | bool)
|