【zabbix】部署nfsen监控netflow

运维监控/Zabbix/Ansible自动化运维/云拨测

netflow和sflow可以帮助我们分析网络中的流量构成,抓取实施带宽使用情况,帮我们找出"hog"。作为collector的软件一般都是收费的,例如solarwinds NTA,sflowTrend-Pro,ntopng商业版等。不过也有开源的解决方案,例如ntopng社区版和nfsen。

以下是基于cenos7.5部署nfsen的过程:

一、安装nfsen 需要以下依赖:

rrdtool和perl模块及所需组件

使用以下yum命令安装:

yum -y install httpd php perl-rrdtool rrdtool rrdtool-devel rrdutils flex byacc perl-Socket6 perl-MailTools perl-Mail-Sender perl-Sys-Syslog perl-Module-Install.noarch

perl-Mail-Sender-0.8.23-1.el7.noarch.rpm和rrdutils-5.2.1-1.el6.rf.noarch.rpm 这两个文件为rrdutils和perl-Mail-Sender,yum源无法安装这两个的时候使用,rpm -ivh 安装即可。

二、Web环境的部署:

vi /etc/httpd/conf/httpd.conf #修改apache配置文件

添加以下语句:

AddType application/x-tar .tgz #查找AddType

AddType application/x-httpd-php .php

index.php nfsen.php #查找index.html将index.php和nfsen.php加至句末

编写测试页面:

vi /var/www/html/index.php

内容如下:

<?php

phpinfo();

?>

关闭防火墙或放通80端口,关闭selinux

systemctl stop firewalld

setenforce 0

重新启动httpd使配置生效

systemctl restart httpd

打开浏览器输入该服务器的IP地址,可查看到界面为php测试界面即apache+php环境配置完毕。

三、安装Nfdump工具----用于抓包主要软件

wget http://downloads.sourceforge.net/project/nfdump/stable/nfdump-1.6.11/nfdump-1.6.11.tar.gz 下载

或使用附件:nfdump-1.6.11.tar.gz

使用以下命令安装:

tar -zxf nfdump-1.6.11.tar.gz

cd nfdump-1.6.11

./configure --enable-nfprofile --enable-nftrack --with-rrdpath=/usr/local/rrdtool

make

make install

cp bin/nftrack /usr/local/bin/ #后面配置Portracker插件的时候需用到

使用nfdump -V命令能看到版本信息,表示安装完成:

四、安装并配置Nfsen

wget http://iweb.dl.sourceforge.net/project/nfsen/stable/nfsen-1.3.6p1/nfsen-1.3.6p1.tar.gz

下载

或使用附件:nfsen-1.3.6p1.tar.gz

mkdir -p /usr/local/nfsen

tar zxvf nfsen-1.3.6p1.tar.gz

cd nfsen-1.3.6p1/

cp etc/nfsen-dist.conf etc/nfsen.conf

修改Nfsen配置文件:

vi etc/nfsen.conf

内容如下:

$BASEDIR = "/usr/local/nfsen";

$HTMLDIR = "/var/www/html/nfsen/";

$USER = "apache";

$WWWUSER = "apache";

$WWWGROUP = "apache";

%sources = (

'upstream1' => { 'port' => '9995', 'col' => '#0000ff', 'type' => 'netflow' },

'peer1' => { 'port' => '9996', 'IP' => '172.16.17.18' },

'peer2' => { 'port' => '9996', 'IP' => '172.16.17.19' },

); #9995为接收网络设备netflow的端口

修改完成后,保存并退出。

安装Nfsen:

./install.pl etc/nfsen.conf

执行安装命令后,回车使用默认配置安装即可。

安装时若报一个204行限制访问的错误,需要修改install.pl,注释掉203-205这三行:

vi install.pl

if ( scalar @out != 2 ) {

die "Error getting nfdump version";

}

然后重新执行安装即可。

五、Nfsen插件PortTracker配置

新建PortTracker数据存放目录:

mkdir /usr/local/nfsen/ports-db

chown -R apache:apache /usr/local/nfsen/ports-db/

编辑PortTracker.pm修改$PORTSDBDIR目录:

注意:该目录为解压nfsen-1.3.6p1.tar.gz后cd nfsen-1.3.6p1的目录。

vi contrib/PortTracker/PortTracker.pm

修改的内容如下:

my $PORTSDBDIR = "/usr/local/nfsen/ports-db";

复制PortTracker插件至相应目录:

cp contrib/PortTracker/PortTracker.pm /usr/local/nfsen/plugins/

cp contrib/PortTracker/PortTracker.php /var/www/html/nfsen/plugins/

