| 2 |
|
|
| 3 |
|
# ----------------------------------------------------------- |
| 4 |
|
# Perl i-scream Host. |
| 5 |
+ |
# http://www.i-scream.org.uk |
| 6 |
|
# |
| 7 |
|
# An all-in-one script to act as an i-scream host on |
| 8 |
|
# a typical Unix/Linux box. You may adapt the data-gathering |
| 72 |
|
|
| 73 |
|
exit(0); |
| 74 |
|
|
| 75 |
+ |
|
| 76 |
+ |
#----------------------------------------------------------------------- |
| 77 |
+ |
# tcp_configure |
| 78 |
+ |
# Establishes a TCP connection to the specified i-scream filter manager. |
| 79 |
+ |
# The host then requests details from the server, such as the intervals |
| 80 |
+ |
# at which to send UDP packets. |
| 81 |
+ |
#----------------------------------------------------------------------- |
| 82 |
|
sub tcp_configure() { |
| 83 |
|
|
| 84 |
|
my($sock) = new IO::Socket::INET( |
| 93 |
|
exit(1); |
| 94 |
|
} |
| 95 |
|
|
| 96 |
< |
# Now run through the configuration process. |
| 96 |
> |
# Now run through the configuration process... |
| 97 |
|
my($response); |
| 98 |
|
|
| 99 |
|
print $sock "STARTCONFIG\n"; |
| 163 |
|
close($sock); |
| 164 |
|
|
| 165 |
|
print "Configuration finished sucessfully!\n"; |
| 166 |
+ |
|
| 167 |
+ |
return; |
| 168 |
|
} |
| 169 |
|
|
| 170 |
+ |
|
| 171 |
+ |
|
| 172 |
+ |
|
| 173 |
+ |
#----------------------------------------------------------------------- |
| 174 |
+ |
# send_udp_packet |
| 175 |
+ |
# Sends a UDP packet to an i-scream filter. |
| 176 |
+ |
# The packet contains XML markup describing some of the machine's state. |
| 177 |
+ |
# Receipt of UDP packets is not guaranteed. |
| 178 |
+ |
#----------------------------------------------------------------------- |
| 179 |
|
sub send_udp_packet() { |
| 180 |
|
|
| 181 |
|
my(@statgrab) = `./statgrab.pl`; |
| 182 |
|
my(%packet); |
| 183 |
< |
for (my($i) = 0; $i < $#statgrab; $i++) { |
| 183 |
> |
for (my($i) = 0; $i <= $#statgrab; $i++) { |
| 184 |
|
$statgrab[$i] =~ /^([^\s]*) (.*)$/; |
| 185 |
|
$packet{$1} = $2; |
| 186 |
|
} |
| 201 |
|
} |
| 202 |
|
$disk_info .= "</disk>"; |
| 203 |
|
|
| 204 |
+ |
print "$disk_info\n"; |
| 205 |
+ |
|
| 206 |
|
my($hostname) = hostname(); |
| 207 |
|
$hostname =~ s/\..*$//g; |
| 208 |
|
`cat /etc/resolv.conf` =~ /domain\s+([^\s]+)/; |
| 212 |
|
|
| 213 |
|
# Build the XML packet this way, as we can clearly |
| 214 |
|
# see the structure and contents... I like this ;-) |
| 215 |
+ |
# [Note that the server rejects UDP packets that are |
| 216 |
+ |
# larger than 8196 bytes] |
| 217 |
|
my($xml) = <<EOF; |
| 218 |
|
|
| 219 |
|
<packet seq_no="$seq_no" machine_name="$machine_name" date="$date" type="data" ip="$ip"> |
| 249 |
|
<swap>$packet{"packet.cpu.swap"}</swap> |
| 250 |
|
</cpu> |
| 251 |
|
<memory> |
| 252 |
< |
<total>$packet{"packet.memory.real"}</total> |
| 252 |
> |
<total>$packet{"packet.memory.total"}</total> |
| 253 |
|
<free>$packet{"packet.memory.free"}</free> |
| 254 |
|
</memory> |
| 255 |
|
<swap> |
| 256 |
< |
<total>$packet{"packet.memory.swap_total"}</total> |
| 257 |
< |
<free>$packet{"packet.memory.swap_free"}</free> |
| 256 |
> |
<total>$packet{"packet.swap.total"}</total> |
| 257 |
> |
<free>$packet{"packet.swap.free"}</free> |
| 258 |
|
</swap> |
| 259 |
|
$disk_info |
| 260 |
|
</packet> |
| 261 |
|
|
| 262 |
|
EOF |
| 263 |
|
|
| 264 |
+ |
# Make the packet smaller by stripping out newlines and leading spaces. |
| 265 |
|
$xml =~ s/\n\s*//g; |
| 266 |
|
|
| 267 |
|
my($sock) = new IO::Socket::INET ( |
| 274 |
|
close($sock); |
| 275 |
|
$seq_no++; |
| 276 |
|
print "-"; |
| 277 |
+ |
|
| 278 |
+ |
return; |
| 279 |
|
} |
| 280 |
|
|
| 281 |
+ |
|
| 282 |
+ |
|
| 283 |
+ |
|
| 284 |
+ |
#----------------------------------------------------------------------- |
| 285 |
+ |
# send_tcp_heartbeat |
| 286 |
+ |
# Establishes a TCP connection to an i-scream filter. |
| 287 |
+ |
# The heartbeat is used as a guaranteed "I'm alive" delivery mechanism. |
| 288 |
+ |
#----------------------------------------------------------------------- |
| 289 |
|
sub send_tcp_heartbeat() { |
| 290 |
|
|
| 291 |
|
my($sock) = new IO::Socket::INET( |
| 353 |
|
|
| 354 |
|
close($sock); |
| 355 |
|
print "^"; |
| 356 |
+ |
|
| 357 |
+ |
return; |
| 358 |
|
} |