From 94dc5455198e0118063604cd4a06bcd38c76c533 Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Mon, 28 Dec 2020 17:23:31 +0100 Subject: [PATCH 1/6] use the official elastic-elastic_stack module to handle the repository. --- manifests/install.pp | 4 +-- manifests/repo.pp | 76 -------------------------------------------- 2 files changed, 2 insertions(+), 78 deletions(-) delete mode 100644 manifests/repo.pp diff --git a/manifests/install.pp b/manifests/install.pp index fd65f4e7..d169234b 100644 --- a/manifests/install.pp +++ b/manifests/install.pp @@ -13,8 +13,8 @@ } Anchor['filebeat::install::begin'] -> Class['filebeat::install::linux'] -> Anchor['filebeat::install::end'] if $::filebeat::manage_repo { - class { '::filebeat::repo': } - Class['filebeat::repo'] -> Class['filebeat::install::linux'] + include elastic_stack::repo + Class['elastic_stack::repo'] -> Class['filebeat::install::linux'] } } 'FreeBSD': { diff --git a/manifests/repo.pp b/manifests/repo.pp deleted file mode 100644 index 1ebd75d5..00000000 --- a/manifests/repo.pp +++ /dev/null @@ -1,76 +0,0 @@ -# filebeat::repo -# -# Manage the repository for Filebeat (Linux only for now) -# -# @summary Manages the yum, apt, and zypp repositories for Filebeat -class filebeat::repo { - $debian_repo_url = "https://artifacts.elastic.co/packages/${filebeat::major_version}.x/apt" - $yum_repo_url = "https://artifacts.elastic.co/packages/${filebeat::major_version}.x/yum" - - case $::osfamily { - 'Debian': { - if $::filebeat::manage_apt == true { - include ::apt - } - - Class['apt::update'] -> Package['filebeat'] - - if !defined(Apt::Source['beats']){ - apt::source { 'beats': - ensure => $::filebeat::alternate_ensure, - location => $debian_repo_url, - release => 'stable', - repos => 'main', - pin => $::filebeat::repo_priority, - key => { - id => '46095ACC8548582C1A2699A9D27D666CD88E42B4', - source => 'https://artifacts.elastic.co/GPG-KEY-elasticsearch', - }, - } - } - } - 'RedHat', 'Linux': { - if !defined(Yumrepo['beats']){ - yumrepo { 'beats': - ensure => $::filebeat::alternate_ensure, - descr => 'elastic beats repo', - baseurl => $yum_repo_url, - gpgcheck => 1, - gpgkey => 'https://artifacts.elastic.co/GPG-KEY-elasticsearch', - priority => $::filebeat::repo_priority, - enabled => 1, - notify => Exec['flush-yum-cache'], - } - } - - exec { 'flush-yum-cache': - command => 'yum clean all', - refreshonly => true, - path => ['/bin', '/usr/bin', '/sbin', '/usr/sbin'], - } - } - 'Suse': { - exec { 'topbeat_suse_import_gpg': - command => 'rpmkeys --import https://artifacts.elastic.co/GPG-KEY-elasticsearch', - unless => 'test $(rpm -qa gpg-pubkey | grep -i "D88E42B4" | wc -l) -eq 1 ', - notify => [ Zypprepo['beats'] ], - } - if !defined(Zypprepo['beats']){ - zypprepo { 'beats': - ensure => $::filebeat::alternate_ensure, - baseurl => $yum_repo_url, - enabled => 1, - autorefresh => 1, - name => 'beats', - gpgcheck => 1, - gpgkey => 'https://packages.elastic.co/GPG-KEY-elasticsearch', - type => 'yum', - } - } - } - default: { - fail($filebeat::osfamily_fail_message) - } - } - -} From 224c9f09268ed910dfa40beb99dd863203c3964d Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Tue, 29 Dec 2020 17:50:22 +0100 Subject: [PATCH 2/6] write multiple named output configs --- manifests/config.pp | 414 ++++++++++++++++++++++++-------------------- manifests/input.pp | 2 +- 2 files changed, 223 insertions(+), 193 deletions(-) diff --git a/manifests/config.pp b/manifests/config.pp index fa0d6714..dfbe580e 100644 --- a/manifests/config.pp +++ b/manifests/config.pp @@ -17,216 +17,246 @@ $setup = $filebeat::setup } - if versioncmp($major_version, '6') >= 0 { - $filebeat_config_temp = delete_undef_values({ - 'shutdown_timeout' => $filebeat::shutdown_timeout, - 'name' => $filebeat::beat_name, - 'tags' => $filebeat::tags, - 'max_procs' => $filebeat::max_procs, - 'fields' => $filebeat::fields, - 'fields_under_root' => $filebeat::fields_under_root, - 'filebeat' => { - 'config.inputs' => { - 'enabled' => true, - 'path' => "${filebeat::config_dir}/*.yml", - }, - 'config.modules' => { - 'enabled' => $filebeat::enable_conf_modules, - 'path' => "${filebeat::modules_dir}/*.yml", - }, - 'shutdown_timeout' => $filebeat::shutdown_timeout, - 'modules' => $filebeat::modules, - }, - 'http' => $filebeat::http, - 'cloud' => $filebeat::cloud, - 'output' => $filebeat::outputs, - 'shipper' => $filebeat::shipper, - 'logging' => $filebeat::logging, - 'runoptions' => $filebeat::run_options, - 'processors' => $filebeat::processors, - 'monitoring' => $filebeat::monitoring, - 'setup' => $setup, - }) - # Add the 'xpack' section if supported (version >= 6.1.0) and not undef - if $filebeat::xpack and versioncmp($filebeat::package_ensure, '6.1.0') >= 0 { - $filebeat_config = deep_merge($filebeat_config_temp, {'xpack' => $filebeat::xpack}) - } - else { - $filebeat_config = $filebeat_config_temp - } - } else { - $filebeat_config_temp = delete_undef_values({ - 'shutdown_timeout' => $filebeat::shutdown_timeout, - 'name' => $filebeat::beat_name, - 'tags' => $filebeat::tags, - 'queue_size' => $filebeat::queue_size, - 'max_procs' => $filebeat::max_procs, - 'fields' => $filebeat::fields, - 'fields_under_root' => $filebeat::fields_under_root, - 'filebeat' => { - 'spool_size' => $filebeat::spool_size, - 'idle_timeout' => $filebeat::idle_timeout, - 'registry_file' => $filebeat::registry_file, - 'publish_async' => $filebeat::publish_async, - 'config_dir' => $filebeat::config_dir, - 'shutdown_timeout' => $filebeat::shutdown_timeout, - }, - 'output' => $filebeat::outputs, - 'shipper' => $filebeat::shipper, - 'logging' => $filebeat::logging, - 'runoptions' => $filebeat::run_options, - 'processors' => $filebeat::processors, - }) - # Add the 'modules' section if supported (version >= 5.2.0) - if versioncmp($filebeat::package_ensure, '5.2.0') >= 0 { - $filebeat_config = deep_merge($filebeat_config_temp, {'modules' => $filebeat::modules}) - } - else { - $filebeat_config = $filebeat_config_temp - } + if $filebeat::outputs.empty == true { + $outputs = { 'none' => undef } } - - if 'filebeat_version' in $facts and $facts['filebeat_version'] != false { - $skip_validation = versioncmp($facts['filebeat_version'], $filebeat::major_version) ? { - -1 => true, - default => false, - } - } else { - $skip_validation = false + else { + $outputs = $filebeat::outputs } - case $::kernel { - 'Linux' : { - $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { - true => undef, - default => $major_version ? { - '5' => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -N -configtest -c %", - default => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -c % test config", - }, + $outputs.each |$output_name, $output_values| { + if 'type' in $output_values { + $output = { $output_values['type'] => delete($output_values, 'type') } + $config_file = regsubst($filebeat::config_file, '.yml', ".${output_name}.yml") + } + else { + if $output_name == 'none' { + $output = $filebeat::outputs } - - file {'filebeat.yml': - ensure => $filebeat::file_ensure, - path => $filebeat::config_file, - content => template($filebeat::conf_template), - owner => $filebeat::config_file_owner, - group => $filebeat::config_file_group, - mode => $filebeat::config_file_mode, - validate_cmd => $validate_cmd, - notify => Service['filebeat'], - require => File['filebeat-config-dir'], + else { + $output = { $output_name => $output_values } } - - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - owner => $filebeat::config_dir_owner, - group => $filebeat::config_dir_group, - mode => $filebeat::config_dir_mode, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, - notify => Service['filebeat'], + if keys($filebeat::outputs).length <= 1 { + $config_file = $filebeat::config_file } - } # end Linux - - 'FreeBSD' : { - $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { - true => undef, - default => '/usr/local/sbin/filebeat ${filebeat::extra_validate_options} -N -configtest -c %', + else { + $config_file = regsubst($filebeat::config_file, '.yml', ".${output_name}.yml") } + } - file {'filebeat.yml': - ensure => $filebeat::file_ensure, - path => $filebeat::config_file, - content => template($filebeat::conf_template), - owner => $filebeat::config_file_owner, - group => $filebeat::config_file_group, - mode => $filebeat::config_file_mode, - validate_cmd => $validate_cmd, - notify => Service['filebeat'], - require => File['filebeat-config-dir'], + if versioncmp($major_version, '6') >= 0 { + $filebeat_config_temp = delete_undef_values({ + 'shutdown_timeout' => $filebeat::shutdown_timeout, + 'name' => $filebeat::beat_name, + 'tags' => $filebeat::tags, + 'max_procs' => $filebeat::max_procs, + 'fields' => $filebeat::fields, + 'fields_under_root' => $filebeat::fields_under_root, + 'filebeat' => { + 'config.inputs' => { + 'enabled' => true, + 'path' => "${filebeat::config_dir}/*.yml", + }, + 'config.modules' => { + 'enabled' => $filebeat::enable_conf_modules, + 'path' => "${filebeat::modules_dir}/*.yml", + }, + 'shutdown_timeout' => $filebeat::shutdown_timeout, + 'modules' => $filebeat::modules, + }, + 'http' => $filebeat::http, + 'cloud' => $filebeat::cloud, + 'output' => $output, + 'shipper' => $filebeat::shipper, + 'logging' => $filebeat::logging, + 'runoptions' => $filebeat::run_options, + 'processors' => $filebeat::processors, + 'monitoring' => $filebeat::monitoring, + 'setup' => $setup, + }) + # Add the 'xpack' section if supported (version >= 6.1.0) and not undef + if $filebeat::xpack and versioncmp($filebeat::package_ensure, '6.1.0') >= 0 { + $filebeat_config = deep_merge($filebeat_config_temp, {'xpack' => $filebeat::xpack}) } - - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - owner => $filebeat::config_dir_owner, - group => $filebeat::config_dir_group, - mode => $filebeat::config_dir_mode, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, - notify => Service['filebeat'], + else { + $filebeat_config = $filebeat_config_temp } - } # end FreeBSD - - 'OpenBSD' : { - $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { - true => undef, - default => $major_version ? { - '5' => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -N -configtest -c %", - default => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -c % test config", + } else { + $filebeat_config_temp = delete_undef_values({ + 'shutdown_timeout' => $filebeat::shutdown_timeout, + 'name' => $filebeat::beat_name, + 'tags' => $filebeat::tags, + 'queue_size' => $filebeat::queue_size, + 'max_procs' => $filebeat::max_procs, + 'fields' => $filebeat::fields, + 'fields_under_root' => $filebeat::fields_under_root, + 'filebeat' => { + 'spool_size' => $filebeat::spool_size, + 'idle_timeout' => $filebeat::idle_timeout, + 'registry_file' => $filebeat::registry_file, + 'publish_async' => $filebeat::publish_async, + 'config_dir' => $filebeat::config_dir, + 'shutdown_timeout' => $filebeat::shutdown_timeout, }, + 'output' => $output, + 'shipper' => $filebeat::shipper, + 'logging' => $filebeat::logging, + 'runoptions' => $filebeat::run_options, + 'processors' => $filebeat::processors, + }) + # Add the 'modules' section if supported (version >= 5.2.0) + if versioncmp($filebeat::package_ensure, '5.2.0') >= 0 { + $filebeat_config = deep_merge($filebeat_config_temp, {'modules' => $filebeat::modules}) } - - file {'filebeat.yml': - ensure => $filebeat::file_ensure, - path => $filebeat::config_file, - content => template($filebeat::conf_template), - owner => $filebeat::config_file_owner, - group => $filebeat::config_file_group, - mode => $filebeat::config_file_mode, - validate_cmd => $validate_cmd, - notify => Service['filebeat'], - require => File['filebeat-config-dir'], + else { + $filebeat_config = $filebeat_config_temp } + } - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - owner => $filebeat::config_dir_owner, - group => $filebeat::config_dir_group, - mode => $filebeat::config_dir_mode, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, - notify => Service['filebeat'], + if 'filebeat_version' in $facts and $facts['filebeat_version'] != false { + $skip_validation = versioncmp($facts['filebeat_version'], $filebeat::major_version) ? { + -1 => true, + default => false, } - } # end OpenBSD - - 'Windows' : { - $cmd_install_dir = regsubst($filebeat::install_dir, '/', '\\', 'G') - $filebeat_path = join([$cmd_install_dir, 'Filebeat', 'filebeat.exe'], '\\') - - $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { - true => undef, - default => $major_version ? { - '7' => "\"${filebeat_path}\" ${filebeat::extra_validate_options} test config -c \"%\"", - default => "\"${filebeat_path}\" ${filebeat::extra_validate_options} -N -configtest -c \"%\"", + } else { + $skip_validation = false + } + + case $::kernel { + 'Linux' : { + $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { + true => undef, + default => $major_version ? { + '5' => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -N -configtest -c %", + default => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -c % test config", + }, + } + + file {"$config_file": + ensure => $filebeat::file_ensure, + path => $config_file, + content => template($filebeat::conf_template), + owner => $filebeat::config_file_owner, + group => $filebeat::config_file_group, + mode => $filebeat::config_file_mode, + validate_cmd => $validate_cmd, + notify => Service['filebeat'], + require => File['filebeat-config-dir'], } - } - - file {'filebeat.yml': - ensure => $filebeat::file_ensure, - path => $filebeat::config_file, - content => template($filebeat::conf_template), - validate_cmd => $validate_cmd, - notify => Service['filebeat'], - require => File['filebeat-config-dir'], - } - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, + if !defined(File['filebeat-config-dir']) { + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + owner => $filebeat::config_dir_owner, + group => $filebeat::config_dir_group, + mode => $filebeat::config_dir_mode, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + notify => Service['filebeat'], + } + } + } # end Linux + + 'FreeBSD' : { + $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { + true => undef, + default => '/usr/local/sbin/filebeat ${filebeat::extra_validate_options} -N -configtest -c %', + } + + file {'filebeat.yml': + ensure => $filebeat::file_ensure, + path => $filebeat::config_file, + content => template($filebeat::conf_template), + owner => $filebeat::config_file_owner, + group => $filebeat::config_file_group, + mode => $filebeat::config_file_mode, + validate_cmd => $validate_cmd, + notify => Service['filebeat'], + require => File['filebeat-config-dir'], + } + + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + owner => $filebeat::config_dir_owner, + group => $filebeat::config_dir_group, + mode => $filebeat::config_dir_mode, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + notify => Service['filebeat'], + } + } # end FreeBSD + + 'OpenBSD' : { + $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { + true => undef, + default => $major_version ? { + '5' => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -N -configtest -c %", + default => "${filebeat::filebeat_path} ${filebeat::extra_validate_options} -c % test config", + }, + } + + file {'filebeat.yml': + ensure => $filebeat::file_ensure, + path => $filebeat::config_file, + content => template($filebeat::conf_template), + owner => $filebeat::config_file_owner, + group => $filebeat::config_file_group, + mode => $filebeat::config_file_mode, + validate_cmd => $validate_cmd, + notify => Service['filebeat'], + require => File['filebeat-config-dir'], + } + + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + owner => $filebeat::config_dir_owner, + group => $filebeat::config_dir_group, + mode => $filebeat::config_dir_mode, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + notify => Service['filebeat'], + } + } # end OpenBSD + + 'Windows' : { + $cmd_install_dir = regsubst($filebeat::install_dir, '/', '\\', 'G') + $filebeat_path = join([$cmd_install_dir, 'Filebeat', 'filebeat.exe'], '\\') + + $validate_cmd = ($filebeat::disable_config_test or $skip_validation) ? { + true => undef, + default => $major_version ? { + '7' => "\"${filebeat_path}\" ${filebeat::extra_validate_options} test config -c \"%\"", + default => "\"${filebeat_path}\" ${filebeat::extra_validate_options} -N -configtest -c \"%\"", + } + } + + file {'filebeat.yml': + ensure => $filebeat::file_ensure, + path => $filebeat::config_file, + content => template($filebeat::conf_template), + validate_cmd => $validate_cmd, + notify => Service['filebeat'], + require => File['filebeat-config-dir'], + } + + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + } + } # end Windows + + default : { + fail($filebeat::kernel_fail_message) } - } # end Windows - - default : { - fail($filebeat::kernel_fail_message) } } } diff --git a/manifests/input.pp b/manifests/input.pp index f3484b87..94cc7276 100644 --- a/manifests/input.pp +++ b/manifests/input.pp @@ -85,7 +85,7 @@ content => template("${module_name}/${input_template}"), validate_cmd => $validate_cmd, notify => Service['filebeat'], - require => File['filebeat.yml'], + require => Class['filebeat::config'], } } From 554cef676f08f5c3620a127c8c7f279dcc444f5b Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Wed, 30 Dec 2020 17:29:35 +0100 Subject: [PATCH 3/6] create additional services for the named output configs --- manifests/config.pp | 24 ++++++++++++------- manifests/params.pp | 3 ++- manifests/service.pp | 33 ++++++++++++++++++++++++++ templates/systemd/filebeat.service.erb | 15 ++++++++++++ 4 files changed, 66 insertions(+), 9 deletions(-) create mode 100644 templates/systemd/filebeat.service.erb diff --git a/manifests/config.pp b/manifests/config.pp index dfbe580e..07fef2f3 100644 --- a/manifests/config.pp +++ b/manifests/config.pp @@ -9,7 +9,7 @@ if has_key($filebeat::setup, 'ilm.policy') { file {"${filebeat::config_dir}/ilm_policy.json": content => to_json({'policy' => $filebeat::setup['ilm.policy']}), - notify => Service['filebeat'], + notify => Service["${service_name}"], require => File['filebeat-config-dir'], } $setup = $filebeat::setup - 'ilm.policy' + {'ilm.policy_file' => "${filebeat::config_dir}/ilm_policy.json"} @@ -28,6 +28,8 @@ if 'type' in $output_values { $output = { $output_values['type'] => delete($output_values, 'type') } $config_file = regsubst($filebeat::config_file, '.yml', ".${output_name}.yml") + $service_output = $output_name + $service_name = "${filebeat::module_name}.${output_name}" } else { if $output_name == 'none' { @@ -38,12 +40,18 @@ } if keys($filebeat::outputs).length <= 1 { $config_file = $filebeat::config_file + $service_output = $filebeat::module_name + $service_name = $filebeat::module_name } else { $config_file = regsubst($filebeat::config_file, '.yml', ".${output_name}.yml") + $service_name = $output_name + $service_name = "${filebeat::module_name}.${output_name}" } } + filebeat::service::add { "${service_output}": } + if versioncmp($major_version, '6') >= 0 { $filebeat_config_temp = delete_undef_values({ 'shutdown_timeout' => $filebeat::shutdown_timeout, @@ -140,7 +148,7 @@ group => $filebeat::config_file_group, mode => $filebeat::config_file_mode, validate_cmd => $validate_cmd, - notify => Service['filebeat'], + notify => Service["${service_name}"], require => File['filebeat-config-dir'], } @@ -154,7 +162,7 @@ recurse => $filebeat::purge_conf_dir, purge => $filebeat::purge_conf_dir, force => true, - notify => Service['filebeat'], + notify => Service["${service_name}"], } } } # end Linux @@ -173,7 +181,7 @@ group => $filebeat::config_file_group, mode => $filebeat::config_file_mode, validate_cmd => $validate_cmd, - notify => Service['filebeat'], + notify => Service["${service_name}"], require => File['filebeat-config-dir'], } @@ -186,7 +194,7 @@ recurse => $filebeat::purge_conf_dir, purge => $filebeat::purge_conf_dir, force => true, - notify => Service['filebeat'], + notify => Service["${service_name}"], } } # end FreeBSD @@ -207,7 +215,7 @@ group => $filebeat::config_file_group, mode => $filebeat::config_file_mode, validate_cmd => $validate_cmd, - notify => Service['filebeat'], + notify => Service["${service_name}"], require => File['filebeat-config-dir'], } @@ -220,7 +228,7 @@ recurse => $filebeat::purge_conf_dir, purge => $filebeat::purge_conf_dir, force => true, - notify => Service['filebeat'], + notify => Service["${service_name}"], } } # end OpenBSD @@ -241,7 +249,7 @@ path => $filebeat::config_file, content => template($filebeat::conf_template), validate_cmd => $validate_cmd, - notify => Service['filebeat'], + notify => Service["${service_name}"], require => File['filebeat-config-dir'], } diff --git a/manifests/params.pp b/manifests/params.pp index fbd6957f..ea67edf0 100644 --- a/manifests/params.pp +++ b/manifests/params.pp @@ -19,7 +19,7 @@ $enable_conf_modules = false $fields = {} $fields_under_root = false - $http = {} + $http = { 'enabled' => false } $cloud = {} $outputs = {} $shipper = {} @@ -33,6 +33,7 @@ $xpack = undef $systemd_override_dir = '/etc/systemd/system/filebeat.service.d' $systemd_beat_log_opts_template = "${module_name}/systemd/logging.conf.erb" + $systemd_service_template = "${module_name}/systemd/filebeat.service.erb" # These are irrelevant as long as the template is set based on the major_version parameter # if versioncmp('1.9.1', $::rubyversion) > 0 { diff --git a/manifests/service.pp b/manifests/service.pp index 4bc01b7c..9702553a 100644 --- a/manifests/service.pp +++ b/manifests/service.pp @@ -65,5 +65,38 @@ } } } +} +define filebeat::service::add { + if $::service_provider == 'systemd' { + if $name == $filebeat::module_name { + $service_name = $name + } + else { + $service_name = "${filebeat::module_name}.${name}" + file { "/var/lib/filebeat/${name}": + ensure => directory, + mode => '0750', + owner => $filebeat::config_file_owner, + group => $filebeat::config_file_group, + before => Systemd::Unit_file["${filebeat::module_name}.${name}.service"], + } + file { "/var/log/filebeat/${name}": + ensure => directory, + mode => '0700', + owner => $filebeat::config_file_owner, + group => $filebeat::config_file_group, + before => Systemd::Unit_file["${filebeat::module_name}.${name}.service"], + } + } + systemd::unit_file { "${service_name}.service": + content => template($filebeat::systemd_service_template), + } + ~> service {"${service_name}": + ensure => 'running', + } + } + else { + warning("You\'re trying to add service to systemd for the additional output '${name}', but the system is using '${::service_provider}' instead of systemd.") + } } diff --git a/templates/systemd/filebeat.service.erb b/templates/systemd/filebeat.service.erb new file mode 100644 index 00000000..56f5ca25 --- /dev/null +++ b/templates/systemd/filebeat.service.erb @@ -0,0 +1,15 @@ +[Unit] +Description=Filebeat sends log files to <%= @name %>. +Documentation=https://www.elastic.co/products/beats/filebeat +Wants=network-online.target +After=network-online.target + +[Service] +Environment="BEAT_LOG_OPTS=" +Environment="BEAT_CONFIG_OPTS=-c /etc/filebeat/filebeat.<%= @name %>.yml" +Environment="BEAT_PATH_OPTS=--path.home /usr/share/filebeat --path.config /etc/filebeat --path.data /var/lib/filebeat/<%= @name %> --path.logs /var/log/filebeat/<%= @name %>" +ExecStart=/usr/share/filebeat/bin/filebeat --environment systemd $BEAT_LOG_OPTS $BEAT_CONFIG_OPTS $BEAT_PATH_OPTS +Restart=always + +[Install] +WantedBy=multi-user.target From 83a52398ad467149bbe91fb8f22753f01137886e Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Thu, 31 Dec 2020 11:55:57 +0100 Subject: [PATCH 4/6] create composite service for all named output services --- manifests/params.pp | 1 + manifests/service.pp | 24 +++++++++++++++---- .../systemd/filebeat.composite.service.erb | 13 ++++++++++ templates/systemd/filebeat.service.erb | 2 +- 4 files changed, 34 insertions(+), 6 deletions(-) create mode 100644 templates/systemd/filebeat.composite.service.erb diff --git a/manifests/params.pp b/manifests/params.pp index ea67edf0..769d6095 100644 --- a/manifests/params.pp +++ b/manifests/params.pp @@ -34,6 +34,7 @@ $systemd_override_dir = '/etc/systemd/system/filebeat.service.d' $systemd_beat_log_opts_template = "${module_name}/systemd/logging.conf.erb" $systemd_service_template = "${module_name}/systemd/filebeat.service.erb" + $systemd_composite_service_template = "${module_name}/systemd/filebeat.composite.service.erb" # These are irrelevant as long as the template is set based on the major_version parameter # if versioncmp('1.9.1', $::rubyversion) > 0 { diff --git a/manifests/service.pp b/manifests/service.pp index 9702553a..209fc475 100644 --- a/manifests/service.pp +++ b/manifests/service.pp @@ -4,10 +4,22 @@ # # @summary Manage the filebeat service class filebeat::service { - service { 'filebeat': - ensure => $filebeat::real_service_ensure, - enable => $filebeat::real_service_enable, - provider => $filebeat::service_provider, + if keys($filebeat::outputs).length <= 1 { + service { 'filebeat': + ensure => $filebeat::real_service_ensure, + enable => $filebeat::real_service_enable, + provider => $filebeat::service_provider, + } + } + else { + systemd::unit_file { "filebeat.service": + content => template($filebeat::systemd_composite_service_template), + } + ~> service {'filebeat': + enable => $filebeat::real_service_enable, + ensure => $filebeat::real_service_ensure, + provider => $filebeat::service_provider, + } } $major_version = $filebeat::major_version @@ -92,7 +104,9 @@ content => template($filebeat::systemd_service_template), } ~> service {"${service_name}": - ensure => 'running', + enable => $filebeat::real_service_enable, + ensure => $filebeat::real_service_ensure, + provider => $filebeat::service_provider, } } diff --git a/templates/systemd/filebeat.composite.service.erb b/templates/systemd/filebeat.composite.service.erb new file mode 100644 index 00000000..d6c09b02 --- /dev/null +++ b/templates/systemd/filebeat.composite.service.erb @@ -0,0 +1,13 @@ +[Unit] +Description=Filebeat composite service to start multiple outputs. +Documentation=https://www.elastic.co/products/beats/filebeat +Wants=network-online.target +After=network-online.target + +[Service] +Type=oneshot +ExecStart=/bin/true +RemainAfterExit=yes + +[Install] +WantedBy=multi-user.target diff --git a/templates/systemd/filebeat.service.erb b/templates/systemd/filebeat.service.erb index 56f5ca25..dd600961 100644 --- a/templates/systemd/filebeat.service.erb +++ b/templates/systemd/filebeat.service.erb @@ -12,4 +12,4 @@ ExecStart=/usr/share/filebeat/bin/filebeat --environment systemd $BEAT_LOG_OPTS Restart=always [Install] -WantedBy=multi-user.target +WantedBy=filebeat.service From 057221378fc14f8dc0c987376280dccc506005ca Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Thu, 31 Dec 2020 12:21:06 +0100 Subject: [PATCH 5/6] add dependencies --- metadata.json | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/metadata.json b/metadata.json index f2fa1d87..b5949fde 100644 --- a/metadata.json +++ b/metadata.json @@ -27,6 +27,14 @@ { "name": "puppetlabs/yumrepo_core", "version_requirement": ">= 1.0.0 < 2.0.0" + }, + { + "name": "camptocamp-systemd", + "version_requirement": ">= 2.0.0 < 3.0.0" + }, + { + "name": "elastic-elastic_stack", + "version_requirement": ">= 7.0.0 < 8.0.0" } ], "operatingsystem_support": [ From b17e8264e96d6b5228d54821d93b64dfda73cccb Mon Sep 17 00:00:00 2001 From: mdklapwijk Date: Thu, 31 Dec 2020 12:29:38 +0100 Subject: [PATCH 6/6] also prevent multiple filebeat-config-dir in other os --- manifests/config.pp | 58 +++++++++++++++++++++++++-------------------- 1 file changed, 32 insertions(+), 26 deletions(-) diff --git a/manifests/config.pp b/manifests/config.pp index 07fef2f3..dc937574 100644 --- a/manifests/config.pp +++ b/manifests/config.pp @@ -185,16 +185,18 @@ require => File['filebeat-config-dir'], } - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - owner => $filebeat::config_dir_owner, - group => $filebeat::config_dir_group, - mode => $filebeat::config_dir_mode, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, - notify => Service["${service_name}"], + if !defined(File['filebeat-config-dir']) { + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + owner => $filebeat::config_dir_owner, + group => $filebeat::config_dir_group, + mode => $filebeat::config_dir_mode, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + notify => Service["${service_name}"], + } } } # end FreeBSD @@ -219,16 +221,18 @@ require => File['filebeat-config-dir'], } - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - owner => $filebeat::config_dir_owner, - group => $filebeat::config_dir_group, - mode => $filebeat::config_dir_mode, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, - notify => Service["${service_name}"], + if !defined(File['filebeat-config-dir']) { + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + owner => $filebeat::config_dir_owner, + group => $filebeat::config_dir_group, + mode => $filebeat::config_dir_mode, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + notify => Service["${service_name}"], + } } } # end OpenBSD @@ -253,12 +257,14 @@ require => File['filebeat-config-dir'], } - file {'filebeat-config-dir': - ensure => $filebeat::directory_ensure, - path => $filebeat::config_dir, - recurse => $filebeat::purge_conf_dir, - purge => $filebeat::purge_conf_dir, - force => true, + if !defined(File['filebeat-config-dir']) { + file {'filebeat-config-dir': + ensure => $filebeat::directory_ensure, + path => $filebeat::config_dir, + recurse => $filebeat::purge_conf_dir, + purge => $filebeat::purge_conf_dir, + force => true, + } } } # end Windows