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

技术 秋水逸冰 1424395 次围观 669 次吐槽

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

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

网友最新评论 (669)

  1. 睡了一晚,睁眼就到4.9.2了~
    Leslie3年前 (2017-01-11)回复
  2. 更新内核到4.9.1,那之前安装了的bbr,需要升级吗?是否直接将本页的这些脚本再执行一遍即可以了? 谢谢!
    Leslie3年前 (2017-01-11)回复
  3. mv: cannot stat ‘shadowsocks-manyuser/shadowsocks’: No such file or directory Shadowsocks install failed! Please Email to Teddysun and contact. 大侠,用你的一键脚本安装SSR,结果出现这个提示,是debian 8 X64 ,已经开启bbr
    DD3年前 (2017-01-10)回复
    • 由于 ShadowsocksR 项目地址已经更换,所以脚本也更新了。 下载最新版的脚本来安装即可。
      秋水逸冰3年前 (2017-01-13)回复
  4. Complete! Error: /boot/grub2/grub.cfg not found, please check it. 秋大 在virpus和budgetvm都出现这个 是因为系统改动过么 centos7
    LOL3年前 (2017-01-10)回复
    • Error: /boot/grub2/grub.cfg not found, please check it. 这是什么问题,uname命令里还是3.xx,单独更新内核提示已经更新
      zenghx2年前 (2017-07-26)回复
  5. 4.9.0版有必要更新到4.9.1吗?如果要更新的话,应该怎么更新?
    无聊先生3年前 (2017-01-10)回复
  6. 无法从4.9.0升级到4.9.1 提示bbr已经开启
    greatui3年前 (2017-01-09)回复
    • 如果是 CentOS 系统,按如下命令即可升级内核: yum --enablerepo=elrepo-kernel -y install kernel-ml kernel-ml-devel CentOS 6 的话,再执行:sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf CentOS 7 的话,再执行:grub2-set-default 0 如果是 Debian/Ubuntu 系统,则需要下载最新版内核手动安装升级。 去网址:http://kernel.ubuntu.com/~kernel-ppa/mainline/ 下载最新版的内核 deb 安装包安装后,再执行:/usr/sbin/update-grub 最后一步,重启。
      秋水逸冰3年前 (2017-01-13)回复
  7. COC Centos 6.8 64可用~~~~~高兴~~~~
    omg3年前 (2017-01-09)回复
  8. CentOS 6.5 虚拟机内核升级后出现FATAL: Module scsi_wait_scan not found 解决办法: 内核升级后,重启前,执行: 1) 创建force-vitio_blk-to-ensure-boot.conf # echo 'add_drivers+="virtio_blk"' >/etc/dracut.conf.d/force-vitio_blk-to-ensure-boot.conf 2) 切换目录 # cd /boot 3) 重新编译生成initramfs # dracut -f /boot/initramfs-4.9.1-1.el6.elrepo.x86_64.img 4.9.1-1.el6.elrepo.x86_64 4) 重启 # reboot
    hawk3年前 (2017-01-09)回复
  9. 有的VPS上是这个步骤 run-parts: executing /etc/kernel/postinst.d/zz-update-grub 4.9.0-040900-generic /boot/vmlinuz-4.9.0-040900-generic Generating grub.cfg ... Found linux image: /boot/vmlinuz-4.9.0-040900-generic Found initrd image: /boot/initrd.img-4.9.0-040900-generic Found linux image: /boot/vmlinuz-3.2.0-4-amd64 Found initrd image: /boot/initrd.img-3.2.0-4-amd64 done Generating grub.cfg ... Found linux image: /boot/vmlinuz-4.9.0-040900-generic Found initrd image: /boot/initrd.img-4.9.0-040900-generic Found linux image: /boot/vmlinuz-3.2.0-4-amd64 Found initrd image: /boot/initrd.img-3.2.0-4-amd64 done 有的则-------------- run-parts: executing /etc/kernel/postinst.d/zz-extlinux 4.9.0-040900-generic /boot/vmlinuz-4.9.0-040900-generic P: Checking for EXTLINUX directory... found. P: Writing config for /boot/vmlinuz-4.9.0-040900-generic... P: Writing config for /boot/vmlinuz-3.2.0-4-amd64... P: Updating /boot/extlinux/linux.cfg... bbr.sh: line 135: update-grub: command not found
    darkradx3年前 (2017-01-08)回复
    • 这说明,在有的 VPS 上缺少 update-grub 命令。 通过 apt-get 来安装后,再次运行脚本即可。
      秋水逸冰3年前 (2017-01-09)回复
  10. 我的VPS是hostdare的,安装后也无法重启了,上面所说的配置自定义内核和引导应该如何设置?也没有找到相关文章,请问这个问题我该如何解决?
    SunZz3年前 (2017-01-08)回复
    • 不过当我把VPS断开在连接,就可以正常启动了,而且BBR也正常启动,但是一旦重启就会再次出现问题。
      SunZz3年前 (2017-01-08)回复
  11. 感謝菊苣
    殷道言3年前 (2017-01-07)回复
  12. 出现这样的错误: Error: Your VPS is based on OpenVZ, not be supported.
    小先生3年前 (2017-01-07)回复
  13. 感谢您的努力和辛苦,顺便问一下,去 北京 深信服 科技 有前途吗?在安全部,17年去工作。
    三叔3年前 (2017-01-07)回复
  14. Ramnode kvm,centos 6/7 , debian 7/8, ubuntu server 14 安装了过后都无法重启,用vnc链接进去看到一堆的看不懂的错误代码
    kkw3年前 (2017-01-06)回复
  15. BuyVM的KVM主机(Debian 7.0 32bit),装完系统启动不起来了,控制台文字重叠显示,网络不通,彻底嗝屁。只能重装系统了。
    没吃饱的熊3年前 (2017-01-06)回复
    • 遇到相同问题,安装以后无法 ping 通了。
      Michael3年前 (2017-01-12)回复