Easily Boost Ubuntu Network Performance by Enabling TCP BBR

This tutorial shows you how to enable TCP BBR on Ubuntu. TCP BBR is a TCP congestion control algorithm developed by Google. It tackles shortcomings of traditional TCP congestion control algorithms (Reno or CUBIC). According to Google, it can achieve orders of magnitude higher bandwidth and lower latency. TCP BBR is already being used on Google.com, YouTube and Google Cloud Platform and the Internet Engineering Task Force (IETF) has been standardizing this algorithm Since July, 2017. BBR stands for Bottleneck Bandwidth and RTT.

BBR requires only changes on the sender side. You can enable TCP BBR on your Linux desktop to improve overall web surfing experience. If you have a Linux web server, TCP BBR can achieve faster web page downloads for your website visitors.

Step 1: Check TCP Congestion Control Algorithms on Linux

By default, Linux uses the Reno and CUBIC congestion control algorithm. To check available congestion control algorithms, run the following command.

sysctl net.ipv4.tcp_available_congestion_control


net.ipv4.tcp_available_congestion_control = cubic reno

To check the current congestion control algorithm in use, run

sysctl net.ipv4.tcp_congestion_control


net.ipv4.tcp_congestion_control = cubic

Step 2: Install Linux Kernel 4.9 or Above

TCP BBR is supported by Linux since kernel version 4.9. Use the following command to check your Linux kernel version.

uname -r

Ubuntu 18.04 has kernel 4.13.


It’s very easy to install Linux kernel 4.10 on Ubuntu 16.04. You don’t have to manually download the kernel from Ubuntu website. Simply install the Hardware Enablement Stack (HWE), which provides newer kernel for Ubuntu LTS releases.

sudo apt update

sudo apt install --install-recommends linux-generic-hwe-16.04

Your VPS provider may use a custom Linux kernel instead of the Ubuntu-provided kernel. If you use Linode VPS, then you need to go to Linode VPS control penal, edit your configuration profile.

bbr ubuntu

In Boot Settings, set kernel to GRUB2.

enable bbr ubuntu

Save your changes. Then reboot to use the new 4.10 kernel.

sudo shutdown -r now

Step 3: Enable TCP BBR in Ubuntu

Once you have kernel 4.9 or above, edit sysctl.conf file.

sudo nano /etc/sysctl.conf

Add the following two lines at the end of the file.


ubuntu tcp bbr

Save and close the file. Then reload sysctl configurations.

sudo sysctl -p

If you have correctly added the above two lines in the file, then they will be included in the output like below.

[email protected]:~$ sudo sysctl -p
net.core.default_qdisc = fq
net.ipv4.tcp_congestion_control = bbr

Now check the congestion control algorithm in use.

sysctl net.ipv4.tcp_congestion_control


net.ipv4.tcp_congestion_control = bbr

Congrats! You have successfully enabled TCP BBR on Ubuntu.

Speed Improvements

I used Shadowsocks proxy on a low-end VPS to test TCP BBR. The speed improvement is huge. The following screenshot shows YouTube connection speed before enabling TCP BBR on my proxy server. As you can see, the speed is only around 400Kb/s (50KB/s).

enable TCP BBR on Ubuntu 16.04

This is YouTube connection speed after enabling TCP BBR on my proxy server. 9878 Kb/s is about 1234 KB/s. My proxy server just got 24 times faster!

enable google tcp bbr ubuntu

On a second Shadowsocks proxy server, the speed went from around 10Mbit/s to around 62Mbit/s (64172Kbit/s) after enabling TCP BBR.

TCP BBR performance boost

Don’t disable TCP Window Scaling

You might need to disable TCP window scaling in order to fix a problem, but doing so can greatly reduce the network performance. Add the following line in /etc/sysctl.conf file to enable TCP window scaling.

net.ipv4.tcp_window_scaling = 1

Then apply the changes.

sudo sysctl -p

That’s it! I hope this tutorial helped you enable TCP BBR on Ubuntu. As always, if you found this post useful, then subscribe to our free newsletter to get more useful tips and tricks.

Rate this tutorial
[Total: 27 Average: 4.3]

