安装BBR教程,来加速VPS

查看: 3.4K|回复: 0
1
tetepay 发表于 2024-3-10 19:54:48
安装BBR教程,来加速VPS


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

根据目前三大发行版的最新内核,一键安装最新内核并开启 TCP BBR 脚本。

个人建议最好不要使用脚本,就几行命令,手动安装不会出错,使用脚本出错概率大,当然懒人除外!

适用环境

系统支持:CentOS7.1+,Debian 7+,Ubuntu 12+

虚拟技术:OpenVZ 以外的,比如 KVM、Xen、VMware 等

内存要求:≥128M

关于脚本

1、本脚本已在 各大厂商上的 VPS 全部测试通过。

2、当脚本检测到 VPS 的虚拟方式为 OpenVZ 时,会提示错误,并自动退出安装。

3、脚本运行完重启发现开不了机的,打开 VPS 后台控制面板的 VNC, 开机卡在 grub 引导, 手动选择内核即可。

4、由于是使用最新版系统内核,最好请勿在生产环境安装,以免产生不可预测之后果。

安装方法

安装前请务必关闭 SELINUX,

使用 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,输入以下命令:

输入:

lsmod | grep bbr

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

CentOS 7.4+ 手动安装方法
安装前请务必关闭 SELINUX,

查看系统版本

cat /etc/redhat-release

输出如下(release 数值大于 7.4 即可)

CentOS Linux release 7.6.1810 (Core)

导入 elrepo 软件源的 GPG 公钥

rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org

更新下配置重启

reboot

导入 elrepo 软件源(该地址可以自动下载该源的最新的软件列表,无需修改地址)

rpm -Uvh https://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm

在 ELRepo中有两个内核选项,一个是kernel-lt(长期支持版),一个是 kernel-ml(主线最新版本),采用长期支持版本(kernel-lt),更加稳定一些

yum -y --enablerepo=elrepo-kernel install kernel-ml //主线最新版本
yum -y --enablerepo=elrepo-kernel install kernel-lt //长期支持版


设定 Grub 默认启动新内核,查看所有的 entry:

awk -F \' '$1=="menuentry " {print i++ " : " $2}' /etc/grub2.cfg

0 : CentOS Linux 7 Rescue be01194033634997b76c097ab3d668ed (4.20.0-1.el7.elrepo.x86_64)
1 : CentOS Linux (4.20.0-1.el7.elrepo.x86_64) 7 (Core)
2 : CentOS Linux (3.10.0-693.11.6.el7.x86_64) 7 (Core)
3 : CentOS Linux (3.10.0-693.el7.x86_64) 7 (Core)
4 : CentOS Linux (0-rescue-00a62363617944e08db8db894ba6145e) 7 (Core)

配置方法

1、通过 grub2-set-default 命令设置
查看当前 default 的 entry

grub2-editenv list

saved_entry=CentOS Linux (3.10.0-693.11.6.el7.x86_64) 7 (Core)
修改为指定的 entry,指定最新内核,然后查看指定内核为:saved_entry=1

grub2-set-default 1
grub2-editenv list


2、编辑 /etc/default/grub 文件
(第一种方式无法修改内核再用这种方式修改)

设置 GRUB_DEFAULT=1,通过上面查询显示的编号为 1 的内核作为默认内核:

GRUB_TIMEOUT=5
GRUB_DISTRIBUTOR=”( s e d ‘ s , r e l e a s e . ∗ (sed ‘s, release .*(sed‘s,release.∗,g’ /etc/system-release)”
GRUB_DEFAULT=1
GRUB_DISABLE_SUBMENU=true
GRUB_TERMINAL=”serial console”
GRUB_TERMINAL_OUTPUT=”serial console”
GRUB_CMDLINE_LINUX=”crashkernel=auto console=ttyS0 console=tty0 panic=5 net.ifnames=0 biosdevname=0 intel_idle.max_cstate=1 intel_pstate=disable”
GRUB_DISABLE_RECOVERY=”true”
GRUB_SERIAL_COMMAND=”serial –speed=9600 –unit=0 –word=8 –parity=no –stop=1″

生成 grub 配置文件

grub2-mkconfig -o /boot/grub2/grub.cfg

Generating grub configuration file …
Found linux image: /boot/vmlinuz-5.8.14-1.el7.elrepo.x86_64
Found initrd image: /boot/initramfs-5.8.14-1.el7.elrepo.x86_64.img
Found linux image: /boot/vmlinuz-3.10.0-1062.18.1.el7.x86_64
Found initrd image: /boot/initramfs-3.10.0-1062.18.1.el7.x86_64.img
Found linux image: /boot/vmlinuz-0-rescue-0ea734564f9a4e2881b866b82d679dfc
Found initrd image: /boot/initramfs-0-rescue-0ea734564f9a4e2881b866b82d679dfc.img
Found linux image: /boot/vmlinuz-0-rescue-d4a7825ac1094e6a9184b6379c189521
Found initrd image: /boot/initramfs-0-rescue-d4a7825ac1094e6a9184b6379c189521.img

衔接第一、二种方式
使用新的内核重启

reboot

检查设置,删除旧的内核,查看当前系统的内核版本号

uname -r

如果输出是 4.10 以上的版本,说明安装成功。

4.20.0-1.el7.elrepo.x86_64

删除旧内核(删除旧内核的目的是为了防止 yum 更新旧版内核之后覆盖了 grub 默认启动项)

yum -y remove kernel kernel-tools

如果名称不匹配就是商家修改过内核名称,先查询一下系统已安装的内核

rpm -qa | grep kernel

然后再删除旧内核

yum remove -y 旧内核的名

开启 bbr,如果你不会用 vim 命令的话可以使用 SFTP 工具修改简单

vim /etc/sysctl.conf

添加如下内容

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


加载系统参数(正常情况下会输出我们之前加入的内容)

sysctl -p

验证 bbr 是否已经开启

sysctl net.ipv4.tcp_available_congestion_control

返回 :net.ipv4.tcp_available_congestion_control = bbr cubic reno 则成功

再验证 bbr

lsmod | grep bbr

返回形如有 bbr 即成功。

tcp_bbr 16384 1

tcp_bbr 20480 0

安装其他服务前重启下

reboot

提醒

提示如下报错:curl: (35) SSL connect error 解决方法:升级网络安全服务即可

yum update nss

原文链接:https://blog.csdn.net/u012241616/article/details/136606703
9000多个源码 www.httple.net
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于本站联系我们FAQ友情链接免责声明生存法则

Build with for "make" Copyright © 2020-2022. Powered by Discuz! GMT+8, 2024-4-28 19:05

快速回复 返回顶部 返回列表