linux的netfilter,Linux增加Netfilter的链路追踪数

1. 调整内核参数 nf_conntrack_buckets 和 net.netfilter.nf_conntrack_max

nf_conntrack_buckets,size of hash table,范围为[32, 16384]。如果未指定,则系统根据公式计算得出此值,主机内存在4GB以上的,设置为65535,相当于使用1GB内存。公式为Total Memory/16384。

net.netfilter.nf_conntrack_max,Size of connection tracking table,默认值为nf_conntrack_buckets * 4。

以上2个值,对于128GB内存主机而言,不同操作系统计算结果不同。

CentOS 6.x/CentOS 7.3以下默认为16384/65535。CentOS 7.6中为65535/262144。如果/var/log/messages中出现nf_conntrack超出的error,增加net.netfilter.nf_conntrack_max即可,x2倍。

临时调整

/sbin/sysctl -w net.netfilter.nf_conntrack_max=524288

永久调整

在/etc/sysctl.d目录下,创建配置文件,将需要调整的参数加入其中即可。配置文件名格式为-.conf。appname可以直接用应用系统运行时的os用户名。

执行以下命令,使之生效。替换掉命令中的文件名。

/sbin/sysctl -p /etc/sysctl.d/-.conf

例如:

cat << EOF > /etc/sysctl.d/101-ichat.conf

#file-max,Linux可以分配的最大fd数量。

net.netfilter.nf_conntrack_max=524288

EOF

2. 查看当前数量

cat /proc/net/nf_conntrack

脚本:

#!/bin/bash

currentLink=$(sudo /bin/cat/proc/net/nf_conntrack | /usr/bin/wc -l)

totalLink=$(/bin/cat/proc/sys/net/netfilter/nf_conntrack_max)

restLink=$[$totalLink-$currentLink]

case $1 in

max)

echo $totalLink

;;

used)

echo $currentLink

;;

idle)

echo $restLink

esac

3. 不跟踪某些特性的连接,节约conntrack

//不跟踪web服务的链接

iptables -t raw -A PREROUTING -p tcp--dport 80 -j NOTRACK

iptables -t raw -A OUTPUT -p tcp --sport80 -j NOTRACK

//不跟踪本地内的所有链接

iptables -t raw -A PREROUTING -i lo -jNOTRACK

iptables -t raw -A OUTPUT -o lo -jNOTRACK

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值