| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420 | .\" $Id$.\".\" Copyright (c) 2002 Damien Miller.  All rights reserved..\" Portions Copyright (c) 2001 Kevin Steves.  All rights reserved..\".\" Redistribution and use in source and binary forms, with or without.\" modification, are permitted provided that the following conditions.\" are met:.\" 1. Redistributions of source code must retain the above copyright.\"    notice, this list of conditions and the following disclaimer..\" 2. Redistributions in binary form must reproduce the above copyright.\"    notice, this list of conditions and the following disclaimer in the.\"    documentation and/or other materials provided with the distribution..\".\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED..\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE..\".Dd October 14, 2002.Dt SOFTFLOWD 8.Os.Sh NAME.Nm softflowd.Nd Traffic flow monitoring.Sh SYNOPSIS.Nm softflowd.Op Fl 6dDh.Op Fl L Ar hoplimit.Op Fl T Ar track_level.Op Fl c Ar ctl_sock.Ek.Oo Fl i\ \&.Sm off.Oo Ar if_ndx : Oc.Ar interface.Sm on.Oc.Bk words.Op Fl m Ar max_flows.Op Fl n Ar host:port.Op Fl p Ar pidfile.Op Fl r Ar pcap_file.Op Fl t Ar timeout_name=seconds.Op Fl v Ar netflow_version.Op bpf_expression.Sh DESCRIPTION.Nmis a software implementation of a flow-based network traffic monitor..Nmreads network traffic and gathers information about active traffic flows.A "traffic flow" is communication between two IP addresses or (if theoverlying protocol is TCP or UDP) address/port tuples..PpThe intended use of.Nmis as a software implementation of Cisco's NetFlow(tm) traffic accountsystem..Nmsupports data export using versions 1, 5 or 9 of the NetFlow protocol..Nmcan also run in statistics-only mode, where it just collects summaryinformation.However, too few statistics are collected to make thismode really useful for anything other than debugging..PpNetwork traffic may be obtained by listening on a promiscuous networkinterface or by reading stored.Xr pcap 3files, such as those written by.Xr tcpdump 8 .Traffic may be filtered with an optional.Xr bpf 4program, specified on the command-line as.Ar bpf_expression ..Nmis IPv6 capable and will track IPv6 flows if the NetFlow export protocolsupports it (currently only NetFlow v.9 possesses an IPv6 export capability)..Pp.Nmtries to track only active traffic flows.When theflow has been quiescent for a period of time it is expired automatically.Flows may also be expired early if they approach their traffic countsexceed 2 Gib or if the number of flows being tracked exceeds.Ar max_flows(default: 8192).In this last case, flows are expired oldest-first..PpUpon expiry, the flow information is accumulated into statistics which maybe viewed using.Xr softflowctl 8 .If the.Fl noption has been specified the flow information is formatted in a UDP datagramwhich is compatible with versions 1, 5 or 9 of Cisco's NetFlow(tm) accountingexport format.These records are sent to the specified.Ar hostand.Ar port .The host may represent a unicast host or a multicast group..PpThe command-line options are as follows:.Bl -tag -width Ds.It Fl n Ar host:portSpecify the.Ar hostand.Ar portthat the accounting datagrams are to be sent to.The host may be specified using a hostname or using a numeric IPv4 orIPv6 address.Numeric IPv6 addresses should be encosed in square brackets to avoid ambiguitybetween the address and the port.The destination port may be a portname listed in.Xr services 5or a numeric port..It Fl i Xo.Sm off.Oo Ar if_ndx : Oc.Ar interface.Sm on.XcSpecify a network interface on which to listen for traffic.Either the.Fl ior the.Fl roptions must be specified..It Fl r Ar pcap_fileSpecify that.Nmshould read from a.Xr pcap 3packet capture file (such as one created with the.Fl woption of.Xr tcpdump 8 )file rather than a network interface..Nmprocesses the whole capture file and only expires flows when.Ar max_flowsis exceeded.In this mode,.Nmwill not fork and will automatically print summary statistics beforeexiting..It Fl p Ar pidfileSpecify an alternate location to store the process ID when in daemon mode.Default is.Pa /var/run/softflowd.pid.It Fl c Ar ctlsockSpecify an alternate location for the remote control socket in daemon mode.Default is.Pa /var/run/softflowd.ctl.It Fl m Ar max_flowsSpecify the maximum number of flow to concurrently track.If this limit is exceeded, the flows which have least recently seen trafficare forcibly expired.In practice, the actual maximum may briefly exceed this limit by asmall amount as  expiry processing happens less frequently than trafficcollection.The default is 8192 flows, which corresponds to slightly lessthan 800k of working data..It Fl t Ar timeout_name=timeSet the timeout names.Ar timeout_nameto.Ar timeRefer to the.Sx Timeoutssection for the valid timeout names and their meanings.The.Ar timeparameter may be specified using one of the formats explained in the.Sx Time Formatssection below..It Fl dSpecify that.Nmshould not fork and daemonise itself..It Fl 6Force.NmTo track IPv6 flows even if the NetFlow export protocol does not supportreporting them.This is useful for debugging and statistics gathering only..It Fl DPlaces.Nmin a debugging mode.This implies the.Fl dand.Fl 6flags and turns on additional debugging output..It Fl hDisplay command-line usage information..It Fl L Ar hoplimitSet the IPv4 TTL or the IPv6 hop limit to.Ar hoplimit ..Nmwill use the default system TTL when exporting flows to a unicast host.When exporting to a multicast group, the default TTL will be 1(i.e. link-local)..It Fl T Ar track_levelSpecify which flow elements.Nmshould be used to define a flow..Ar track_levelmay be one of:.Dq full(track everything in the flow, the default),.Dq proto(track source and destination addresses and protocol), or.Dq ip(only track source and destination addresses).Selecting either of the latter options will produce flows with less informationin them (e.g. TCP/UDP ports will not be recorded).This will cause flows to be consolidated, reducing the quantity of outputand CPU load that.Nmwill place on the system at the cost of some detail being lost..It Fl v Ar netflow_versionSpecify which version of the NetFlow(tm) protocol.Nmshould use for export of the flow data.Supported versions are 1, 5 and 9.Default is version 5..El.PpAny further command-line arguments will be concatenated together andapplied as a.Xr bpf 4packet filter.This filter will cause.Nmto ignore the specified traffic..Ss Timeouts.Pp.Nmwill expire quiescent flows after user-configurable periods.The exact timeout used depends on the nature of the flow.The various timeouts that may be set from the command-line (using the.Fl toption) and their meanings are:.Bl -tag -width Ds.It Ar generalThis is the general timeout applied to all traffic unless overridden byone of the other timeouts..It Ar tcpThis is the general TCP timeout, applied to open TCP connections..It Ar tcp.rstThis timeout is applied to a TCP connection when a RST packet has beensent by one or both endpoints..It Ar tcp.finThis timeout is applied to a TCP connection when a FIN packet has beensent by both endpoints..It Ar udpThis is the general UDP timeout, applied to all UDP connections..It Ar maxlifeThis is the maximum lifetime that a flow may exist for.All flows are forcibly expired when they pass.Ar maxlifeseconds.To disable this feature, specify a.Ar maxlifeof 0..It Ar expintSpecify the interval between expiry checks.Increase this to group more flows into a NetFlow packet.To disable this feature, specify a.Ar expintof 0..El.PpFlows may also be expired if there are not enough flow entries to hold themor if their traffic exceeds 2 Gib in either direction..Xr softflowctl 8may be used to print information on the average lifetimes of flows andthe reasons for their expiry..Ss Time Formats.Pp.Nmcommand-line arguments that specify time may be expressed using a sequenceof the form:.Sm off.Ar time Op Ar qualifier ,.Sm onwhere.Ar timeis a positive integer value and.Ar qualifieris one of the following:.Pp.Bl -tag -width Ds -compact -offset indent.It Cm <none>seconds.It Cm s | Cm Sseconds.It Cm m | Cm Mminutes.It Cm h | Cm Hhours.It Cm d | Cm Ddays.It Cm w | Cm Wweeks.El.PpEach member of the sequence is added together to calculate the total time value..PpTime format examples:.Pp.Bl -tag -width Ds -compact -offset indent.It 600600 seconds (10 minutes).It 10m10 minutes.It 1h30m1 hour 30 minutes (90 minutes).El.Ss Run-time Control.PpA daemonised.Nminstance may be controlled using the.Xr softflowctl 8command.This interface allows one to shut down the daemon, force expiry ofall tracked flows and extract debugging and summary data.Also, upon receipt of a.Dv SIGTERMor.DV SIGINT.Nmwill cause.Nmto exit, after expiring all flows (and thus sending flow export packetsif.Fl nwas specified on the command-line).If you do not want to export flows upon shutdown, clear them first with.Xr softflowctl 8or use.Xr softflowctl 8 's.Dq exitcommand..Sh EXAMPLES.Bl -tag -width Ds.It softflowd -i fxp0This command-line will cause.Nmto listen on interface fxp0 and to run in statistics gathering modeonly (i.e. no NetFlow data export)..It softflowd -i fxp0 -n 10.1.0.2:4432This command-line will cause.Nmto listen on interface fxp0 and to export NetFlow v.5 datagrams on flowexpiry to a flow collector running on 10.1.0.2 port 4432..It softflowd -v 5 -i fxp0 -n 10.1.0.2:4432 -m 65536 -t udp=1m30sThis command-line increases the number of concurrent flows that.Nmwill track to 65536 and increases the timeout for UDP flows to 90 seconds..It softflowd -v 9 -i fxp0 -n 224.0.1.20:4432 -L 64This command-line will export NetFlow v.9 flows to the multicast group224.0.1.20.The export datagrams will have their TTL set to 64, so multicast receiverscan be many hops away..It softflowd -i fxp0 -p /var/run/sfd.pid.fxp0 -c /var/run/sfd.ctl.fxp0This command-line specifies alternate locations for the control socketand pid file.Similar command-lines are useful when running multipleinstances of.Nmon a single machine..El.Sh FILES.Bl -tag -width Ds.It Pa /var/run/softflowd.pidThis file stores the process ID when.Nmis in daemon mode.This location may be overridden using the.Fl pcommand-line option..It Pa /var/run/softflowd.ctlThis is the remote control socket..Nmlistens on this socket for commands from.Xr softflowctl 8 .This location may be overridden using the.Fl ccommand-line option..El.Sh BUGSCurrently.Nmdoes not handle maliciously fragmented packets properly, i.e. packetsfragemented such that the UDP or TCP header does not fit into the firstfragment.It will product correct traffic counts when presented with maliciouslyfragmented packets, but will not record TCP or UDP port information..Sh AUTHORS.An Damien Miller Aq djm@mindrot.org.Sh SEE ALSO.Xr softflowctl 8 ,.Xr tcpdump 8 ,.Xr pcap 3 ,.Xr bpf 4.Bd -literalhttp://www.cisco.com/univercd/cc/td/doc/product/rtrmgmt/nfc/nfc_3_0/nfc_ug/nfcform.htm.Ed
 |