forked from DataDog/puppet-datadog-agent
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker_daemon.pp
More file actions
112 lines (105 loc) · 3.39 KB
/
docker_daemon.pp
File metadata and controls
112 lines (105 loc) · 3.39 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
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
# Class: datadog_agent::integrations::docker_daemon
#
# This class will install the necessary configuration for the docker integration
#
# Parameters:
# $url:
# The URL for docker API
#
# $tags:
# optional array of tags
#
# $group:
# optional name of docker group to add dd-agent user too
#
#
# Sample Usage:
#
# class { 'datadog_agent::integrations::docker_daemon' :
# url => 'unix://var/run/docker.sock',
# }
#
class datadog_agent::integrations::docker_daemon(
$group = 'docker',
$docker_root = '/',
$timeout = 10,
$api_version = 'auto',
$tls = false,
$tls_client_cert = '/path/to/client-cert.pem',
$tls_client_key = '/path/to/client-key.pem',
$tls_cacert = '/path/to/ca.pem',
$tls_verify = true,
$init_retry_interval = 0,
$init_retries = 0,
$url = 'unix://var/run/docker.sock',
$collect_events = true,
$filtered_event_types = [],
$collect_container_size = false,
$custom_cgroups = false,
$health_service_check_whitelist = [],
$collect_container_count = false,
$collect_volume_count = false,
$collect_images_stats = false,
$collect_image_size = false,
$collect_disk_stats = false,
$collect_exit_codes = false,
$exclude = [],
$include = [],
$tags = [],
$ecs_tags = true,
# Possible values: "container_name", "image_name", "image_tag", "docker_image"
$performance_tags = [],
# Possible values: "image_name", "image_tag", "docker_image"
$container_tags = [],
# Ex. "com.docker.compose.service", "com.docker.compose.project"
$collect_labels_as_tags = [],
$event_attributes_as_tags = [],
) inherits datadog_agent::params {
include datadog_agent
exec { 'dd-agent-should-be-in-docker-group':
command => "/usr/sbin/usermod -aG ${group} ${datadog_agent::params::dd_user}",
unless => "/bin/cat /etc/group | grep '^${group}:' | grep -qw ${datadog_agent::params::dd_user}",
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
if !$::datadog_agent::agent5_enable {
$legacy_dir = "${datadog_agent::conf6_dir}/docker_daemon.d"
file { $legacy_dir:
ensure => directory,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => '0755',
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
$legacy_conf = "${legacy_dir}/conf.yaml"
} else {
$legacy_conf = "${datadog_agent::conf_dir}/docker.yaml"
}
file { $legacy_conf:
ensure => 'absent'
}
if !$::datadog_agent::agent5_enable {
$dst_dir = "${datadog_agent::conf6_dir}/docker.d"
file { $dst_dir:
ensure => directory,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => '0755',
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
$dst = "${dst_dir}/conf.yaml"
} else {
$dst = "${datadog_agent::conf_dir}/docker_daemon.yaml"
}
file { $dst:
ensure => file,
owner => $datadog_agent::params::dd_user,
group => $datadog_agent::params::dd_group,
mode => '0644',
content => template('datadog_agent/agent-conf.d/docker_daemon.yaml.erb'),
require => Package[$datadog_agent::params::package_name],
notify => Service[$datadog_agent::params::service_name]
}
}