一键安装最新内核并开启 BBR 脚本

技术 秋水逸冰 2789638浏览 717评论

最近,Google 开源了其 TCP BBR 拥塞控制算法,并提交到了 Linux 内核,从 4.9 开始,Linux 内核已经用上了该算法。根据以往的传统,Google 总是先在自家的生产环境上线运用后,才会将代码开源,此次也不例外。
根据实地测试,在部署了最新版内核并开启了 TCP BBR 的机器上,网速甚至可以提升好几个数量级。
于是我根据目前三大发行版的最新内核,开发了一键安装最新内核并开启 TCP BBR 脚本。

本脚本适用环境

系统支持:CentOS 6+,Debian 8+,Ubuntu 16+
虚拟技术:OpenVZ 以外的,比如 KVM、Xen、VMware
内存要求:≥128M
日期  :2022 年 5 月 11 日

关于本脚本

1、本脚本已在 Vultr 上的 VPS 全部测试通过。
2、当脚本检测到 VPS 的虚拟方式为 OpenVZ 时,会提示错误,并自动退出安装。
3、脚本运行完重启发现开不了机的,打开 VPS 后台控制面板的 VNC, 开机卡在 grub 引导, 手动选择内核即可。
4、由于是使用最新版系统内核,最好请勿在生产环境安装,以免产生不可预测之后果。

使用方法

使用root用户登录,运行以下命令:

wget --no-check-certificate -O /opt/bbr.sh https://github.com/teddysun/across/raw/master/bbr.sh
chmod 755 /opt/bbr.sh
/opt/bbr.sh

安装完成后,脚本会提示需要重启 VPS,输入 y 并回车后重启。
重启完成后,进入 VPS,验证一下是否成功安装最新内核并开启 TCP BBR,输入以下检查:
No.1

uname -r

查看内核版本,显示为新版内核就表示 OK 了。
No.2

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

No.3

sysctl net.ipv4.tcp_congestion_control

返回值一般为:

net.ipv4.tcp_congestion_control = bbr

No.4

sysctl net.core.default_qdisc

返回值一般为:

net.core.default_qdisc = fq

No.5

lsmod | grep bbr

返回值有 tcp_bbr 模块即说明 bbr 已启动。比如:

tcp_bbr                20480  3

注意:并不是所有的 VPS 都会有此返回值,若没有也属正常。

特别说明

如果你使用的是 Google Cloud Platform (GCP)更换内核,有时会遇到重启后,整个磁盘变为只读的情况。只需执行以下命令即可恢复:

mount -o remount rw /

 

更新日志:

2021 年 5 月 11 日:
1、在 CentOS 7 下更改为安装 5.15.38 版本内核;
2、精简在 Debian 和 Ubuntu 下的可选内核版本,从 5.15 起始到当前最新版结束。

2021 年 1 月 3 日:
1、为了稳定性,在 CentOS 7 下更改 elrepo-kernel 为 centos-release-xen-48,并升级安装 4.9 版稳定内核;
2、在 CentOS 6 和 CentOS 8 下不再安装 elrepo-kernel。原因:CentOS 6 是通过 rpm 安装 4.18.20;CentOS 8 则无需升级内核即可开启 BBR。
3、精简在 Debian 和 Ubuntu 下的可选内核版本,从 5.9 起始到当前最新版结束。

2020 年 6 月 23 日:
1、重构了代码,去除一些不必要的处理;
2、精简在 Debian 和 Ubuntu 下的可选内核版本,从 5.6 起始到当前最新版结束。

2018 年 12 月 14 日:
1、修正:在 CentOS 6 系统下 kernel-ml 及 kernel-ml-devel 无法安装的问题。原因是 elrepo 官方最近取消了 kernel-ml 及 kernel-ml-devel 的 rpm 资源。脚本已改为下载 rpm 来安装的方式。版本 4.18.20 将会是 CentOS 6 下最新的内核,目测以后也不会再有升级了,请尽快迁移到 CentOS 7 系统。

2018 年 06 月 09 日:
1、修正:在 CentOS 系统下将 elrepo-kernel 默认启用,以解决在安装新内核后执行 yum update 再次安装旧内核的问题。

2018 年 05 月 12 日:
1、修正:在 Ubuntu 或 Debian 系统中某些情况下获取不到某个编译失败的安装包导致退出安装的问题。并且现在可以手动选择安装从 4.14 到最新版本的内核。

2018 年 02 月 24 日:
1、新增:手动安装最新版内核 headers 的教程。

2017 年 10 月 28 日:
1、更新:自动判断内核版本。如果内核版本已经大于或等于 4.9 且没有开启 BBR,脚本会直接设置好 BBR;
2、新增:脚本执行时会在当前目录下创建日志(install_bbr.log),方便查看及排错。

2017 年 02 月 22 日:
1、更新:自动获取最新版 4.10 内核。

2017 年 01 月 20 日:
1、新增:自动获取并下载安装最新版内核的功能。

2017 年 01 月 13 日:
1、更新:内核到 4.9.3。

2017 年 01 月 09 日:
1、更新:内核到 4.9.1。

参考链接:

https://github.com/google/bbr/blob/master/Documentation/bbr-quick-start.md
http://elrepo.org/tiki/tiki-index.php
http://kernel.ubuntu.com/~kernel-ppa/mainline/

转载请注明:秋水逸冰 » 一键安装最新内核并开启 BBR 脚本

发表我的评论
取消评论

请输入正确答案后提交评论 *超出时限。 请再次填写验证码。

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

