This procedure will help you get NFSEN and NFDUMP running on CentOS 7. Start with a minimal installation of CentOS 7, update it "yum update" to apply all the latest update. Then proceed with the below steps.
Change "SELINUX=enforcing" to --> "SELINUX=disabled"
vi /etc/selinux/config
Stop iptables firewall:
systemctl stop firewalld
systemctl disable firewalld
Reboot to apply the SELINUX and the ipTables Changes:
reboot
Run "sestatus" to verify selinux is disabled. The status should say the following: "SELinux status: disabled"
sestatus
Run the following to verify the firewall status. It should say: "not running"
firewall-cmd --state
We will need to install a number of packages for CentOS 7 to get NFSEN running:
yum install -y httpd php wget gcc make rrdtool-devel rrdtool-perl perl-MailTools perl-Socket6 flex byacc perl-Sys-Syslog perl-Data-Dumper
yum install -y autoconf automake apache php perl-MailTools rrdtool-perl perl-Socket6 perl-Sys-Syslog.x86_64 policycoreutils-python tcpdump
echo "date.timezone = America/Denver" > /etc/php.d/timezone.ini
yum update -y
Create the netflow user account and add it to the apache group:
useradd netflow -G apache
Create the directories which we will specify later in the configuration file:
mkdir -p /data/nfsen
mkdir -p /var/www/html/nfsen
Download the latest nfdump and nfsen packages. At time of this writing the latest versions are nfdump-1.6.13.tar.gz and nfsen-1.3.8.tar.gz
cd /opt/
wget http://downloads.sourceforge.net/project/nfdump/stable/nfdump-1.6.13/nfdump-1.6.13.tar.gz
wget https://sourceforge.net/projects/nfsen/files/stable/nfsen-1.3.8/nfsen-1.3.8.tar.gz
Start the httpd service:
service httpd start
Untar the downloaded nfdump package into the "/opt/" Directory.
tar -zxvf nfdump-1.6.13.tar.gz
Compile nfdump while in the "/opt/nfdump-1.6.13" directory:
cd /opt/nfdump-1.6.13
./configure --prefix=/opt/nfdump --enable-nfprofile --enable-nftrack --enable-sflow
autoreconf
make && sudo make install
Untar nfsen into the "/opt/" directory.
cd ..
cd /opt/
tar -zxvf nfsen-1.3.8.tar.gz
cd nfsen-1.3.8
cd etc
cp nfsen-dist.conf nfsen.conf
vi nfsen.conf
Edit the nfsen.conf file with at least the changes below. Make sure all data path variables are set correctly:
$BASEDIR= "/data/nfsen";
$HTMLDIR = "/var/www/nfsen"; 'change to' --> $HTMLDIR = "/var/www/html/nfsen";
$PREFIX = '/usr/local/bin'; 'change to' --> '$PREFIX = '/opt/nfdump/bin';
$WWWUSER = "www"; 'change to' --> $WWWUSER = "apache"; $WWWGROUP = "www"; 'change to' --> $WWWGROUP = "apache";
You can change the following if you know all the hosts: Duplicate the 'router-1' line for each different host. Change the Name, Port and Color for each different line. Comment out lines by using "#" at the beginning of the line
%sources = (
'router-1' => { 'port' => '9030', 'col' => '#0000ff', 'type' => 'netflow' },
'firewall-1' => { 'port' => '9031', 'col' => '#9093ff', 'type' => 'netflow' },
);
The next section we will add the "flowdoh" plugin which we will install and configure after NFSEN and NFDUMP are up and running.
@plugins = ( # profile # module
# [ '', 'demoplugin' ],
[ '', 'flowdoh' ], )
Save the above changes
cd ..
./install.pl etc/nfsen.conf
Press enter to accept the default path.
Perl to use: [/usr/bin/perl]
You may get Errors since we did not configure any flows at this point.
Let's now create a startup script for the service
vi /etc/init.d/nfsen
Copy the below information into the new configuration file:
#!/bin/bash
#! #chkconfig: - 50 50
#description: nfsen
DAEMON=/data/nfsen/bin/nfsen
case "$1" in
start)
$DAEMON start
;;
stop)
$DAEMON stop
;; status)
$DAEMON status
;;
restart)
$DAEMON stop
sleep 1
$DAEMON start
;;
*)
echo "Usage: $0 {start|stop|status|restart}"
exit 1
;;
esac
exit 0
Save the above file.
Make sure the script is executable
chmod +x /etc/init.d/nfsen
Start the nfsen deamon:
/etc/init.d/./nfsen start
Use the following to restart nfsen when necessary:
/etc/init.d/nfsen restart
Go to http://127.0.0.1/nfsen/nfsen.php (in place of 127.0.0.1" use your server IP.)
Backend version missmatch!
We enabled it earlier, now we are going to installand configure it.
cd /opt/
sudo wget https://sourceforge.net/projects/flowdoh/files/FlowDoh_1.0.2.tar.gz
sudo tar -zxvf FlowDoh_1.0.2.tar.gz
Backend: (/data/nfsen/plugins/)
cd /opt/flowdoh/backend/
cp -avr flowdoh/ /data/nfsen/plugins/
cp flowdoh.pm /data/nfsen/plugins/
cd /data/nfsen/plugins/flowdoh
cp flowdoh.conf.defaults flowdoh.conf
cd /data/nfsen/plugins
chmod 777 flowdoh
chmod 777 flowdoh.pm
FrontEnd: (/var/www/html/nfsen/plugins/)
cd /opt/flowdoh/frontend/
cp flowdoh.php /var/www/html/nfsen/plugins/
cp -avr flowdoh/ /var/www/html/nfsen/plugins/
cd /var/www/html/nfsen/plugins
chmod 777 flowdoh
chmod 777 flowdoh.php
Restart NFSEN to add the FLOWDOH Plugin.
/etc/init.d/nfsen restart
The below steps will help in troubleshooting and maintaning your installation.
Use tcpdump to verify that flows are being received on the specified port.
Run the below to list the device NICs:
ip link show
tcpdump -i <NIC_IDENTIFIER> port <TCP_PORT_DEFINED_IN_SETUP>
Make sure that you see traffic on this port from required host.
With nfdump you can read flow collection files from command line
cd /data/nfsen/profiles-data/live/ /opt/nfdump/bin/nfdump -r "<your_file_name>"
You may need to edit /etc/php.ini and adjust your (date.timezone = "US/Eastern") settings
ps axo command | grep '[n]fcapd'
Check which ports nfcapd is listening on:
ss -nutlp
On the nfsen server, edit the nfsen.conf file to add NetFlow sources:
vi /data/nfsen/etc/nfsen.conf
You can set the color ( 'col' => '#xxyyxx') to something you would like by finding a HEX color identifyer at the following site: https://www.color-hex.com/ In place of ('CiscoRouter') and or ('LinuxServer') use a friendly name for your device like 'corp-firewall' or 'corp-router'
%sources = (
'CiscoRouter' => { 'port' => '2055', 'col' => '#0000ff', 'type' => 'netflow' },
'LinuxServer' => { 'port' => '9666', 'col' => '#ff5a00', 'type' => 'netflow' },
);
cd /data/nfsen/bin/
./nfsen reconfig
/etc/init.d/nfsen restart
It takes around 5 minutes (depending on your server) to start showing data on the web pages. Validate with TCP Dump (Troubleshooting section above) to ensure data is being received. If data is being received just wait it will start to populate the graphs.
-
Initial work completed by - paidegua
-
If I helped in anyway consider - Donating a Beer