add mtail role
This commit is contained in:
parent
341583bbe1
commit
523d6f3b32
50
roles/mtail/defaults/main.yaml
Normal file
50
roles/mtail/defaults/main.yaml
Normal file
@ -0,0 +1,50 @@
|
||||
---
|
||||
mtail_go_arch_map:
|
||||
i386: '386'
|
||||
x86_64: 'amd64'
|
||||
|
||||
mtail_go_arch: "{{ mtail_go_arch_map[ansible_architecture] | default('amd64') }}"
|
||||
|
||||
mtail_service_name: mtail.service
|
||||
mtail_service_state: started
|
||||
mtail_service_enabled: yes
|
||||
|
||||
mtail_version_regex: ^mtail version (\S+)
|
||||
|
||||
mtail_github_project_url: https://github.com/google/mtail
|
||||
mtail_release_file: "mtail_{{ mtail_version }}_{{ ansible_system | capitalize }}_{{ ansible_architecture }}.tar.gz"
|
||||
mtail_release_url: "{{ mtail_github_project_url }}/releases/download/v{{ mtail_version }}/{{ mtail_release_file }}"
|
||||
mtail_download_path: "/tmp/{{ mtail_release_file }}"
|
||||
mtail_checksum_url: "{{ mtail_github_project_url }}/releases/download/v{{ mtail_version }}/checksums.txt"
|
||||
mtail_extracted_path: "/tmp"
|
||||
mtail_unarchive_dest_path: "/tmp"
|
||||
|
||||
mtail_user: mtail
|
||||
mtail_user_state: present
|
||||
mtail_user_shell: /usr/sbin/nologin
|
||||
mtail_append_groups:
|
||||
- adm
|
||||
|
||||
mtail_group: mtail
|
||||
mtail_group_state: "{{ mtail_user_state | default('present') }}"
|
||||
|
||||
mtail_etc_path: /etc/mtail
|
||||
mtail_etc_owner: root
|
||||
mtail_etc_group: root
|
||||
mtail_etc_mode: "0755"
|
||||
|
||||
mtail_var_path: /var/lib/mtail
|
||||
mtail_var_owner: "{{ mtail_user }}"
|
||||
mtail_var_group: "{{ mtail_group }}"
|
||||
mtail_var_mode: "0755"
|
||||
|
||||
mtail_var_log_path: /var/log/mtail
|
||||
mtail_var_log_owner: "{{ mtail_user }}"
|
||||
mtail_var_log_group: "{{ mtail_group }}"
|
||||
mtail_var_log_mode: "0755"
|
||||
|
||||
mtail_bin_path: /usr/local/bin
|
||||
|
||||
mtail_arg_logs:
|
||||
- "/var/log/syslog/{{ inventory_hostname_short }}/*/*/*.log"
|
||||
- /var/log/nginx/*.access.log
|
29
roles/mtail/files/rules/nginx.mtail
Normal file
29
roles/mtail/files/rules/nginx.mtail
Normal file
@ -0,0 +1,29 @@
|
||||
getfilename() !~ /nginx\/.*\.log$/ {
|
||||
stop
|
||||
}
|
||||
|
||||
counter nginx_http_requests_total by vhost, method, code
|
||||
counter nginx_http_response_size_bytes_total by vhost, method, code
|
||||
|
||||
histogram nginx_http_response_time_seconds buckets 0.0, 0.01, 0.025, 0.05, 0.1, 0.25, 0.5, 1.0, 2.5, 5.0, 10.0, 25.0, 50.0 by vhost, method, code
|
||||
|
||||
/^/ +
|
||||
/(?P<vhost>[0-9A-Za-z\.\-:]+) / +
|
||||
/(?P<remote_addr>\S+) / +
|
||||
/- / +
|
||||
/(?P<remote_user>\S+) / +
|
||||
/\[(?P<time_local>\d{2}\/\w{3}\/\d{4}:\d{2}:\d{2}:\d{2} (\+|-)\d{4})\] / +
|
||||
/"(?P<request_method>[A-Z]+) (?P<request_uri>\S+) (?P<http_version>HTTP\/[0-9\.]+)" / +
|
||||
/(?P<status>\d{3}) / +
|
||||
/(?P<bytes_sent>\d+) / +
|
||||
/(?P<request_time>\d+\.\d+) / +
|
||||
/"(?P<http_referer>\S+)" / +
|
||||
/"(?P<http_user_agent>[[:print:]]+)" / +
|
||||
/"(?P<http_x_forwarded_for>\S+)"/ +
|
||||
/$/ {
|
||||
nginx_http_requests_total[$vhost][$request_method][$status]++
|
||||
|
||||
nginx_http_response_size_bytes_total[$vhost][$request_method][$status] += $bytes_sent
|
||||
|
||||
nginx_http_response_time_seconds[$vhost][$request_method][$status] = $request_time
|
||||
}
|
32
roles/mtail/files/rules/syslog.mtail
Normal file
32
roles/mtail/files/rules/syslog.mtail
Normal file
@ -0,0 +1,32 @@
|
||||
getfilename() !~ /^\/var\/log\/syslog\// {
|
||||
stop
|
||||
}
|
||||
|
||||
def syslog {
|
||||
/(?P<date>(?P<legacy_date>\w+\s+\d+\s+\d+:\d+:\d+)|(?P<rfc3339_date>\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}.\d+[+-]\d{2}:\d{2}))/ +
|
||||
/\s+(?:\w+@)?(?P<hostname>[\w\.-]+)\s+(?P<application>[\w\.-]+)(?:\[(?P<pid>\d+)\])?:\s+(?P<message>.*)/ {
|
||||
# If the legacy_date regexp matched, try this format.
|
||||
len($legacy_date) > 0 {
|
||||
strptime($legacy_date, "Jan _2 15:04:05")
|
||||
}
|
||||
# If the RFC3339 style matched, parse it this way.
|
||||
len($rfc3339_date) > 0 {
|
||||
strptime($rfc3339_date, "2006-01-02T15:04:05-07:00")
|
||||
}
|
||||
# Call into the decorated block
|
||||
next
|
||||
}
|
||||
}
|
||||
|
||||
counter syslog_loglines_total by application
|
||||
counter ssh_invalid_user
|
||||
|
||||
@syslog {
|
||||
syslog_loglines_total[$application]++
|
||||
$application == "sshd" {
|
||||
$message =~ /^Invalid user/ {
|
||||
ssh_invalid_user++
|
||||
}
|
||||
}
|
||||
}
|
||||
|
6
roles/mtail/handlers/main.yaml
Normal file
6
roles/mtail/handlers/main.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: restart mtail
|
||||
systemd:
|
||||
name: mtail.service
|
||||
daemon_reload: true
|
||||
state: restarted
|
67
roles/mtail/tasks/configure.yaml
Normal file
67
roles/mtail/tasks/configure.yaml
Normal file
@ -0,0 +1,67 @@
|
||||
---
|
||||
- name: create group
|
||||
group:
|
||||
name: "{{ mtail_group }}"
|
||||
system: true
|
||||
state: "{{ mtail_group_state | default('present') }}"
|
||||
|
||||
- name: create user
|
||||
user:
|
||||
name: "{{ mtail_user }}"
|
||||
system: true
|
||||
shell: "{{ mtail_user_shell }}"
|
||||
group: "{{ mtail_group }}"
|
||||
groups: "{{ [mtail_group] + (mtail_append_groups | default([])) }}"
|
||||
append: true
|
||||
createhome: false
|
||||
home: "{{ mtail_var_path }}"
|
||||
state: "{{ mtail_user_state | default('present') }}"
|
||||
|
||||
- name: create etc path
|
||||
file:
|
||||
path: "{{ mtail_etc_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_etc_owner }}"
|
||||
group: "{{ mtail_etc_group }}"
|
||||
mode: "{{ mtail_etc_mode }}"
|
||||
|
||||
- name: create var path
|
||||
file:
|
||||
path: "{{ mtail_var_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_var_owner }}"
|
||||
group: "{{ mtail_var_group }}"
|
||||
mode: "{{ mtail_var_mode }}"
|
||||
|
||||
- name: create var_log path
|
||||
file:
|
||||
path: "{{ mtail_var_log_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_var_log_owner }}"
|
||||
group: "{{ mtail_var_log_group }}"
|
||||
mode: "{{ mtail_var_log_mode }}"
|
||||
|
||||
- name: configure rules
|
||||
copy:
|
||||
src: "{{ item }}"
|
||||
dest: "{{ mtail_etc_path }}/{{ item | basename }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: "0755"
|
||||
loop: "{{ lookup('fileglob', 'rules/*.mtail', wantlist=True) }}"
|
||||
notify: restart mtail
|
||||
|
||||
- name: configure systemd template
|
||||
template:
|
||||
src: mtail.service.j2
|
||||
dest: /etc/systemd/system/mtail.service
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0444
|
||||
notify: restart mtail
|
||||
|
||||
- name: manage service
|
||||
service:
|
||||
name: "{{ mtail_service_name }}"
|
||||
enabled: "{{ mtail_service_enabled }}"
|
||||
state: "{{ mtail_service_state }}"
|
0
roles/mtail/tasks/default.yaml
Normal file
0
roles/mtail/tasks/default.yaml
Normal file
52
roles/mtail/tasks/install.yaml
Normal file
52
roles/mtail/tasks/install.yaml
Normal file
@ -0,0 +1,52 @@
|
||||
---
|
||||
#- block:
|
||||
# - name: download tar
|
||||
# get_url:
|
||||
# url: "{{ mtail_release_url }}"
|
||||
# dest: "{{ mtail_download_path }}"
|
||||
# register: dl
|
||||
# until: dl is success
|
||||
# retries: 5
|
||||
# delay: 10
|
||||
#
|
||||
# - name: install binaries
|
||||
# copy:
|
||||
# src: "{{ mtail_download_path }}"
|
||||
# dest: "{{ mtail_bin_path }}/mtail"
|
||||
# owner: root
|
||||
# group: root
|
||||
# mode: 0755
|
||||
# remote_src: true
|
||||
# notify: restart mtail
|
||||
# when: mtail_version != mtail_local_version
|
||||
#
|
||||
- block:
|
||||
- name: download tar
|
||||
get_url:
|
||||
url: "{{ mtail_release_url }}"
|
||||
dest: "{{ mtail_download_path }}"
|
||||
checksum: "{{ mtail_checksum }}"
|
||||
register: dl
|
||||
until: dl is success
|
||||
retries: 5
|
||||
delay: 10
|
||||
|
||||
- name: extract tar
|
||||
unarchive:
|
||||
src: "{{ mtail_download_path }}"
|
||||
dest: "{{ mtail_unarchive_dest_path }}"
|
||||
creates: "{{ mtail_extracted_path }}/mtail"
|
||||
remote_src: true
|
||||
|
||||
- name: install binaries
|
||||
copy:
|
||||
src: "{{ mtail_extracted_path }}/{{ item }}"
|
||||
dest: "{{ mtail_bin_path }}/{{ item }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0755
|
||||
remote_src: true
|
||||
loop:
|
||||
- mtail
|
||||
notify: restart mtail
|
||||
when: mtail_version != mtail_local_version
|
30
roles/mtail/tasks/main.yaml
Normal file
30
roles/mtail/tasks/main.yaml
Normal file
@ -0,0 +1,30 @@
|
||||
---
|
||||
- name: gather os specific variables
|
||||
include_vars: "{{ lookup('first_found', possible_files) }}"
|
||||
vars:
|
||||
possible_files:
|
||||
files:
|
||||
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml"
|
||||
- "{{ ansible_distribution }}.yaml"
|
||||
- "{{ ansible_os_family }}.yaml"
|
||||
- "default.yaml"
|
||||
paths:
|
||||
- vars
|
||||
|
||||
- name: include os specific tasks
|
||||
include_tasks: "{{ lookup('first_found', possible_files) }}"
|
||||
vars:
|
||||
possible_files:
|
||||
files:
|
||||
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml"
|
||||
- "{{ ansible_distribution }}.yaml"
|
||||
- "{{ ansible_os_family }}.yaml"
|
||||
- "default.yaml"
|
||||
paths:
|
||||
- tasks
|
||||
|
||||
- include: pre.yaml
|
||||
|
||||
- include: install.yaml
|
||||
|
||||
- include: configure.yaml
|
88
roles/mtail/tasks/pre.yaml
Normal file
88
roles/mtail/tasks/pre.yaml
Normal file
@ -0,0 +1,88 @@
|
||||
---
|
||||
#- name: determine if installed
|
||||
# stat:
|
||||
# path: "{{ mtail_bin_path }}/mtail"
|
||||
# register: st
|
||||
#
|
||||
#- name: set mtail_installed
|
||||
# set_fact:
|
||||
# mtail_installed: "{{ st.stat.exists | bool }}"
|
||||
#
|
||||
#- block:
|
||||
# - name: determine latest version
|
||||
# uri:
|
||||
# url: https://api.github.com/repos/google/mtail/releases/latest
|
||||
# return_content: true
|
||||
# body_format: json
|
||||
# register: _latest_version
|
||||
# until: _latest_version.status == 200
|
||||
# retries: 3
|
||||
#
|
||||
# - name: set mtail_version
|
||||
# set_fact:
|
||||
# mtail_version: "{{ _latest_version.json['tag_name'] | regex_replace('^v', '') }}"
|
||||
#
|
||||
#- block:
|
||||
# - name: determine installed version
|
||||
# command: "{{ mtail_bin_path }}/mtail --version"
|
||||
# register: _installed_version_string
|
||||
# changed_when: false
|
||||
#
|
||||
# - name: set mtail_local_version
|
||||
# set_fact:
|
||||
# mtail_local_version: "{{ _installed_version_string.stdout | regex_search(mtail_version_regex, '\\1') | first }}"
|
||||
# when: mtail_installed
|
||||
#
|
||||
#- name: set mtail_local_version to 0
|
||||
# set_fact:
|
||||
# mtail_local_version: "0"
|
||||
# when: not mtail_installed
|
||||
- name: determine if installed
|
||||
stat:
|
||||
path: "{{ mtail_bin_path }}/mtail"
|
||||
register: st
|
||||
|
||||
- name: set mtail_installed
|
||||
set_fact:
|
||||
mtail_installed: "{{ st.stat.exists | bool }}"
|
||||
|
||||
- block:
|
||||
- name: determine latest version
|
||||
uri:
|
||||
url: https://api.github.com/repos/google/mtail/releases/latest
|
||||
return_content: true
|
||||
body_format: json
|
||||
register: _latest_version
|
||||
until: _latest_version.status == 200
|
||||
retries: 3
|
||||
|
||||
- name: set mtail_version
|
||||
set_fact:
|
||||
mtail_version: "{{ _latest_version.json['tag_name'] | regex_replace('^v', '') }}"
|
||||
|
||||
- block:
|
||||
- name: determine installed version
|
||||
command: "{{ mtail_bin_path }}/mtail --version"
|
||||
register: _installed_version_string
|
||||
changed_when: false
|
||||
|
||||
- name: set mtail_local_version
|
||||
set_fact:
|
||||
mtail_local_version: "{{ _installed_version_string.stdout | regex_search(mtail_version_regex, '\\1') | first }}"
|
||||
when: mtail_installed
|
||||
|
||||
- name: set mtail_local_version to 0
|
||||
set_fact:
|
||||
mtail_local_version: "0"
|
||||
when: not mtail_installed
|
||||
|
||||
- block:
|
||||
- name: get checksums
|
||||
set_fact:
|
||||
_checksums: "{{ lookup('url', mtail_checksum_url, wantlist=True) }}"
|
||||
|
||||
- name: set mtail_checksum
|
||||
set_fact:
|
||||
mtail_checksum: "sha256:{{ item.split(' ') | first }}"
|
||||
loop: "{{ _checksums }}"
|
||||
when: "mtail_release_file in item"
|
16
roles/mtail/templates/mtail.service.j2
Normal file
16
roles/mtail/templates/mtail.service.j2
Normal file
@ -0,0 +1,16 @@
|
||||
[Unit]
|
||||
Description=mtail
|
||||
|
||||
[Service]
|
||||
User={{ mtail_user }}
|
||||
ExecStart={{ mtail_bin_path }}/mtail \
|
||||
--progs {{ mtail_etc_path }} \
|
||||
--log_dir={{ mtail_var_log_path }} \
|
||||
{% if mtail_arg_logs %}
|
||||
{% for path in mtail_arg_logs %}
|
||||
--logs {{ path }} \
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
0
roles/mtail/vars/default.yaml
Normal file
0
roles/mtail/vars/default.yaml
Normal file
Loading…
Reference in New Issue
Block a user