Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
OpnSense
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
OpnSense
Commits
370992c1
Commit
370992c1
authored
Mar 24, 2016
by
Ad Schellevis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(netflow) simplify setup and add version selector
parent
30016352
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
38 additions
and
33 deletions
+38
-33
netflow.conf.sample
src/etc/netflow.conf.sample
+8
-8
netflow
src/etc/rc.d/netflow
+30
-25
No files found.
src/etc/netflow.conf.sample
View file @
370992c1
...
...
@@ -4,11 +4,11 @@
# define interfaces to configure
netflow_interfaces="em0 em1"
#
per interface settings
# netflow_<interface>_int_destination -> address:port
netflow_em0_int_destination="127.0.0.1:3001"
netflow_em1_int_destination="127.0.0.1:3002"
# netflow_<interface>_destinations -> address:port address:port ...
netflow_em0_destinations="10.211.55.101:2055 10.211.55.100:4444"
netflow_
em1_destinations="10.211.55.101:2056
"
#
select version [5|9]
netflow_version="5"
# send data to
netflow_int_destination="127.0.0.1:3001"
# route to the following endpoints
netflow_
destinations="10.211.55.101:2055 10.211.55.100:4444
"
src/etc/rc.d/netflow
View file @
370992c1
...
...
@@ -39,31 +39,36 @@ stop_cmd="${name}_stop"
[
-z
"
$netflow_enable
"
]
&&
netflow_enable
=
"NO"
# setup_interface (interface
, internal destination, destinations
)
# setup_interface (interface)
# - use netgraph + ng_netflow in combination with samplicate to record netflow data and send it to multiple locations
setup_interface
()
{
# set netflow version (export keyword)
if
[
"
$netflow_version
"
==
"9"
]
;
then
nfversion
=
"9"
else
nfversion
=
""
fi
interface
=
$1
netflow_int_destination
=
$2
netflow_port
=
`
echo
$netflow_int_destination
| /usr/bin/sed
's/:/ /g'
| /usr/bin/awk
'{print $2}'
`
destinations
=
`
echo
$3
| /usr/bin/sed
's/:/\//g'
`
echo
"setup
$interface
(
$netflow_int_destination
$destinations
)"
# determine (snmp) ifIndex
ifIndex
=
`
/usr/bin/netstat
-i
| /usr/bin/grep Link# | /usr/bin/grep
$interface
|
awk
'{print $3}'
| /usr/bin/sed
's/<Link#//g'
| /usr/bin/sed
's/>//g'
`
if
[
"
$ifIndex
"
==
""
]
;
then
echo
"error : interface
$interface
not found"
return
fi
echo
"setup
$interface
"
# make sure netgraph is attached
/usr/local/sbin/ngattach
$interface
# remove earlier setup (if any)
/usr/sbin/ngctl shutdown netflow_
$interface
:
>
/dev/null 2>&1
# configure netflow for this interface, sending all to localhost
/usr/sbin/ngctl
-f-
<<-
SEQ
mkpeer
$interface
: netflow lower iface
0
mkpeer
$interface
: netflow lower iface
$ifIndex
name
$interface
:lower netflow_
$interface
connect
$interface
: netflow_
$interface
: upper out
0
connect
$interface
: netflow_
$interface
: upper out
$ifIndex
mkpeer netflow_
$interface
: ksocket export inet/dgram/udp
msg netflow_
$interface
:export connect inet/
$netflow_int_destination
msg netflow_
$interface
:export
$nfversion
connect inet/
$netflow_int_destination
SEQ
# forward netflow packets, make sure $netflow_int_destination forwards to localhost (127.0.0.1)
if
[
"
$destinations
"
!=
""
]
;
then
/usr/sbin/daemon
-p
/var/run/netflow_samplicate_
$interface
-u
nobody /usr/local/bin/samplicate
-s
127.0.0.1
-p
$netflow_port
$destinations
fi
}
netflow_start
()
...
...
@@ -73,33 +78,33 @@ netflow_start()
echo
"already running"
return
fi
# configure interfaces
for
interface
in
$netflow_interfaces
do
int_destination
=
"netflow_"
$interface
"_int_destination"
eval
"int_destination=
\$
$int_destination
"
destinations
=
"netflow_"
$interface
"_destinations"
eval
"destinations=
\$
$destinations
"
if
[
"
$int_destination
"
!=
""
]
;
then
setup_interface
"
$interface
"
"
$int_destination
"
"
$destinations
"
fi
setup_interface
"
$interface
"
done
# forward netflow packets, make sure $netflow_int_destination forwards to localhost (127.0.0.1)
if
[
"
$netflow_destinations
"
!=
""
]
;
then
netflow_port
=
`
echo
$netflow_int_destination
| /usr/bin/sed
's/:/ /g'
| /usr/bin/awk
'{print $2}'
`
destinations
=
`
echo
$netflow_destinations
| /usr/bin/sed
's/:/\//g'
`
/usr/sbin/daemon
-p
/var/run/netflow_samplicate.pid
-u
nobody /usr/local/bin/samplicate
-s
127.0.0.1
-p
$netflow_port
$destinations
fi
}
# stop netflow collect and distribution
netflow_stop
()
{
# kill all samplicate processes
for
samplicate_pid
in
`
ls
/var/run/netflow_samplicate_
*
2>/dev/null
`
do
kill
-9
`
cat
$samplicate_pid
`
done
# kill all samplicate process
if
[
-f
/var/run/netflow_samplicate.pid
]
;
then
kill
-9
`
cat
/var/run/netflow_samplicate.pid
`
fi
# cleanup netflow processes
for
netflow_node
in
`
ngctl list |
grep
netflow_ |
awk
'{print $2;}'
`
do
/usr/sbin/ngctl shutdown
$netflow_node
:
done
}
load_rc_config
$name
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment