Puppet Class: datadog_agent::integrations::kafka
- Inherits:
- datadog_agent::params
- Defined in:
- manifests/integrations/kafka.pp
Overview
Class: datadog_agent::integrations::kafka
This class will install the necessary configuration for the kafka integration
Parameters:
$host:
The host kafka is running on. Defaults to 'localhost'
$username
Optionally specify username for connection
$password
Optionally specify password for connection
$port
The port kafka is running on. Defaults to 9999
$name
Name given to kafka instance
$process_name_regex
Instead of specifying a host, and port. The agent can connect using the attach api.
$tools_jar_path
Path to tools jar needs to be set when process_name_regex is set
$java_bin_path
Path to java binary, should be set if agent cant find your java executable
$trust_store_path
Path to the trust store, should be set if ssl is enabled
$trust_store_password
Password to the trust store
$tags
Optional array of tags
Sample Usage:
class { 'datadog_agent::integrations::kafka' :
servers => [
{
'host' => 'localhost',
'username' => 'kafka_username',
'password' => 'kafka_password',
'port' => '9999',
'name' => 'kafka_instance',
'process_name_regex' => '.*process_name.*',
'tools_jar_path' => '/usr/lib/jvm/java-7-openjdk-amd64/lib/tools.jar',
'java_bin_path' => '/path/to/java',
'trust_store_path' => '/path/to/trustStore.jks',
'trust_store_password' => 'password',
'tags' => ['env: test', 'sometag: someinfo'],
},
{
'host' => 'localhost',
'port' => '9999',
'tags' => [],
},
]
}
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 |
# File 'manifests/integrations/kafka.pp', line 55
class datadog_agent::integrations::kafka(
$host = 'localhost',
Variant[String[1], Integer] $port = 9999,
Optional[String[1]] $username = undef,
Optional[String[1]] $password = undef,
Optional[String[1]] $process_name_regex = undef,
Optional[String[1]] $tools_jar_path = undef,
Optional[String[1]] $java_bin_path = undef,
Optional[String[1]] $trust_store_path = undef,
Optional[String[1]] $trust_store_password = undef,
Optional[Hash[String[1], String[1]]] $tags = undef,
Optional[Array[Hash[String[1], Data]]] $instances = undef,
) inherits datadog_agent::params {
require ::datadog_agent
if !$instances and $host and $port {
$servers = [{
'host' => $host,
'port' => $port,
'username' => $username,
'password' => $password,
'process_name_regex' => $process_name_regex,
'tools_jar_path' => $tools_jar_path,
'java_bin_path' => $java_bin_path,
'trust_store_path' => $trust_store_path,
'trust_store_password' => $trust_store_password,
'tags' => $tags,
}]
} elsif !$instances{
$servers = []
} else {
$servers = $instances
}
$legacy_dst = "${datadog_agent::params::legacy_conf_dir}/kafka.yaml"
if $::datadog_agent::_agent_major_version > 5 {
$dst_dir = "${datadog_agent::params::conf_dir}/kafka.d"
file { $legacy_dst:
ensure => 'absent'
}
file { $dst_dir:
ensure => directory,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => $datadog_agent::params::permissions_directory,
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
$dst = "${dst_dir}/conf.yaml"
} else {
$dst = $legacy_dst
}
file { $dst:
ensure => file,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => $datadog_agent::params::permissions_protected_file,
content => template('datadog_agent/agent-conf.d/kafka.yaml.erb'),
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name],
}
}
|