-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathINSTALL
378 lines (263 loc) · 13.1 KB
/
INSTALL
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
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
/*
* Argus-5.0 Software. Argus flow data generation
* Copyright (c) 2000-2024 QoSient, LLC
* All rights reserved.
*
* This program is free software, released under the GNU General
* Public License; 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 3, or any later version.
*
* Other licenses are available through QoSient, LLC.
* Inquire at info@qosient.com.
*
* This program is distributed 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.
*
* Date: Thu Jan 11 15:35:49 EST 2024
*/
QUICK MAKE
If all things are ready, distribution untarred, and you have libpcap
and bison installed on your system, you should be able to make
argus by simply typing:
% ./configure
% make
If you have any problems with this procedure, read further, if not
congratulations. You can proceed to INSTALLATION.
DEPENDENCIES
The argus distribution is dependant on two public domain packages; libpcap,
which provides the argus server's portable packet capture interface, and flex/bison()
which are used for to build the filter compilers. Both of these sets of
packages must be installed in order to compile argus. Most versions of
Linux/Unix/Mac OS X/xBSD have these packages installed by default, so
hopefully it won't be a problem.
Below is the offical source of libpcap and current version:
libpcap-1.10.4
http://www.tcpdump.org/release/libpcap-1.10.4.tar.gz
The official site and current version of bison is:
bison-3.8
http://ftp.gnu.org/gun/bison/
And the offical site for Flex: The Fast Lexical Analyzer is:
flex-2.6.4
https://github.com/westes/flex
Because argus is dependant on libpcap and flex/bison, you will need to
have them available prior to building the package. Please refer to the
individual packages for installation instructions. If you are not
interested in performing a system installtion for libpcap, then you
can simply untar libpcap in the same directory where you untared argus.
Argus's ./configure will find the package and use it accordingly.
For some operating systems, such as Fedora, you may have to install the
developement versions of some packages in order to get all the supporting
files. On Fedora, the libpcap library is provided, however, compilers
etc... can't find the library at compile time. Installing libpcap-devel
fixes this problem:
yum install libpcap-devel
apt-get install libpcap-devel
In order to support some specific DSR metrics, argus needs the XDR library,
which is now provided in the libtirpc-devel package on Linux. Without the
XDR functions, argus will not be able to generate the ARGUS_JITTER_DSR
metrics, but argus will build without the library.
Getting this library can be different for most any platform. For
Centos Stream 9, as an example, libtirpc is available in the Base OS
repository, but the needed libtirpc-devel package in is the CRB
repository. You will need to configure 'dnf' to add CRB to the
repo lists.
dnf config-manager --set-enabled crb
For all Linux platforms, you will use either yum, apt-get, or dnf ...
dnf install libtirpc-devel
Argus supports block compression for some of its functions. To support
this, argus will look for a usable zlib. If not found, it will not
use the functions.
Argus can link to the public domain package tcp_wrappers to
provide remote access control. At this time, the lastest version
is tcp_wrappers-7.6. If tcp_wrappers in not installed on your
system, then installing this package in the same directory as
libpcap and argus is recommended.
tcp_wrappers.7.6
Wietse Venema (wietse@wzv.win.tue.nl)
Department of Mathematics and Computing Science
Eindhoven University of Technology
P.O. Box 513
5600 MB Eindhoven
The Netherlands
ftp://ftp.porcupine.org/pub/security
Argus can also link to the cryptographic package SASL, the Simple
Authentication and Security Layer, which provides strong authentication
and wireline confidentiality for argus data. Because of its features
and flexibility, we highly recommend using SASL, and becoming experienced
with its administration.
cyrus-sasl-2.1.23
Carnegie Mellon Univeristy
http://ftp.andrew.cmu.edu/pub/cyrus-mail/
CONFIGURE
The program, ./configure, will scan the file system, looking for a lot
of things, including the libpcap and tcp_wrapper directories and libraries and
make assumptions about the platform which will allow ./configure to choose
between gcc, acc, cc, flex, lex, bison, yacc, pcre, sasl and where your specific
version of Perl.
If the libpcap or bison packages are not discovered, the ./configure
script will fail, as these packages are required.
Argus can be compiled with support for Sasl, to provide strong
authentication and confidentiality protection for data "on the wire".
This can be turned on using the option "--with-sasl[=DIR]". If you do
not provide the optional directory, ./configure will guess where
sasl could be, using the standard installation directories as
a guide.
You can also specify that ./configure should not use gcc as the
compiler, which the default. For Solaris, the sun c compiler is
much better for various reasons, and so providing the "--without-gcc"
option may generate more efficient code, when a native compiler
is available.
Configure will create links for the libpcap.a and libwrap.a libraries
in ./lib, and will create links to the distribution directories as
./libpcap and ./wrapper. Configure will attempt to find the libpcap
and tcp_wrappers distribution directories, and their corresponding
libraries. The path used to find these dependancies is ./libpcap,
./wrapper, /usr/lib, /usr/local/lib, ../libpcap, ../wrapper,
../tcp_wrappers, ../libpcap-[0-9]*.[0-9ab]*, and
../tcp_wrappers[-.][0-9]*.[0-9ab]*.
Because of major changes between tcp_wrappers-6 and tcp_wrappers-7,
./configure needs to discover the tcp_wrappers version number. It
does this by scanning the patchlevel.h file in the tcp_wrapper
distribution, as a result, ./configure will attempt to find and then
establish a link to your tcp_wrappers distribution directory.
Again, we recommend that you install your libpcap and tcp_wrappers
distribution directories, or links to them, in either the same
directory as the Argus distribution, or as the directories
./libpcap and ./wrapper, in the Argus directory.
BUILDING ARGUS
So, after all that, to build Argus on a supported platform, first run
./configure. ./configure will determine your system attributes and
generate subdirectories and the appropriate Makefiles from the Makefile.in
files found in the distribution. After this, run "make". If everything
goes well, appropriate libraries and binaries will be found in the ./bin
and ./lib subdirectories. So, ....
% ./configure
% make
The argus will be found as ./bin/argus.
So, at this point you should have all the execuables needed. But,
if you are having problems, it may be related to your compiler or
the flex and bison utilities. So, ...
You will need an ANSI C compiler to build argus. If your compiler
is not ANSI compliant, we highly recommend using the GNU C compiler,
available via anonymous ftp:
ftp://prep.ai.mit.edu/pub/gnu/gcc-*.tar.gz
Argus requires bison and flex. For flex, version 2.4.6 or higher
is recommended. The current version of flex and bison are available
via anonymous ftp:
ftp://prep.ai.mit.edu/pub/gnu/bison-*.tar.gz
ftp://prep.ai.mit.edu/pub/non-gnu/flex/flex-*.tar.gz
Now, if you are still having problems, ..., well its hard to say
from here what it might be. So, you may want to send us some
mail.
INSTALLATION
QUICK INSTALL
If all things are well at this point, and you will be using
the installation strategy that we use, all you need do now
is:
# make install
This will create the /usr/local/argus directory and move all
the binaries, supporting programs, man pages and
documenation into it.
If you are unsure about the standard installtion, run
% make -n install
to review what make will try to do. If you would like to
do something other than the standard install, then please
continue to read through this file.
If you are planning on running the argus as a persistant
daemon on your machine, then one additional step is recommended,
and that is setting up system wide argus configuration files;
/etc/argus.conf.conf.
# cp ./support/Config/argus.conf /etc
You must edit /etc/argus.conf file for argus to work, as
the default configuration will have argus do a lot of work
but not output anything.
Argus writes its data either to an output file, or if you intend
argus to monitor traffic in realtime, to a socket port that client
programs can attach to. You specify either, or both, in the
argus.conf file, by uncommenting the appropriate line.
At this point your ready to run the argus.
But if you wanted to do something different, then read on.
Argus does not have any installation retrictions, so you can
install Argus anywhere. There are some conventions that have
been established, and I'll present them here, but you can, of
course, do your own thing.
I have found it useful to have an argus home directory to hold
the binaries, argus configuration files, the argus output file,
and hold my argus data archive. If you would like to use this
strategy, create your directory, and create the environment
variable ARGUSHOME and set it to this directory.
I use /usr/local/argus. I prefer putting the argus binary in
/usr/local/sbin (system binaries).
After making, as root, I just:
# mkdir /usr/local/argus
# cp bin/argusbug /usr/local/argus/bin
# cp bin/argus /usr/local/sbin/argus
It is convenient to chmod argus so that it is "setuid root",
but many feel that this is a security problem, as any user
could then start an argus on the system. Use this technique at
at your discretion.
# chown root /usr/local/sbin/argus
# chmod 4755 /usr/local/sbin/argus
Argus has a system configuration file that normally resides
as /etc/argus.conf. You can install this file anywhere, but
the scripts that are provided in the ./support directory
will assume that the configuration is at /etc/argus.conf.
# cp ./support/Config/argus.conf /etc/argus.conf
You will want to edit this file to choose values of your
liking. The sample has all the common values set and is
a good suggestion.
Copying the man and doc directories is nice.
# tar cf - doc man | (cd /usr/local/argus; tar xvpf -)
This should handle the basic installion.
Any comments, patches, bug reports or additions should be sent to
argus@lists.andrew.cmu.edu.
PORTABILITY
Argus and its supporting routines have been developed on Sparc
architectures under SunOS 4.1.x and Solaris 2.7, and have been successfully
ported to Solaris, SGI, Ultrix, Linux, OpenBSD and FreeBSD platforms.
No claim is made as to the portability of Argus to other platforms, although
it is much easier now that we've addressed the big endian little endian
issues. If you make any modifications to support installing and running
Argus in any other environment, please send us comments and/or patches.
We will be most grateful.
OPENWRT
Argus has been ported to OpenWrt, and a specific configure program is
provided to assist in making for OpenWrt.
First, untar the argus distribution into your OpenWrt-SDK-Linux-i686-1/package
directory. Be sure that the libpcap library is installed in the
OpenWrt-SDK-Linux-i686-1/staging_dir_mipsel/usr/lib, and your ready.
% ./configure.openwrt
% make
That should make an argus binary that can be installed on an openwrt system.
You will still need to provide an /etc/argus.conf file, and any type
of startup script to get argus going.
CYGWIN
Argus has been ported to Cygwin, the RedHat Linux environment for Windows.
Cygwin can be found at http://www.cygwin.com. Install the latest version
of Cygwin, modifying the default install to include the developement support.
As noted above, you will need bison and flex and optionally tcpwrappers,
which are available for Cygwin.
On CYGWIN, the libpcap function is provided by the WinPcap Developers Pack.
The current version can be found at:
http://www.winpcap.org/devel.htm
Place the unzipped WpdPack folder in the same directory that you
untared argus, and the argus ./configure script will find it
and do the right thing. At this point, to make argus:
% ./configure
% make
That should make an argus binary that can be installed as a Windows
service, using the cygrunsrv() program.
Because interface names are so difficult to use on Windows, the Cygwin
port of argus allows you to specify an index for the interface you want
to monitor. By running argus without an interface specification, argus
will print out the available interfaces, with thier indexes. Use the
index number on the command line, or in the argus.conf file.
To setup argus as a system service under CYGWIN, use the cygrunsvc()
program. Argus will write its output to /var/log/argus.log, so check
there is you have any problems.