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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
|
=head1 NAME
smokeping_install - How to install SmokePing
=head1 OVERVIEW
This document explains how to setup SmokePing at your site.
=head1 DESCRIPTION
=head2 Prerequisites
SmokePing does not stand alone. It relies on various other tools and
services being present. Apart from a Unix OS and a working Perl installation
you need the following components:
=over
=item RRDtool 1.2.x or later
Smokeping uses RRDtool for logging and graphing. If your linux distro provides
an rrdtool package with perl support, use this. If you want to get the latest
and greatest version, compile your own: L<http://oss.oetiker.ch/rrdtool/>
=item FPing (optional)
The official site L<http://fping.sourceforge.net/> seems to be a bit
unmaintained. You might want to grab an updated version of fping from
L<http://oss.oetiker.ch/smokeping/pub/>.
Note that fping must be installed setuid root. It seems that older versions
of fping report round trip times in 0.1 milliseconds instead of 1 milliseconds
as advertised ... SmokePing tries to figure this out. It tells
you when it starts ... let me know if it gets it wrong.
=item EchoPing (Optional)
L<http://echoping.sourceforge.net/>
You need this to run the EchoPing probes
=item Curl (Optional)
L<http://curl.haxx.se/>
You need this for the Curl probe.
=item dig (Optional)
L<http://www.isc.org/sw/bind/>
You need this for the DNS probe.
=item SSH (Optional)
L<http://www.openssh.org/>
You need this for the SSH probe.
=item Webserver
L<http://httpd.apache.org/>
Well I won't get much into this. The important thing is, to have a webserver
which allows you to run CGI and preferably FastCGI scripts. If you are using
Apache I strongly recommend using the F<suexec> system for running CGI
scripts as a particular user.
See L<http://httpd.apache.org/mod_fcgid/mod/mod_fcgid.html> and
L<http://httpd.apache.org/docs/2.2/mod/mod_suexec.html> for more information
on this.
=item Perl 5.8.8 or later.
If you still have an older version, maybe have a look at perlbrew.
=item Various Perl modules (Many are optional)
The modules are all available from L<http://www.cpan.org> and you may be
able to get them as packages from your distro's repository. There is also a
script provided in the setup folder to install the missing bits. You will
be instructed later on how to use the script.
=over
=item FCGI
The module for supporting FastCGI operation.
=item CGI, CGI::Fast
Perl CGI/FastCGI support. Might already be installed localy.
=item Config::Grammar
The configuration file parser used in smokeping
=item LWP
The master/slave functionality introduced a dependency on LWP::UserAgent
from the libwww-perl (also known as LWP) library. The module is required
even if the master/slave mode is not enabled.
=item Socket6 (optional)
The Socket6 module enables smokeping to check hostnames that only resolve to
an IPv6 address. If you probe such hosts using ie. the FPing6 probe and get
warnings that those hosts don't resolve to an IP address, you need to
install it.
=item Net::Telnet (optional)
You need this for the TelnetIOSPing probe.
=item Net::OpenSSH (optional)
You need this for the OpenSSHJunOSPing probe.
=item Net::DNS (optional)
You need this for the AnotherDNS probe.
=item Net::LDAP (optional)
You need this for the LDAP probe.
=item IO::Socket::SSL (optional)
You need this if you want the LDAP probe to be able to use the 'starttls' command.
=item Authen::Radius (optional)
You need this for the Radius probe.
=back
=back
=head2 Installation
Once the tools listed above are in place, you can start setting up SmokePing
itself. Unpack the tar archive and run the included configure script:
./configure --prefix=/opt/smokeping
Configure will verify that all the required perl modules are available.
If some are missing it will tell you to run the module build script.
Just follow the instructions on screen and then run configure again.
Once it completes, you can run
make install
to finish your setup.
=head2 Configuration
Use the F<etc/config.dist> file as a template to create your own smokeping configuration file.
See L<smokeping_config> for details.
=over
=item Installing the webinterface
Copy the content of the F<PREFIX/htdocs> directory to the place where your webserver
expects its data. Maybe to F</var/www/smokeping>.
Edit the F<smokeping.fcgi> script to point to your smokeping_cgi script.
If you have no FastCGI support in your webserver, you may want to use the
F<smokeping.cgi> script.
=item F<etc/basepage.html>
Edit the html template to your likings. Please do not remove the link to the
SmokePing counter and my name from the template. The content of the
template will be renderd by smokeping.cgi. This means that all embedded
links must be relative to smokeping.cgi.
If you are using HTTP authentication, then the template variable C<authuser> will be populated
from the C<$ENV{REMOTE_USER}> environment variable.
=item F<etc/smokemail>
If you are going to use the B<DYNAMIC> IP support, customize the contents of this file.
=back
=head2 Starting the Smokeping Daemon
With all the scaffolding in place, you can now launch the smokeping daemon and
have it gather data for you. First you may want to run it in debug mode to see what
it is doing
./bin/smokeping --config=/opt/smokeping/etc/config --debug
once all is well, start it up as a daemon. I would recomend you enable the
logfile option so that you can see if it runs into trouble.
./bin/smokeping --config=/opt/smokeping/etc/config --logfile=smoke.log
Once the system works, you may want to put a SmokePing startup script into
your F</etc/init.d> tree. Check out L<smokeping> for further information.
You can now open the smokeping.cgi webpage to look at your data.
See the L<smokeping_cgi> documentation on how to setup the smokeping web interface.
=head1 COPYRIGHT
Copyright (c) 2001, 2011 by Tobias Oetiker. All right reserved.
=head1 LICENSE
This program is free software; you can redistribute it
and/or modify it under the terms of the GNU General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later
version.
This program is distributed in the hope that it will be
useful, but WITHOUT ANY WARRANTY; without even the implied
warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the GNU General Public License for more
details.
You should have received a copy of the GNU General Public
License along with this program; if not, write to the Free
Software Foundation, Inc., 675 Mass Ave, Cambridge, MA
02139, USA.
=head1 AUTHOR
Tobias Oetiker E<lt>tobi@oetiker.chE<gt>
=cut
|