实验环境如下
$ uname -a
Linux host.localdomain 3.10.0-514.el7.x86_64 #1 SMP Tue Nov 22 16:42:41 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux
$ cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)
$ whoami
root
习惯性的更新一下系统
$ yum clean all
$ yum makecache
$ yum update -y
$ shutdown -r now
BBR (Bottleneck Bandwidth and RTT
) 是一种新的拥塞控制算法,由Google开发,供Linux内核的TCP协议栈使用,有了BBR算法,Linux服务器可以显著提高吞吐量并减少连接延迟。
要使用BBR,需要将CentOS 7
机器的内核升级到4.x.x
或者更新,使用elrepo RPM存储库轻松完成该操作。
当前的内核为3.10.x
$ uname -r
3.10.0-957.1.3.el7.x86_64
$ rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
$ rpm -Uvh https://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
$ yum --enablerepo=elrepo-kernel install kernel-ml -y
$ rpm -qa | grep kernel
kernel-tools-3.10.0-957.1.3.el7.x86_64
kernel-tools-libs-3.10.0-957.1.3.el7.x86_64
kernel-3.10.0-957.1.3.el7.x86_64
kernel-ml-4.19.9-1.el7.elrepo.x86_64
kernel-3.10.0-514.el7.x86_64
如上的内核版本kernel-ml-4.19.9-1.el7.elrepo.x86_64
就是我们安装成功的。
显示grub2菜单中的所有条目
$ egrep ^menuentry /etc/grub2.cfg | cut -f 2 -d \'
CentOS Linux (4.19.9-1.el7.elrepo.x86_64) 7 (Core)
CentOS Linux 7 Rescue 766d6a9cbb4ccb4cffa665fbc544c2bb (3.10.0-957.1.3.el7.x86_64)
CentOS Linux (3.10.0-957.1.3.el7.x86_64) 7 (Core)
CentOS Linux (3.10.0-514.el7.x86_64) 7 (Core)
CentOS Linux (0-rescue-bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb) 7 (Core)
新内核4.19.9
位于第一行,因此将默认引导条目设置为0:
$ grub2-set-default 0
接着重启系统
$ shutdown -r now
重启之后通过uname -r
指令你会发现新内核已经是我们安装的4.19.9
这个版本
$ uname -r
4.19.9-1.el7.elrepo.x86_64
要启用BBR算法,您需要修改sysctl配置,如下所示:
$ echo 'net.core.default_qdisc=fq' | sudo tee -a /etc/sysctl.conf
net.core.default_qdisc=fq
$ echo 'net.ipv4.tcp_congestion_control=bbr' | sudo tee -a /etc/sysctl.conf
net.ipv4.tcp_congestion_control=bbr
$ sysctl -p
net.ipv4.neigh.default.base_reachable_time_ms = 600000
net.ipv4.neigh.default.mcast_solicit = 20
net.ipv4.neigh.default.retrans_time_ms = 250
net.core.default_qdisc = fq
net.ipv4.tcp_congestion_control = bbr
查看如下命令的返回结果是否与我一直
$ sysctl net.ipv4.tcp_available_congestion_control
# 输出
net.ipv4.tcp_available_congestion_control = reno cubic bbr
$ sysctl -n net.ipv4.tcp_congestion_control
# 输出
bbr
检查内核模块是否已加载
$ lsmod | grep bbr
# 输出类似于
tcp_bbr 20480 1
请自行了解何为SS(shadowsock)。
$ wget -P /etc/yum.repos.d/ https://copr.fedoraproject.org/coprs/librehat/shadowsocks/repo/epel-7/librehat-shadowsocks-epel-7.repo
$ yum update
$ yum install shadowsocks-libev
如果安装报类似如下错误
Error: Package: shadowsocks-libev-3.1.3-1.el7.centos.x86_64 (librehat-shadowsocks)
Requires: libsodium >= 1.0.4
Error: Package: shadowsocks-libev-3.1.3-1.el7.centos.x86_64 (librehat-shadowsocks)
Requires: mbedtls
说明系统没有启用EPEL,那么我们需要首先启用EPEL,再安装shadowsocks-libev
$ yum remove epel-release -y
$ yum install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
$ yum install -y shadowsocks-libev
修改配置文件
$ vi /etc/shadowsocks-libev/config.json
{
"server": "0.0.0.0",
"server_port": 8388,
"password": "blog.ansheng.me",
"timeout": 60,
"method": "aes-256-cfb"
}
启动并设置开机自启动
$ systemctl enable --now shadowsocks-libev
查看运行状态
$ systemctl status shadowsocks-libev
请确保服务器已经安装了docker
$ docker run --name=ss --restart=always -e METHOD=<method> -e PASSWORD=<password> -p<server-port>:8388 -p<server-port>:8388/udp -d shadowsocks/shadowsocks-libev