美文网首页
Linux增加Netfilter的链路追踪数

Linux增加Netfilter的链路追踪数

作者: 唯米天空 | 来源:发表于2020-08-25 18:50 被阅读0次

    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目录下,创建配置文件,将需要调整的参数加入其中即可。配置文件名格式为<number>-<appname>.conf。appname可以直接用应用系统运行时的os用户名。

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

    /sbin/sysctl -p /etc/sysctl.d/<number>-<appname>.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
    

    相关文章

      网友评论

          本文标题:Linux增加Netfilter的链路追踪数

          本文链接:https://www.haomeiwen.com/subject/tdcnjktx.html