-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathwrite-metrics.pl
executable file
·111 lines (102 loc) · 3.4 KB
/
write-metrics.pl
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
#!/usr/bin/perl
use Getopt::Long;
use POSIX qw(strftime);
use IO::Socket::INET;
$output = 'influx';
$influx_url = 'http://localhost:8086';
$influx_db = 'metrics';
$influx_user = 'sensu';
$influx_password = 'sensu';
$sensu_host = 'localhost';
$sensu_port = 3030;
$measurement = 'test.foo';
$tag = 'zot';
$series = 10;
$batch = 50;
$total = 10000;
$base = 0;
$scale = 1;
$generator = 'sine';
$start_time = time - 60*60;
$end_time = time;
GetOptions("output=s", \$output,
"influx_url=s", \$influx_url,
"influx_db=s", \$influx_db,
"influx_user=s", \$influx_user,
"influx_password=s", \$influx_password,
"sensu_host=s", \$sensu_host,
"sensu_port=i", \$sensu_port,
"measurement=s", \$measurement,
"tag=s", \$tag,
"series=i", \$series,
"batch=i", \$batch,
"total=i", \$total,
"base=f", \$base,
"scale=i", \$scale,
"generator=s", \$generator,
"start_time=i", \$start_time,
"end_time=i", \$end_time
);
if($output eq 'influx') {
if(eval {require LWP::UserAgent;1;} != 1) {
die "libwww-perl required to use influx output\n";
}
LWP::UserAgent->import();
$ua = LWP::UserAgent->new;
}
$data = [];
for($i=0; $i<$total; $i++) {
$t = $start_time + $i * ($end_time - $start_time) / $total;
if($generator eq 'sine') {
push(@$data, sprintf("%s,%s=%d value=%f %d", $measurement, $tag, $i % $series, $scale*($base+sin(2*3.14*($i%$series)/$series + $i*2*3.14/$total)), ($t*1000*1000*1000)+($i%1000)));
} elsif($generator eq 'random') {
push(@$data, sprintf("%s,%s=%d value=%f %d", $measurement, $tag, $i % $series, $scale*($base+rand), ($t*1000*1000*1000)+($i%1000)));
} else {
push(@$data, sprintf("%s,%s=%d value=%f %d", $measurement, $tag, $i % $series, $scale*$base, ($t*1000*1000*1000)+($i%1000)));
}
if($i && !($i % $batch)) {
write_data($data);
$data = [];
}
}
write_data($data) if(@$data > 0);
printf("Wrote %d entries in %d series from %s to %s\n", $total, $series, strftime("%Y-%m-%d %H:%M:%S", localtime($start_time)), strftime("%Y-%m-%d %H:%M:%S", localtime($end_time)));
sub write_data {
my($data) = @_;
if($output eq 'influx') {
write_influx($data);
} elsif($output eq 'sensu') {
write_sensu($data);
} else {
die("Unknown output: $output\n");
}
}
sub write_influx {
my($data) = @_;
my($req) = HTTP::Request->new(POST => "$influx_url/write?db=$influx_db&u=$influx_user&p=$influx_password");
$req->content(join("\n", @$data));
my($res) = $ua->request($req);
warn(sprintf("write error: %s\n", $res->code)) if(!$res->is_success);
}
sub write_sensu {
my($data) = @_;
my $socket = new IO::Socket::INET(
PeerHost => $sensu_host,
PeerPort => $sensu_port,
Proto => 'tcp',
);
if($socket) {
my $msg = sprintf('{"name":"%s","type":"metric","handlers":["events_nano"],"output":"%s"}',$measurement, join("\\n", @$data));
my $l = $socket->send($msg);
if($l == length($msg)) {
my $res = '';
$socket->recv($res, 1024);
warn(sprintf("write error: %s\n", $res)) if($res ne 'ok');
} else {
warn("Socket write error.\n");
}
$socket->close();
} else {
warn "Couldn't connect to sensu socket.\n" unless($socket);
}
}