前言
一般而言,在云计算商那里“租”了一台服务器之后,我一般会选择
CentOS 7
系统,所以这篇文章,就以CentOS为例(似乎有一点标题党的嫌疑?
基本不会介绍BBR的原理,需要详细了解,可以访问research,我技术并不够优秀,很难解释清楚,还请见谅!
先讲讲BBR吧!Wiki百科给出的解释是Bottleneck Bandwidth and Round-trip propagation time (BBR)
,是Google在2016年开发的TCP拥塞控制算法(开源了)。TCP拥塞控制算法有很多,BBR是其中一种,但是由于它出色的效果,被很多人采用。至于linux内核什么时候开始原生支持的,网上的说法真的是五花八门,很多人文章感觉就是互相抄,连2.6.*
的说法都能蹦出来(我怀疑是一些采集站)。相对而言,很多大佬的博客文章,就比较严谨一些,基本上都是4.9
。抱着不懂就差的态度,我去Google稍微搜了一下,不敢确定是不是一定是对的。Wiki百科的详细说明,可以找到如下一条说明:
内核 | 初始发行日期 | 最新版本 | 维护者 | 支持状态 | 备注 |
---|---|---|---|---|---|
4.9 | 2016年12月11日 | 4.9.148 | 葛雷格·克罗哈曼 | 长期支持版本,从2016年12月至2023年1月 | 开始支持 BBR congestion control。 |
更换/更新内核
这时候我们来更换内核吧,这里我的测试机器是中国香港ECS。
- 当前的 Kernel 版本
$ uname -r
- 更新软件包
$ yum update -y
ELRepo项目
这里我们需要用到Repo项目Enterprise Linux软件包的RPM存储库。
- 导入ELRepo公钥
$ rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
- 安装ELRepo的 yum 源到系统
$ yum install https://www.elrepo.org/elrepo-release-7.0-4.el7.elrepo.noarch.rpm
安装新内核啦
- 查看ELRepo仓库下,在当前系统支持的内核包 ELRepo会提供he Linux Kernel Archives用资源。
$ yum --disablerepo="*" --enablerepo="elrepo-kernel" list available
- 安装最新的主线稳定内核
$ yum --enablerepo=elrepo-kernel install kernel-ml
更改grub配置
在安装完新的 Kernrl 之后,系统是不会帮你切换到新内核的,重启也不行,需要我们自己设置,将新内核设置为默认启动选项。
- 查看所有的 Kernel
$ rpm -qa | grep kernel
- 查看当前正在使用的 Kernrl
$ uname -r
- 查看 Kernel 启动顺序
$ awk -F' '$1=="menuentry " {print i " : " $2}' /etc/grub2.cfg
我们可以看到,安装完之后,内核没有切换过去,通过查看得知,新安装的内核位于第一个位置,标记为 0
。这是我们需要修改/etc/default/grub
文件,以便于让系统在启动时让新内核成为默认选项。
$ vim /etc/default/grub
需要把图中的GRUB_DEFAULT=saved
改成 GRUB_DEFAULT=0
,然后保存。当然,你也可以在安装其它版本的Kernel之后,更改GRUB_DEFAULT
的值。
- 重新生成 Kernrl 配置
$ grub2-mkconfig -o /boot/grub2/grub.cfg
- 然后重启机器
$ reboot
- 重启完毕后,检查是否成功
$ uname -r
可以看到,已经成功啦!
删除多余内核
你可以在安装新内核之后,选择把其它内核删掉,但是请注意千万不要删除正在运行的那个内核!!!
- 查看所有的 Kernel
$ rpm -qa | grep kernel
- 删除你想删除的内核
$ yum remove kernel-[old_kernel_version]
# 举个例子
$ yum remove kernel-3.10.0-957.el7.x86_64
- 重新生成 Kernrl 配置
$ grub2-mkconfig -o /boot/grub2/grub.cfg
开启BBR
整了这么半天,除了更新下内核,另一个重要的事情就是需要开启BBR了。
- 编辑
/tec/sysctl.conf
文件
$ vim /etc/sysctl.conf
- 添加如下内容:
net.core.default_qdisc=fq
net.ipv4.tcp_congestion_control=bbr
- 或者使用tee命令重定向追加到
/tec/sysctl.conf
文件中:
$ echo 'net.core.default_qdisc=fq' | sudo tee -a /etc/sysctl.conf
$ echo 'net.ipv4.tcp_congestion_control=bbr' | sudo tee -a /etc/sysctl.conf
- 从配置文件“/etc/sysctl.conf”加载内核参数设置
$ sysctl -p
- 验证是否成功(是否开启了BBR
$ sysctl net.ipv4.tcp_congestion_control
# 显示如下内容即可:
# net.ipv4.tcp_congestion_control = bbr
$ sysctl net.ipv4.tcp_available_congestion_control
# 显示如下内容即可:
# net.ipv4.tcp_available_congestion_control = reno cubic bbr
- 查看内核模块是否加载
$ lsmod | grep bbr
到这里,基本上就成功了!
最后
其实大家觉得这样很麻烦,也可以去网上找一键脚本。但是我觉得这并不是很好的习惯,不能对脚本产生过度依赖,除非你是买一台vps小鸡当玩具玩,否则千万不要用脚本,更不要在生产环境用这种一键脚本。很多人连一键脚本的内容都没瞟一眼,在搜索引擎找到后,直接就运行,造成重启后开不了机的,也大有人在! 我不是说不能用所谓的一键脚本,我也经常用。我的观点是,不应该对一键脚本产生过度依赖,同时尽量不要在生产环境用! 如果可以,也可以看一看哪些写的比较好的脚本,多研究研究也是不错的,“先懂后懒”嘛!
注:如果文章中的超链接没出现,可以点击阅读原文去找超链接!!!
*版权声明:版权归作者本人所有,尊重原创,推送文章除非无法确认,都会注明作者和来源。如果出处有误或侵犯到原作者权益,实属无心之举,请务必与我联系删除或授权事宜。本公众号所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处