
The elastic Stack has the ability to get application performance metrics using the built in APM server. This change implements the APM server in an existing ELK environment. Change-Id: Ie6f533b81cfdb0c6a4ba2f33fd3b9f0a3e49a1fc Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
57 lines
1.4 KiB
YAML
57 lines
1.4 KiB
YAML
---
|
|
- name: Install apm-server
|
|
hosts: apm-server
|
|
become: true
|
|
vars:
|
|
haproxy_ssl: false
|
|
|
|
vars_files:
|
|
- vars/variables.yml
|
|
|
|
pre_tasks:
|
|
- include_tasks: common_task_install_elk_repo.yml
|
|
|
|
- name: Ensure apm-server is installed
|
|
apt:
|
|
name: "{{ item }}"
|
|
state: present
|
|
update_cache: true
|
|
with_items:
|
|
- apm-server
|
|
|
|
post_tasks:
|
|
- name: Drop apm-server conf file
|
|
template:
|
|
src: templates/apm-server.yml.j2
|
|
dest: /etc/apm-server/apm-server.yml
|
|
|
|
- name: Enable and restart APM Server
|
|
systemd:
|
|
name: "apm-server"
|
|
enabled: true
|
|
state: restarted
|
|
|
|
|
|
- name: Load apm-server Dashboards
|
|
hosts: apm-server[0]
|
|
become: true
|
|
vars_files:
|
|
- vars/variables.yml
|
|
tasks:
|
|
- name: Load templates
|
|
shell: >-
|
|
{% set IP_ARR=[] %}
|
|
{% for host in groups['elastic-logstash'] %}
|
|
{% if IP_ARR.insert(loop.index,hostvars[host]['ansible_host']) %}
|
|
{% endif %}
|
|
{% endfor %}
|
|
{% set elasticsearch_hosts = [IP_ARR | map('regex_replace', '$', ':' ~ elastic_port|string()) | map('regex_replace', '$', '"') | map('regex_replace', '^', '"') | list | join(',' )] %}
|
|
apm-server setup
|
|
{{ item }}
|
|
-E 'apm-server.host=localhost:8200'
|
|
-E 'output.elasticsearch.hosts={{ elasticsearch_hosts }}'
|
|
-e -v
|
|
with_items:
|
|
- "--template"
|
|
- "--dashboards"
|