TCP BBR(Bottleneck Bandwidth and Round-trip propagation time)是由Google设计,于2016年发布的拥塞算法。以往大部分拥塞算法是基于丢包来作为降低传输速率的信号,而BBR则基于模型主动探测。该算法使用网络最近出站数据分组当时的最大带宽和往返时间来创建网络的显式模型。数据包传输的每个累积或选择性确认用于生成记录在数据包传输过程和确认返回期间的时间内所传送数据量的采样率。
Google在YouTube上应用该算法,将全球平均的YouTube网络吞吐量提高了4%,在一些国家超过了14%。根据实地测试,在部署了最新版内核并开启了 TCP BBR 的机器上,网速甚至可以提升好几个数量级。
从 4.9 开始,Linux 内核已经用上了该算法,并且对于QUIC可用。如果想在Linux使用BBR,那么首先就是判断内核版本是否大于4.9,如果符合版本标准,那么直接启动BBR就可以了,如果低于4.9,升级内核之后启动就行了。
下面就介绍一下在CentOS 7.3上安装TCP BBR的方法
查看系统版本
cat /etc/redhat-release
查看现在的内核
uname -r
先下载内核
https://elrepo.org/linux/kernel/el7/x86_64/RPMS/
下载地址好多, 我是顺便找的一个
wget https://elrepo.org/linux/kernel/el7/x86_64/RPMS/kernel-ml-5.13.2-1.el7.elrepo.x86_64.rpm --no-check-certificate
安装
yum install kernel-ml-5.13.2-1.el7.elrepo.x86_64.rpm -y
查看一下内核启动顺序
awk -F\' '$1=="menuentry " {print $2}' /etc/grub2.cfg
设置启动顺序
grub2-set-default 0
重启CentOS
reboot
快速开启BBR加速
因为内核是4.9.x或以上, 那么可以直接开启
echo "net.core.default_qdisc=fq" >> /etc/sysctl.conf
echo "net.ipv4.tcp_congestion_control=bbr" >> /etc/sysctl.conf
然后使其生效
sysctl -p
验证bbr是否已经开启
A,验证当前TCP控制算法的命令:
sysctl net.ipv4.tcp_available_congestion_control
返回值一般为:net.ipv4.tcp_available_congestion_control = bbr cubic reno 或者为:net.ipv4.tcp_available_congestion_control = reno cubic bbr
B,验证BBR是否已经启动。
sysctl net.ipv4.tcp_congestion_control
返回值一般为:net.ipv4.tcp_congestion_control = bbr
lsmod | grep bbr
返回值有 tcp_bbr 模块即说明 bbr 已启动。
其他相关命令
显示所有内核
rpm -qa | grep kernel
删除指定内核
yum remove kernel-ml-4.19.0-1.el7.elrepo.x86_64