proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操做提供接口。用户和应用程序能够经过proc获得系统的信息,并能够改变内核的某些参数。"网络
这里将介绍如何从/proc文件系统中获取与防火墙相关的一些性能参数,以及如何经过/proc文件系统修改内核的相关配置。性能
一、从/proc文件系统获取相关的性能参数spa
cpu使用率:/proc/stat命令行
内存使用状况: /proc/meminfocode
网络负载信息:/proc/net/devorm
相应的计算方法:(摘自:什么是proc文件系统)接口
(1) 处理器使用率ip
(2) 内存使用率内存
(3) 流入流出数据包it
(4) 总体网络负载
这些数据分别要从/proc/stat、/proc/net/dev、/proc/meminfo三个文件中提取。如里有问题或对要提取的数据不太清楚,能够使用man proc来查看proc文件系统的联机手册。
(1) 处理器使用率
这里要从/proc/stat中提取四个数据:用户模式(user)、低优先级的用户模式(nice)、内核模式(system)以及空闲的处理器时间(idle)。它们均位于/proc/stat文件的第一行。CPU的利用率使用以下公式来计算。
CPU利用率 = 100 *(user + nice + system)/(user + nice + system + idle)
(2) 内存使用率
这里须要从/proc/meminfo文件中提取两个数据,当前内存的使用量(cmem)以及内存总量(amem)。
内存使用百分比 = 100 * (cmem / umem)
(3)网络利用率
为了获得网络利用率的相关数据,须要从/proc/net/dev文件中得到两个数据:从本机输出的数据包数,流入本机的数据包数。它们都位于这个文件的第四行。
性能收集程序开始记录下这两个数据的初始值,之后每次得到这个值后均减去这个初始值即为从集群启动开始从本节点经过的数据包。
利用上述数据计算出网络的平均负载,方法以下:
平均网络负载 = (输出的数据包+流入的数据包) / 2
2. 经过/proc文件系统调整相关的内核配置
容许ip转发 /proc/sys/net/ipv4/ip_forward
禁止ping/proc/sys/net/ipv4/icmp_echo_ignore_all
能够在命令行下直接往上述两个“文件”里头写入"1"来实现相关配置,若是写入"0"将取消相关配置。不过在系统重启之后,这些配置将恢复默认设置,因此,若是想让这些修改生效,能够把下面的配置直接写入/etc/profile文件,或者其余随系统启动而执行的程序文件中。
echo 1 > /proc/sys/net/ipv4/ip_forward echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
若是须要获取其余的性能参数,或者须要对内核进行更多的配置,能够参考proc文件系统介绍,也能够直接经过man proc查看相关的信息