修改Nfsen配置文件添加插件信息:

vi /usr/local/nfsen/etc/nfsen.conf

内容如下:

@plugins = (

[ 'live', 'PortTracker' ],

);

生成PortTracker测试数据:

(执行完此命令后,需要等待一段时间)

sudo -u apache /usr/local/bin/nftrack -I -d /usr/local/nfsen/ports-db/

执行完成后如下图所示:

启动Nfsen:

/usr/local/nfsen/bin/nfsen start

ps -ef | grep nfsen 可以看到nfsen的进程

让apache加载nfsen:

vi /etc/httpd/conf/httpd.conf #修改apache配置文件

修改后的内容如下:

DocumentRoot "/var/www/html/nfsen"

修改完成后,保存并退出。

重新启动httpd使配置生效

systemctl restart httpd

打开浏览器输入该服务器的IP地址,可查看到界面为nfsen的界面。

部署nfsen完成。

六、附加:使用flowexport把cenos网卡的流量发到9995端口就行监控

https://www.flowtraq.com/ flowtra官网,可下载flowexport

附件:flowexport_linux_x86_64.bin

上传flowexport_linux_x86_64.bin 到任意目录下

chmod +x flowexport_linux_x86_64.bin 授权

执行以下命令:把网卡ens160的流量发到127.0.0.1的9995端口,发送间隔最小30秒最大60秒:

./flowexport_linux_x86_64.bin -i ens160 -nf5 127.0.0.1 9995 -a 30 -e 60

ping ens160网卡的IP,即可产生一些icmp的流量,大概1分钟后,可在nfsen界面上看到流量图有流量了。

七、附加:安裝HostStats插件

用hoststats,可以根据时间来显示流量状况.

安装编译需要的环境

yum -y install gcc gcc-c++ gcc-g77

附件:libnfdump.tar.gz 和hoststats-1.1.5.tar.gz

tar zxvf hoststats-1.1.5.tar.gz

cd hoststats-1.1.5

上传libnfdump.tar.gz到该目录下

./install-libnfdump.sh

mkdir /var/www/html/hoststats/

./configure

make

make install

这个时候会提示要确认安装路径,输入/var/www/html/hoststats/

chown apache:apache -R /var/www/html/hoststats

启动

/var/www/html/hoststats/hoststats start

重新启动Nfsen:

/usr/local/nfsen/bin/nfsen stop

/usr/local/nfsen/bin/nfsen start

如要添加到/etc/rc.local,开机启动:

echo ‘/var/www/hoststats/hoststats start‘ >> /etc/rc.local

以上步骤完成后,稍等几分钟,即可在plugins菜单上看到界面.

如出现提示错误:Fatal error: Call to undefined function mb_convert_encoding() in /var/www/html/nfsen/plugins/HostStats/libs/Nette/Utils/Strings.php on line 61

解决方法:

1.首先安装 php-mbstring库文件:

yum install php-mbstring

2.之后,修改/etc/php.ini文件,在里面加一句

extension=mbstring.so

3.保存后重启httpd服务。

service httpd restart

关于界面操作教程,以下网址参考:

http://blog.sina.com.cn/s/blog_704836f40102w9xa.html

//////////////////////////////////////////////////////////////////////////////////////////////

11、若需修改时间显示粒度及设置filter输入框字符限制(默认50字符)可修改如下:

vim /var/www/html/nfsen/details.php

1277行 <textarea name="filter" id="filter" multiline="true" wrap="phisical" rows="6" cols="50" maxlength="100"><?php

vim /var/www/html/nfsen/nfsenutil.php

430行 ( time() - $_SESSION['PluginListUpdate'] < 600 ) ) {

456行 ( time() - $_SESSION['ProfileListUpdate'] < 600 ) ) {

633行 ( time() - $_SESSION['DefaultFiltersUpdate'] < 600 ) ) {

12、web页面如需设置用户名密码登陆可按如下配置:

vim /etc/httpd/conf/httpd.conf

在最后添加如下(开启http的访问验证功能):

<Directory /var/www/html/nfsen>

Options Indexes FollowSymLinks

allowoverride authconfig

order allow,deny

allow from all

</Directory>

然后设置访问限制配置文件:

vim /var/www/html/nfsen/.htacces

编写如下内容:

Authname "Authorized users only. All activity may be monitored and reported!"

Authtype basic

Authuserfile /etc/httpd/conf/.htpasswd

require valid-user

配置访问用户名及密码:

htpasswd -bc /etc/httpd/conf/.htpasswd 用户名 密码

其他插件安装参考:

http://www.mamicode.com/info-detail-1331877.html

附件:

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容