Files

128 lines
4.1 KiB
Markdown
Raw Permalink Normal View History

2015-04-20 01:46:12 +02:00
ansible-rsyslog
=========
This role installs and configures rsyslog.
2015-09-04 00:17:28 +02:00
Supported Platforms
-------------------
2017-03-15 23:53:20 +01:00
* RHEL 5/6/7
* Almalinux
* Rocky Linux
2015-09-04 00:17:28 +02:00
* Archlinux
2017-03-15 23:53:20 +01:00
* Ubuntu Trusty/Xenial
2015-09-04 00:17:28 +02:00
* Debian Wheezy
It will likely run on other platforms, just drop in vars/ a new file to support your os variant, vars are parsed in the following order/format:
* {{ ansible_distribution }}_{{ ansible_distribution_major_version }}.yml
* {{ ansible_distribution }}.yml
* {{ ansible_os_family }}_{{ ansible_distribution_major_version }}.yml
* {{ ansible_os_family }}.yml"
2015-04-20 01:46:12 +02:00
Requirements
------------
None at this time.
Default Role Variables
--------------
2015-09-04 00:17:28 +02:00
By default this role will install rsyslog and provide a minimal configuration, however variables can be passed to this role
and configuration can be overridden, for additional informations please have a look to **defaults/main.yml**
2015-04-20 02:00:01 +02:00
2017-03-15 23:51:08 +01:00
**rsyslog_default_config**: Setup a default basic configuration stanza (default: "True")
**purge_config**: Purge existing config snippets (default: "False")
**rsyslog_use_repo**: Use Adiscon rsyslog official package repository (default: "False")
**rsyslog_repo_releasever**: Default rsyslog major release repository version to use (default: 8)
2017-03-15 23:51:08 +01:00
**rsyslog_action_file_template**: Define a custom template for file logging (default: RSYSLOG_TraditionalFileFormat)
**rsyslog_priv_drop_to_user**: Drop root privileges and switch to given user (default: root)
**rsyslog_priv_drop_to_group**: Drop root privileges and switch to given group (default: root)
**rsyslog_server_udp**: Enable a simple UDP server receiver (default: False)
**rsyslog_server_udp_name**: Assign a name to the given receiver (default: "imudp")
**rsyslog_server_udp_port**: Specifies the port the server shall listen to (default: "514")
**rsyslog_server_udp_address**: Local ip address the udp server should listen (default: "0.0.0.0")
**rsyslog_server_udp_ratelimit**: The rate-limiting interval in seconds (default: "5")
**rsyslog_server_tcp**: Enable a simple TCP server receiver (default: False)
**rsyslog_server_tcp_name**: Assign a name to the given receiver (default: "imtcp")
**rsyslog_server_tcp_port**: Specifies the port the server shall listen to (default: "514")
**rsyslog_server_tcp_address**: Local ip address the tcp server should listen **POSSIBLY BROKEN** (default: "0.0.0.0")
**rsyslog_server_tcp_ratelimit**: The rate-limiting interval in seconds (default: "5")
2015-04-20 02:00:01 +02:00
Additional Role Variables:
--------------
2017-03-15 23:51:08 +01:00
**rsyslog_custom_config**: Use a custom template to use as main configuration file (eg: rsyslog_custom_config: /path/to/rsyslog_custom.j2)
2015-04-20 01:46:12 +02:00
Dependencies
------------
None at this time.
Example Playbook
----------------
2015-09-04 00:17:28 +02:00
1) Just install rsyslog with default configuration (it will be placed in /etc/rsyslog.d/)
```yaml
- hosts: all
remote_user: root
sudo: no
- roles:
2015-09-04 20:09:36 +02:00
- { role: rsyslog }
2015-09-04 00:17:28 +02:00
```
2) Install rsyslog, without default configuration and setup two different custom stanzas
```yaml
- hosts: all
remote_user: root
2015-09-04 20:09:36 +02:00
vars:
2015-09-04 00:17:28 +02:00
rsyslog_default_config: False
2015-09-04 20:09:36 +02:00
roles:
2015-09-04 00:17:28 +02:00
- role: rsyslog
items:
2015-09-04 20:09:36 +02:00
- name: "20-iptables"
lines:
- ':msg, contains, "iptables" /var/log/iptables.log'
- '& ~'
- name: "30-dovecot"
lines:
- 'if $programname == "dovecot" and $syslogseverity <= "6" then ~'
- '& ~'
2015-09-04 00:17:28 +02:00
```
3) Install rsyslog, specify a custom configuration template
```yaml
- hosts: all
remote_user: root
vars:
rsyslog_default_config: False
rsyslog_custom_config: /home/servers/foo.bar/templates/rsyslog_custom.j2
roles:
- role: rsyslog
```
4) Install rsyslog using official repository packages, use major release 7
```
- hosts: all
remote_user: root
roles:
- { role: rsyslog, "rsyslog_use_repo": True, "rsyslog_repo_releasever": 7 }
```
5) Enable a simple rsyslog UDP server (receiver) for remote logging
2016-09-28 16:03:36 +02:00
```yaml
2016-09-28 16:00:48 +02:00
- hosts: all
vars:
2016-09-28 16:00:48 +02:00
roles:
- role: rsyslog
rsyslog_server_udp_port: 514
rsyslog_server_udp_address: 192.168.200.201
2016-09-28 16:00:48 +02:00
```
2015-04-20 01:46:12 +02:00
License
-------
GPLv2
Author Information
------------------
Alessio Cassibba (x-drum) http://blog.zerodev.it.