参考“毛蛋哥”的文档,在 FreeBSD 12 里尝试安装 nfsen。用一个VirtualBox虚拟机测试,目的是让nfsen portraker 在浏览器里显示出图表,不做网络流量分析。
1.下载现成的虚拟机虚拟磁盘文件,如国内的可从阿里云镜像点下载 https://mirrors.aliyun.com/freebsd/releases/VM-IMAGES/12.0-RELEASE/amd64/Latest/FreeBSD-12.0-RELEASE-amd64.vhd.xz
2.下载好磁盘文件后,解压。在VirtualBox里创建虚拟机,配置虚拟机用现有的,刚下载到的磁盘文件,虚拟网卡为“桥接网络”
data:image/s3,"s3://crabby-images/65e96/65e968e012937bbf9ba82ade842d4eb96158ba6f" alt="nfsen-1.png nfsen-1.png"
3.root账户密码默认为空。新增一个普通用户,添加到wheel组中,可ssh登录输入操作,较方便
data:image/s3,"s3://crabby-images/8366e/8366e81fa13e03439ecdc2590933b846ea8dd6af" alt="nfsen-2.png nfsen-2.png"
4.sysrc sshd_enable=YES # 配置sshd服务
5.service sshd start # 启动sshd服务
data:image/s3,"s3://crabby-images/09fe8/09fe8de6f4411df1f57d0b2e8138946107dff56e" alt="nfsen-3.png nfsen-3.png"
6.以普通用户ssh登录,然后通过su切换到root
7.pkg # 运行pkg,如果没有安装,会提示下载和安装
data:image/s3,"s3://crabby-images/f0965/f09651520c3c96c4578dd23602920c065b2c17ee" alt="nfsen-4.png nfsen-4.png"
8.pkg install fprobe # 如需fprobe,可使用pkg便捷安装
data:image/s3,"s3://crabby-images/c0dba/c0dba5f935b7a6d51d785fe94b50eccf7042d80d" alt="nfsen-5.png nfsen-5.png"
9.portsnap fetch # 获取 ports
10.portsnap extract # 展示 ports
11.pkg install nfsen # 安装 nfsen
data:image/s3,"s3://crabby-images/9a5be/9a5be32166b6332d957b6b1ba0661e9e6d126bc3" alt="nfsen-7.png nfsen-7.png"
12.pkg install apache24 # 安装 apache24
data:image/s3,"s3://crabby-images/92f5d/92f5d0182c66ba8159d35759bfb8567affc65e90" alt="nfsen-8.png nfsen-8.png"
13.sysrc apache24_enable=yes # 配置 apache24 服务
14.sysrc php_fpm_enable=yes # 配置 php-fpm 服务
15.vi /usr/local/etc/apache24/httpd.conf # 编辑 apache24 配置文件,启用 mod_proxy 和 mod_proxy_fcgi 模块
data:image/s3,"s3://crabby-images/1904e/1904e7b2c728bac18253743e02f9588388daf197" alt="nfsen-9.png nfsen-9.png"
16.继续编辑httpdconf配置文件,替换默认文件路径 /usr/local/www/apache24/data 为 nfsen 的 /usr/local/www/nfsen,添加php文件处理 ProxyPassMatch ^/(.*.php)$ fcgi://127.0.0.1:9000/usr/local/www/nfsen/$1 ,添加 nfsen.php 默认首页
data:image/s3,"s3://crabby-images/1e742/1e742d5f63519b4bacb8bd3160b37702bb211503" alt="nfsen-10.png nfsen-10.png"
17.service php-fpm start # 启动 php-fpm 服务
18.service apache24 start # 启动 apache24 服务
19.在浏览器里访问虚拟机的IP,如果看到nfsen的报错信息,那apache和php基本上可以运行了
data:image/s3,"s3://crabby-images/a64b7/a64b7ba221a00e68274988e4afaabc4a62213ba3" alt="nfsen-11.png nfsen-11.png"
20.vi /usr/local/etc/nfsen.conf # 编辑nfsen配置文件,修改netflow数据源地址
data:image/s3,"s3://crabby-images/469fc/469fc1400d19caae3e87f491380c15d784bdb17b" alt="nfsen-12.png nfsen-12.png"
21.sysrc nfsen_enable=yes # 配置 nfsen 服务
22.service nfsen start # 尝试启动 nfsen 服务
23.nfsen reconfig # 如果启动失败,会提示需先配置
data:image/s3,"s3://crabby-images/b930f/b930f49e8fcd73c57eb5502915fcbfc5e7838845" alt="nfsen-13.png nfsen-13.png"
24.cd /usr/ports/net-mgmt/nfdump/ # 切换到nfdump的ports路径
25.make # 编译,记得要勾选nftrack
data:image/s3,"s3://crabby-images/d5caf/d5caf6cc4e603437552ddca8979a0ee2a4ab3e60" alt="nfsen-14.png nfsen-14.png"
26.cp /usr/ports/net-mgmt/nfdump/work/nfdump-1.6.17/bin/.libs/nftrack /usr/local/bin/ # 复制 nftrack
data:image/s3,"s3://crabby-images/e256b/e256b943ef70d244c66212a5ee60d4fba7279055" alt="nfsen-15.png nfsen-15.png"
27.rehash
28.mkdir /usr/local/var/nfsen/portsdb
29.cp /usr/ports/net-mgmt/nfsen/work/nfsen-1.3.8/contrib/PortTracker/PortTracker.pm /usr/local/libexec/nfsen/plugins/ # 复制 PortTracker.pm。如果提示没有找到文件,可转到 /usr/ports/net-mgmt/nfsen,make之后看是否会自动生成
30.cp /usr/ports/net-mgmt/nfsen/work/nfsen-1.3.8/contrib/PortTracker/PortTracker.php /usr/local/www/nfsen/plugins/ # 复制 PortTracker.php
data:image/s3,"s3://crabby-images/a7076/a7076bf080d345188982c854b399eb0f04f769c7" alt="nfsen-16.png nfsen-16.png"
31.vi /usr/local/libexec/nfsen/plugins/PortTracker.pm # 编辑PortTracker配置文件,修改 $PORTSDBDIR 的路径
data:image/s3,"s3://crabby-images/c54a0/c54a0306b4b243ded4dd801596fca343d84ae0bd" alt="nfsen-17.png nfsen-17.png"
32.vi /usr/local/etc/nfsen.conf # 编辑 nfsen 配置文件,增加插件 PortTracker @plugins
data:image/s3,"s3://crabby-images/450b9/450b9eb9e6fb2652e93d76df50d9b387eda540e0" alt="nfsen-18.png nfsen-18.png"
33.nftrack -I -d /usr/local/var/nfsen/portsdb/ # 初始化数据文件
data:image/s3,"s3://crabby-images/153b8/153b8b4e1918595c5d7d39cd39e7e09bdae50654" alt="nfsen-19.png nfsen-19.png"
34.touch /usr/local/var/nfsen/portsdb/portstat.txt /usr/local/var/nfsen/portsdb/portstat24.txt # 创建记录文件
35.chown -R www:www /usr/local/var/nfsen/portsdb # 更改数据目录权限为web用户的
36.service nfsen restart # 尝试重启 nfsen 服务
data:image/s3,"s3://crabby-images/1305f/1305fb0024bdefb4bf30c92af97add4f1a05e95b" alt="nfsen-20.png nfsen-20.png"
37.等约五分钟后,再在浏览器里访问,可以看到nfsen相关页内容,如详情页:
data:image/s3,"s3://crabby-images/3099c/3099cbc6fd0f1cfbd5d54eff387b08c7a6f19227" alt="nfsen-21.png nfsen-21.png"
38.nfsen插件PortTracker页:
data:image/s3,"s3://crabby-images/133d0/133d05612ce4befcc999d2d8419a4d5ba993ca62" alt="nfsen-22.png nfsen-22.png"
参考: