周五晚上LVS集群的一台LB由于CPU单核耗尽挂掉了,最后查到原因是网卡调优没有生效,今天查了一下网卡调优的资料,感谢同事higkoo给我讲解了一下这方面的东西,下面是关于我们公司网卡调优的相关知识,欢迎大家共同探讨,让我们的机器跑的更high。
1、Broadcom的网卡建议关闭GRO功能
| 1 2 3 4 | ethtool-K eth0 gro offethtool-K eth1 gro offethtool-K eth2 gro offethtool-K eth3 gro off |
2、关闭irqbalance服务并手动分配网卡中断
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | service irqbalance stopchkconfig irqbalance off# 查看网卡中断号grep/proc/interrupts# 分配到每颗颗CPU核上cat/proc/irq/{84,85,86,87,88,89,90,91,92,93}/smp_affinityecho/proc/irq/84/smp_affinityecho/proc/irq/85/smp_affinityecho/proc/irq/86/smp_affinityecho/proc/irq/87/smp_affinityecho/proc/irq/88/smp_affinityecho/proc/irq/89/smp_affinityecho/proc/irq/90/smp_affinityecho/proc/irq/91/smp_affinityecho/proc/irq/92/smp_affinityecho/proc/irq/93/smp_affinityPS:smp_affinity的值可以用下面脚本算哈,此脚本来自:http://rfyiamcool.blog.51cto.com/1030776/1335700#!/bin/bash#echo"统计cpu的16进制"[ $# -ne 1 ] && echo ‘$1 is Cpu core number’ && exit 1CCN=$1echo“Print eth0 affinity”for((i=0; i<${CCN}; i++))doecho==============================echo"Cpu Core $i is affinity"((affinity=(1<<i)))echo"obase=16;${affinity}"bcdone使用方法:sh 脚本名字 空格 cpu核数 |
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | # Enable RPS (Receive Packet Steering)rfc=4096cc=$(grep/proc/cpuinfo)rsfe=$(echobc)sysctl -w net.core.rps_sock_flow_entries=$rsfeforin$(ls/sys/class/net/eth*/queues/rx-*/rps_cpus)doechofff > $fileRpsdoneforin$(ls/sys/class/net/eth*/queues/rx-*/rps_flow_cnt)doecho$rfc > $fileRfcdonetail/sys/class/net/eth*/queues/rx-*/{rps_cpus,rps_flow_cnt} |
献上一个完整的脚本:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | vi/opt/sbin/change_irq.sh#!/bin/bashethtool-K eth0 gro offethtool-K eth1 gro offethtool-K eth2 gro offethtool-K eth3 gro offservice irqbalance stopchkconfig irqbalance offcat/proc/irq/{84,85,86,87,88,89,90,91,92,93}/smp_affinityecho/proc/irq/84/smp_affinityecho/proc/irq/85/smp_affinityecho/proc/irq/86/smp_affinityecho/proc/irq/87/smp_affinityecho/proc/irq/88/smp_affinityecho/proc/irq/89/smp_affinityecho/proc/irq/90/smp_affinityecho/proc/irq/91/smp_affinityecho/proc/irq/92/smp_affinityecho/proc/irq/93/smp_affinity# Enable RPS (Receive Packet Steering)rfc=4096cc=$(grep/proc/cpuinfo)rsfe=$(echobc)sysctl -w net.core.rps_sock_flow_entries=$rsfeforin$(ls/sys/class/net/eth*/queues/rx-*/rps_cpus)doechofff > $fileRpsdoneforin$(ls/sys/class/net/eth*/queues/rx-*/rps_flow_cnt)doecho$rfc > $fileRfcdonetail/sys/class/net/eth*/queues/rx-*/{rps_cpus,rps_flow_cnt}chmod/opt/sbin/change_irq.shecho"/opt/sbin/change_irq.sh"/etc/rc.localPS:记得修改网卡中断号,别直接拿来用哦 |