网友最新评论 (717)

  1. 你好,博主,请问下debian的安装这个脚本后提示,已经安装了bbr,内核是4.9.0.30,请问这样是默认安装了不用再设置什么了吧。
    w9196年前(2018-09-19)回复
    • 是的,内核大于等于 4.9 即可开启 BBR,无需升级到最新的内核。
      秋水逸冰6年前(2018-09-23)回复
  2. 你的网站给墙了?翻墙才看得到。。。。
    小智6年前(2018-08-29)回复
  3. 为什么我升级了内核,Package kernel-ml-devel-4.18.3-1.el6.elrepo.x86_64 already installed and latest version Nothing to do 可是用uname -r查看还是4.17.14呢?这样到底有没有升级成功?谢谢指教
    bmw13986年前(2018-08-21)回复
    • 按照教程,CentOS 6 还需执行一下以下命令,调整一下启动内核顺序。 sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf
      秋水逸冰6年前(2018-08-23)回复
  4. 我按你的教程安装成功了BBR,现在想升级BBR版本,要用什么命令?谢谢指教
    bmw13986年前(2018-08-21)回复
  5. online杜甫,用了脚本安装restart后就开不了机了,和楼下的有点像,前几天KS杜甫还刚用过,没问题~~~
    se7en6年前(2018-08-11)回复
    • centos 7.5
      se7en6年前(2018-08-11)回复
    • 脚本运行完重启发现开不了机的各位兄弟,可以看看“逗比根据地 » 『原创』Debian/Ubuntu TCP拥塞控制技术 ——TCP-BBR 一键安装脚本”https://doub.io/wlzy-16/这篇文章,估计大家和我一样在中间删除旧内核的那步操作中弹出的对话框选择了“yes”,应该要选择“no”~
      jameslxj6年前(2018-09-04)回复
  6. 脚本运行完重启发现开不了机的,打开 VPS 后台控制面板的 VNC, 开机卡在 grub 引导, 手动选择内核即可 这个应该怎么操作呢,我照着教程做完后,就连接不上vps了。
    Nelighty6年前(2018-08-07)回复
  7. 你好。用的谷歌GCP。实例选的ubuntu 16.04 和18.04 都无法安装您的bbr脚本。8月5号还能用,虽然显示内核高于4.9. 但返回正常reno cubic bbr。youtube速度120000kbps 。 8月6号就直接不能装了。显示内核高于4.9直接设置bbr。但是实际8月5号,返回还能显示 reno cubic bbr。 8月6号返回,只有reno cubic bbr了。实际youtube测试速度,8月5号。还是120000kbps。现在只有40000kbps了。 求教。谢谢。
    halcyon6年前(2018-08-06)回复
    • 内核≥4.9的时候就直接设置 bbr 了,不会更新内核。显示的返回值里有 bbr 就说明已经开启了,跟显示出来的顺序无关。 还有就是速度的问题,跟上网时段也有关系。
      秋水逸冰6年前(2018-08-06)回复
      • 不好意思,问题写错了。很尴尬。 简单说,8月5,你的脚本还能装。8月6不能装。不知道为什么。 同样都是4.9以上内核。8月5,返回有bbr,满速。8月6返回没有bbr。速度也很低。 后来自己用命令解决了,返回有bbr了,速度也对了。 不过,还是谢谢回复。
        halcyon6年前(2018-08-07)回复
  8. 连接挂了
    chaorenna6年前(2018-08-01)回复
  9. 阿里云国际版 UBUNTU和DEBIAN都出现下面的情况 进入不了 CENTOS就没有问题 [ 0.504447] Kernel panic — not syncing: VFS: Unable to mount root fs on unknown-block(0,0) [ 0.505338] CPU: 0 PID: 1 Conm: swapper/0 Not tainted 4.17.11—041711—generic #201807280505 [ 0.506153] Hardware name: Alibaba Cloud Alibaba Cloud ECS, BIOS rel—1 .7 .5—0—ge51488c—20140602_164612—nilsson.home.kraxel.org 04/01/2014 [ 0.507361] Call Trace: [ 0.507604] dump_stack +0x63/0x83 [ 0.507920] panic+Oxe7/0x247 [ 0.508262] mount_block_root +0x231/0x2d8 [ 0.508638] ? do_early_param+0x95/0x95 [ 0.508995] mount_root+Ox7c/Ox7f [ 0.509372] prepare_namespace+0x139/Ox171 [ 0.509753] kernel_init_freeab le+0x236/0x261 [ 0.510172] ? rest_in it0xb0/0xb0 [ 0.510532] kernel_initOxe/0x109 [ 0.510853] ret_from_fork +0x35/0x40 [ 0.513719] Kernel Offset: Ox12c00000 from Oxffffffff81000000 (relocation range: Oxffffffff80000000—Oxffffffffbfffffff) [ 0.514821] ———[ end Kernel panic — not syncing: VFS: Unable to mount root fs on unknown—block(0,0) ]———
    哈哈和6年前(2018-08-01)回复
  10. 大佬的好东西,用很久了。 前来回复表支持!
    Yoodi6年前(2018-07-25)回复
  11. dpkg -i linux-image-unsigned-4.17.9-041709-generic_4.17.9-041709.201807221110_amd64.deb dpkg: error: cannot access archive 'linux-image-unsigned-4.17.9-041709-generic_4.17.9-041709.201807221110_amd64.deb': No such file or directory
    Color丶6年前(2018-07-23)回复
  12. 为什么谷歌的用这个最新版的,直接登不上ssh
    Color丶6年前(2018-07-22)回复
  13. 最新版在谷歌云里装了,退出就登录不了SSH
    Color6年前(2018-07-22)回复
  14. 我安装了bbr 速度还是一般 我看有的人100兆宽带快跑满了 怎么搞的?
    星星6年前(2018-07-11)回复
  15. Debian 8 重启直接挂掉了,安装时选最新的内核,试好好几个小鸡都一样,比如DO…
    Bdosn6年前(2018-07-08)回复