在CentOS上设置网卡的上行和下行带宽限制可以通过使用Traffic Control (tc) 工具来实现。这是一个强大的网络流量控制工具,属于iproute2包的一部分。以下是具体的步骤和方法:
安装必要的工具首先,确保已安装tc工具:
sudo yum install iproute确定网卡名称
使用以下命令查看网卡名称:
ip addr
假设我们要限制的网卡名称为eth0。
创建流量控制规则以下是一个基本的脚本,用于设置上行和下行带宽限制:
#!/bin/bash # 网卡名称 IFACE="eth0" # 上行带宽限制(单位:kbit) UPLINK="1mbit" # 下行带宽限制(单位:kbit) DOWNLINK="1mbit" # 清除现有的 qdisc tc qdisc del dev $IFACE root 2>/dev/null tc qdisc del dev $IFACE ingress 2>/dev/null # 设置上行带宽限制 tc qdisc add dev $IFACE root handle 1: htb default 10 tc class add dev $IFACE parent 1: classid 1:1 htb rate $UPLINK tc class add dev $IFACE parent 1:1 classid 1:10 htb rate $UPLINK # 设置下行带宽限制 tc qdisc add dev $IFACE handle ffff: ingress tc filter add dev $IFACE parent ffff: protocol ip u32 match u32 0 0 police rate $DOWNLINK burst 10k drop flowid :1使用脚本
保存上述脚本为文件,例如 bandwidth_limit.sh,然后赋予执行权限:
chmod +x bandwidth_limit.sh
执行脚本以应用带宽限制:
sudo ./bandwidth_limit.sh验证设置
使用以下命令查看当前的 tc 规则:
tc qdisc show dev eth0 tc class show dev eth0移除带宽限制
如果需要移除带宽限制,可以使用以下命令:
tc qdisc del dev eth0 root tc qdisc del dev eth0 ingress
注意事项:
请根据实际情况调整脚本中的网卡名称和带宽值。
带宽单位可以是 kbit(千比特每秒)、mbit(兆比特每秒)等。
这种方法主要适用于出站流量控制。入站流量控制在某些情况下可能不太精确,因为数据包在到达 tc 之前就已经进入了系统。
对于更复杂的流量控制需求,可能需要更高级的 tc 配置或其他工具。
在生产环境中应用带宽限制时要小心,确保不会意外限制重要的网络流量。
重启后,这些设置会失效。如果需要持久化设置,可以将脚本添加到系统的启动脚本中。
通过这种方法,你可以有效地控制 CentOS 系统上特定网卡的上行和下行带宽。
网友回复