热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【zabbix】部署nfsen监控netflow

运维监控ZabbixAnsible自动化运维云拨测netflow和sflow可以帮助我们分析网络中的流量构成,抓取实施带宽使用情况,帮我们找出hog

运维监控/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

内容如下:

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

systemctl stop firewalld

setenforce 0

重新启动httpd使配置生效

systemctl restart httpd

打开浏览器输入该服务器的IP地址,可查看到界面为php测试界面即apache+php环境配置完毕。
【zabbix】部署nfsen监控netflow

三、安装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行

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

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

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

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

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

vim /etc/httpd/conf/httpd.conf

在最后添加如下&#xff08;开启http的访问验证功能&#xff09;&#xff1a;

Options Indexes FollowSymLinks

allowoverride authconfig

order allow,deny

allow from all

然后设置访问限制配置文件&#xff1a;

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

编写如下内容&#xff1a;

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

Authtype basic

Authuserfile /etc/httpd/conf/.htpasswd

require valid-user

配置访问用户名及密码&#xff1a;

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

其他插件安装参考&#xff1a;

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

附件&#xff1a;
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


推荐阅读
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
author-avatar
阿里根本_436
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有