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

技术 秋水逸冰 1504380 次围观 691 次吐槽

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

本脚本适用环境

系统支持:CentOS 6+,Debian 7+,Ubuntu 12+
虚拟技术:OpenVZ 以外的,比如 KVM、Xen、VMware 等
内存要求:≥128M
日期  :2018 年 12 月 14 日

关于本脚本

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

使用方法

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

wget --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh && chmod +x bbr.sh && ./bbr.sh

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

uname -r

查看内核版本,显示为最新版就表示 OK 了

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

sysctl net.ipv4.tcp_congestion_control

返回值一般为:
net.ipv4.tcp_congestion_control = bbr

sysctl net.core.default_qdisc

返回值一般为:
net.core.default_qdisc = fq

lsmod | grep bbr

返回值有 tcp_bbr 模块即说明 bbr 已启动。注意:并不是所有的 VPS 都会有此返回值,若没有也属正常。

CentOS 下最新版内核 headers 安装方法

本来打算在脚本里直接安装 kernel-ml-headers,但会出现和原版内核 headers 冲突的问题。因此在这里添加一个脚本执行完后,手动安装最新版内核 headers 之教程。
执行以下命令

yum --enablerepo=elrepo-kernel -y install kernel-ml-headers

根据 CentOS 版本的不同,此时一般会出现类似于以下的错误提示:

Error: kernel-ml-headers conflicts with kernel-headers-2.6.32-696.20.1.el6.x86_64
Error: kernel-ml-headers conflicts with kernel-headers-3.10.0-693.17.1.el7.x86_64

因此需要先卸载原版内核 headers ,然后再安装最新版内核 headers。执行命令:

yum remove kernel-headers

确认无误后,输入 y,回车开始卸载。注意,有时候这么操作还会卸载一些对内核 headers 依赖的安装包,比如 gcc、gcc-c++ 之类的。不过不要紧,我们可以在安装完最新版内核 headers 后再重新安装回来即可。
卸载完成后,再次执行上面给出的安装命令。

yum --enablerepo=elrepo-kernel -y install kernel-ml-headers

成功安装后,再把那些之前对内核 headers 依赖的安装包,比如 gcc、gcc-c++ 之类的再安装一次即可。

为什么要安装最新版内核 headers 呢?
这是因为 shadowsocks-libev 版有个 tcp fast open 功能,如果不安装的话,这个功能是无法开启的。

内核升级方法

如果是 CentOS 系统,执行如下命令即可升级内核:

yum -y install kernel-ml kernel-ml-devel

如果你还手动安装了新版内核 headers ,那么还需要以下命令来升级 headers :

yum -y install kernel-ml-headers

CentOS 6 的话,执行命令:

sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf

CentOS 7 的话,执行命令:

grub2-set-default 0

如果是 Debian/Ubuntu 系统,则需要手动下载最新版内核来安装升级。
这里下载最新版的内核 deb 安装包。
如果系统是 64 位,则下载 amd64 的 linux-image 中含有 generic 这个 deb 包;
如果系统是 32 位,则下载 i386 的 linux-image 中含有 generic 这个 deb 包;
安装的命令如下(以最新版的 64 位 4.12.4 举例而已,请替换为下载好的 deb 包):

dpkg -i linux-image-4.12.4-041204-generic_4.12.4-041204.201707271932_amd64.deb

安装完成后,再执行命令:

/usr/sbin/update-grub

最后,重启 VPS 即可。

特别说明

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

mount -o remount rw /

更新日志:

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,您需要填写昵称和邮箱!

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

网友最新评论 (691)

  1. ./bbr.sh: line 205: sysctl: command not found online的debian10好像是缺少东西
    寒夜方舟1周前 (2019-11-28)回复
    • 说明shell在当前搜索路径中找不到 sysctl 命令。 搜索路径是由冒号分隔的目录列表。用 echo $PATH 命令显示 PATH 的值,PATH 的值代表当前搜索路径。
      秋水逸冰1周前 (2019-11-28)回复
  2. 阿里云使用萌咖的网络重装开机。
    1111周前 (2019-11-28)回复
  3. 128M内存貌似用不了,安装kernel包的时候进程被kvm杀死了。虚拟内存也不行,脚本能分步执行吗?300多M内存的机器可以用没问题
    cc1周前 (2019-11-27)回复
  4. bbr2来啦,坐等大佬开发bbr2一键脚本 :roll:
    寒夜方舟2周前 (2019-11-23)回复
    • bbr2 还在 Alpha 阶段,离合并进内核为时尚早
      秋水逸冰2周前 (2019-11-23)回复
  5. 感谢 成功搭建了
    myhlovetaylorswift2周前 (2019-11-21)回复
  6. 提示这个错误怎么办? Error: /boot/grub2/grub.cfg not found, please check it.
    sypopo3周前 (2019-11-18)回复
  7. 大佬,谷歌云怎么开启内网转发啊?安装没报错,但是上不了外网
    2366523周前 (2019-11-16)回复
  8. 很奇怪,我Azure的其中一台机子用不了,提示不兼容的系统。 明明都是centos7.7.1908,怎么会有一个会说不兼容呢?
    IRAY1个月前 (2019-11-02)回复
  9. 5.3.8-1.el7.elrepo.x86_64是最新的吗
    QQ游客1个月前 (2019-11-02)回复
  10. 新用户只要做到“返回值有 tcp_bbr 模块即说明 bbr 已启动。注意:并不是所有的 VPS 都会有此返回值,若没有也属正常。”就可以了吧,后面的CentOS 下最新版内核 headers 安装方法和内核升级方法不需要制作吧?
    QQ游客1个月前 (2019-11-02)回复
  11. curl: (7) Failed connect to www.elrepo.org:443; Connection timed out error: https://www.elrepo.org/RPM-GPG-KEY-elrepo.org: import read failed(2). curl: (7) Failed connect to www.elrepo.org:443; Connection timed out error: skipping https://www.elrepo.org/elrepo-release-7.0-4.el7.elrepo.noarch.rpm - transfer failed Retrieving https://www.elrepo.org/elrepo-release-7.0-4.el7.elrepo.noarch.rpm Error: Install elrepo failed, please check it. 这种情况是elrepo.org的问题吗? 换时间再试?
    Excalibur2个月前 (2019-10-10)回复
  12. 秋大能兼容Centos8吗
    llopod2个月前 (2019-10-04)回复
    • CentOS 8 的默认内核是 4.18,已经大于 4.9,因此不会安装更新的内核,而是直接开启 BBR
      秋水逸冰2个月前 (2019-10-05)回复
  13. 博主有兴趣做个BBR v2的一件脚本吗?
    anon3个月前 (2019-09-20)回复
    • BBR v2 还在 Alpha/Preview 阶段……现在用还为时尚早吧
      秋水逸冰3个月前 (2019-09-20)回复
      • 确实,我现在经常遇到掉速的情况,没有BBR v1稳定。
        anon3个月前 (2019-09-20)回复
  14. 水哥,这个脚本使用的是谷歌原版bbr吗
    Jack Smith4个月前 (2019-08-18)回复
    • 对的,集成在内核里的原版 bbr
      秋水逸冰4个月前 (2019-08-19)回复
      • 终于又可以访问了这个网站了,最近都烦死了一直被封
        1232个月前 (2019-10-01)回复