TCP BBR(Bottleneck Bandwidth and Round-trip propagation time)是由Google设计,于2016年发布的拥塞算法。以往大部分拥塞算法是基于丢包来作为降低传输速率的信号,而BBR则基于模型主动探测。该算法使用网络最近出站数据分组当时的最大带宽和往返时间来创建网络的显式模型。数据包传输的每个累积或选择性确认用于生成记录在数据包传输过程和确认返回期间的时间内所传送数据量的采样率。该算法认为随着网络接口控制器逐渐进入千兆速度时,分组丢失不应该被认为是识别拥塞的主要决定因素,所以基于模型的拥塞控制算法能有更高的吞吐量和更低的延迟,可以用BBR来替代其他流行的拥塞算法,例如CUBIC。Google在YouTube上应用该算法,将全球平均的YouTube网络吞吐量提高了4%,在一些国家超过了14%。

总而言之,TCP BBR是谷歌出品的TCP拥塞控制算法,可以起到单边网络加速的作用,特别是对于延迟较高,有丢包的链路。从Linux Kernel 4.9起,就加入了该算法,但是CentOS7默认的内核还停留在3.10.0,想要享受BBR带来的加成,必须更新内核才可以。

升级内核

查看当前内核版本:uname -r
如果大于4.9可以直接进行下一步,不过你想要更新版本的内核可以继续。
为了更新内核,我们需要增加一个 ELRepo 源。
添加 ELRepo GPG key:
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
添加 ELRepo 源:
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-2.el7.elrepo.noarch.rpm
为了获取最快镜像,可以安装fastestmirror插件:
yum install yum-plugin-fastestmirror
现在就可以安装安装最新Kernel了:
yum --enablerepo=elrepo-kernel install kernel-ml
等待安装完成后,切换至刚安装好的新版内核:
grub2-set-default 0
重启之后,可以通过uname -r查看当前内核版本,应该是高于4.9的。

切换为BBR算法

/etc/sysctl.conf加入以下内容:

net.core.default_qdisc=fq
net.ipv4.tcp_congestion_control=bbr

使设置生效:sysctl -p
查看是否成功设置:

sysctl net.ipv4.tcp_available_congestion_control #查看可以用的拥塞控制算法
sysctl net.ipv.tcp_congestion_control #查看现在使用的拥塞控制算法

两个返回值都应包含bbr
检查BBR是否运行:lsmod | grep tcp_bbr
返回值有tcp_bbr即可

现在,BBR算法就生效了,享受它带来的提升吧。

注意事项

值得注意的是,OpenVZ架构的VPS无法直接使用BBR算法。但办法还是有的,只要善用搜索引擎。
还有,BBR不是魔法,无法突破物理带宽限制。