9 Responses to “Easily Boost Ubuntu Network Performance by Enabling TCP BBR

  • MrAdminus
    3 years ago

    You should write a little notice on Linuxtoday so more people get to know about your blog. I think what you’re doing is great and contributes to the Linux community. It’s free to write a post there too and many Linux users reads it!

  • Greya Being
    3 years ago

    How do I undo this?

  • Sayyed Alireza
    3 years ago

    Best Blog website ever

    thanks for being born :*

  • Michael
    2 years ago

    Thank you for this little gem! So easy to do too 🙂

  • Hi
    I have tried to enable it but my output is different from yours. Below is the output from my system

    [email protected]:~$ sysctl net.ipv4.tcp_available_congestion_control
    net.ipv4.tcp_available_congestion_control = reno cubic
    [email protected]:~$ sysctl net.ipv4.tcp_congestion_control
    net.ipv4.tcp_congestion_control = cubic
    [email protected]:~$ sudo nano /etc/sysctl.conf
    [sudo] password for jieru:
    [email protected]:~$ sudo sysctl -p
    [email protected]:~$ sysctl net.ipv4.tcp_congestion_control
    net.ipv4.tcp_congestion_control = cubic

    • /etc/sysctl.conf

      If you have correctly added the above two lines in the file, then they will be included in the output like below when you run sudo sysctl -p.

      [email protected]:~$ sudo sysctl -p
      net.core.default_qdisc = fq
      net.ipv4.tcp_congestion_control = bbr
      • Hi
        Here is the updated outputs

        [email protected]:~$ sudo cat /boot/config-$(uname -r) | grep 'CONFIG_TCP_CONG_BBR'
        [sudo] password for jieru:           
        [email protected]:~$ sudo cat /boot/config-$(uname -r) | grep 'CONFIG_NET_SCH_FQ'
        [email protected]:~$ sudo nano /etc/sysctl.conf
        [email protected]:~$ sudo sysctl --system
        * Applying /etc/sysctl.d/10-console-messages.conf ...
        kernel.printk = 4 4 1 7
        * Applying /etc/sysctl.d/10-ipv6-privacy.conf ...
        net.ipv6.conf.all.use_tempaddr = 2
        net.ipv6.conf.default.use_tempaddr = 2
        * Applying /etc/sysctl.d/10-kernel-hardening.conf ...
        kernel.kptr_restrict = 1
        * Applying /etc/sysctl.d/10-link-restrictions.conf ...
        fs.protected_hardlinks = 1
        fs.protected_symlinks = 1
        * Applying /etc/sysctl.d/10-magic-sysrq.conf ...
        kernel.sysrq = 176
        * Applying /etc/sysctl.d/10-network-security.conf ...
        net.ipv4.conf.default.rp_filter = 2
        net.ipv4.conf.all.rp_filter = 2
        * Applying /etc/sysctl.d/10-ptrace.conf ...
        kernel.yama.ptrace_scope = 1
        * Applying /etc/sysctl.d/10-zeropage.conf ...
        vm.mmap_min_addr = 65536
        * Applying /usr/lib/sysctl.d/50-coredump.conf ...
        kernel.core_pattern = |/lib/systemd/systemd-coredump %P %u %g %s %t 9223372036854775808 %h
        * Applying /usr/lib/sysctl.d/50-default.conf ...
        net.ipv4.conf.default.promote_secondaries = 1
        sysctl: setting key "net.ipv4.conf.all.promote_secondaries": Invalid argument
        net.ipv4.ping_group_range = 0 2147483647
        net.core.default_qdisc = fq_codel
        fs.protected_regular = 1
        fs.protected_fifos = 1
        * Applying /usr/lib/sysctl.d/50-mint.conf ...
        fs.inotify.max_user_watches = 65536
        * Applying /usr/lib/sysctl.d/50-pid-max.conf ...
        kernel.pid_max = 4194304
        * Applying /etc/sysctl.d/99-sysctl.conf ...
        net.core.default_qdisc = fq
        net.ipv4.tcp_congestion_control = bbr
        * Applying /usr/lib/sysctl.d/protect-links.conf ...
        fs.protected_fifos = 1
        fs.protected_hardlinks = 1
        fs.protected_regular = 2
        fs.protected_symlinks = 1
        * Applying /etc/sysctl.conf ...
        net.core.default_qdisc = fq
        net.ipv4.tcp_congestion_control = bbr
        [email protected]:~$ sysctl net.ipv4.tcp_congestion_control
        net.ipv4.tcp_congestion_control = bbr
        [email protected]:~$ 

        Is everything correct?


    • Yes. it’s correct.

Leave a Comment

  • Comments with links are moderated by admin before published.
  • Your email address will not be published.
  • Use <pre> ... </pre> HTML tag to quote the output from your terminal/console.
  • Please use the community (https://community.linuxbabe.com) for questions unrelated to this article.
  • I don't have time to answer every question. Making a donation would incentivize me to spend more time answering questions.

The maximum upload file size: 2 MB. You can upload: image. Links to YouTube, Facebook, Twitter and other services inserted in the comment text will be automatically embedded. Drop file here