Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Slow work during testing on VM #352

Open
grishy opened this issue Jul 8, 2023 · 17 comments
Open

Slow work during testing on VM #352

grishy opened this issue Jul 8, 2023 · 17 comments

Comments

@grishy
Copy link

grishy commented Jul 8, 2023

Hi 👋

I wanted to add mDNS support for wireguard and decided to take userspace module for it. But during the test I found the strange thing that the bandwidth dropped a lot and the ping increased in boringtun. This does not happen when switching to kernel or Go implementation (just switch WG_QUICK_USERSPACE_IMPLEMENTATION).

The latest version is used as mentioned in the README. This appeared after some time of testing. In the beginning everything was fine. As you can see the CPU is not busy.

Untitled
vagrant@wgserver:~$ boringtun-cli -V
boringtun 0.6.0

vagrant@wgserver:~$ rustup -V
rustup 1.26.0 (5af9b9484 2023-04-05)
info: This is the version for the rustup toolchain manager, not the rustc compiler.
info: The currently active `rustc` version is `rustc 1.70.0 (90c541806 2023-05-31)`

vagrant@wgserver:~$ hostnamectl
 Static hostname: wgserver
 Pretty hostname: wg_server
       Icon name: computer-vm
         Chassis: vm 🖴
      Machine ID: 794e8af11ca343c3ac86176f4506a03e
         Boot ID: 5c51191b3166487ea3d9dad3aa1ec591
  Virtualization: oracle
Operating System: Ubuntu 23.04
          Kernel: Linux 6.2.0-24-generic
    Architecture: x86-64
 Hardware Vendor: innotek GmbH
  Hardware Model: VirtualBox
Firmware Version: VirtualBox

P.S. Maybe I should also mention in the README that WG_QUICK_USERSPACE_IMPLEMENTATION parameter doesn't work without fixes because it doesn't go into basic mode inside if

~ Sergei

@grishy
Copy link
Author

grishy commented Jul 8, 2023

If you know how to debug this and its interesting , I will be glad to hear :)
(I am not a Rust professional)

@grishy
Copy link
Author

grishy commented Jul 8, 2023

I tested with a remote server (one of VM - cloud VM) and got the same results

@Noah-Kennedy
Copy link
Collaborator

Noah-Kennedy commented Jul 8, 2023

Interesting!

Can you walk through the different versions and see if this is a regression?

@Noah-Kennedy
Copy link
Collaborator

The cli used to just be boringtun, before we split the crates.

@grishy
Copy link
Author

grishy commented Jul 8, 2023

I will try it again in the cloud and if it works, I will write 👍

@grishy
Copy link
Author

grishy commented Jul 8, 2023

On clean new env same speed BUT now we have 100% CPU. Just same, one core. Load not from iperf side, because in load less 1%. By kernel I guess.

P.S. Kernel and wg-go OK

Also OS version is different + kernel 5.15:

> hostnamectl
 Static hostname: server
       Icon name: computer-vm
         Chassis: vm
      Machine ID: bfa83f0910c74cd0b5936a1ec423c924
         Boot ID: 9701f19ae2814bb5ae25d01104db086a
  Virtualization: microsoft
Operating System: Ubuntu 22.04.2 LTS
          Kernel: Linux 5.15.0-76-generic
    Architecture: x86-64
 Hardware Vendor: Red Hat
  Hardware Model: KVM
image image

@grishy
Copy link
Author

grishy commented Jul 8, 2023

v0.5.2 - have a problem during installation.

cargo install [email protected]

Output:

...many errors...
...
error[E0412]: cannot find type `StaticSecret` in crate `x25519_dalek`
   --> /root/.cargo/registry/src/index.crates.io-6f17d22bba15001f/boringtun-0.5.2/src/noise/mod.rs:295:39
    |
295 |         static_private: x25519_dalek::StaticSecret,
    |                                       ^^^^^^^^^^^^ help: a struct with a similar name exists: `SharedSecret`
    |
   ::: /root/.cargo/registry/src/index.crates.io-6f17d22bba15001f/x25519-dalek-2.0.0-rc.3/src/x25519.rs:275:1
    |
275 | pub struct SharedSecret(pub(crate) MontgomeryPoint);
    | ----------------------- similarly named struct `SharedSecret` defined here

error[E0412]: cannot find type `StaticSecret` in crate `x25519_dalek`
   --> /root/.cargo/registry/src/index.crates.io-6f17d22bba15001f/boringtun-0.5.2/src/noise/mod.rs:331:39
    |
331 |         static_private: x25519_dalek::StaticSecret,
    |                                       ^^^^^^^^^^^^ help: a struct with a similar name exists: `SharedSecret`
    |
   ::: /root/.cargo/registry/src/index.crates.io-6f17d22bba15001f/x25519-dalek-2.0.0-rc.3/src/x25519.rs:275:1
    |
275 | pub struct SharedSecret(pub(crate) MontgomeryPoint);
    | ----------------------- similarly named struct `SharedSecret` defined here

Some errors have detailed explanations: E0412, E0433.
For more information about an error, try `rustc --explain E0412`.
error: could not compile `boringtun` (lib) due to 13 previous errors
error: failed to compile `boringtun-cli v0.5.2`, intermediate artifacts can be found at `/tmp/cargo-installqRD3Ni`

@grishy
Copy link
Author

grishy commented Jul 8, 2023

@Noah-Kennedy can you try to reproduce it?

@Noah-Kennedy
Copy link
Collaborator

Noah-Kennedy commented Jul 8, 2023

Ignore v0.5.2, I need to yank it and put out a patch release due to an issue with how cargo resolves release candidate semver.

@Noah-Kennedy
Copy link
Collaborator

I've posted v0.5.3 now

@grishy
Copy link
Author

grishy commented Jul 9, 2023

Do we have CLI for v0.5.3?

> cargo install [email protected]
    Updating crates.io index
error: there is nothing to install in `boringtun v0.5.3`, because it has no binaries
`cargo install` is only for installing programs, and can't be used with libraries.
To use a library crate, add it as a dependency to a Cargo project with `cargo add`.

@grishy
Copy link
Author

grishy commented Jul 9, 2023

I built from source - works great! Same servers as before.

sudo WG_QUICK_USERSPACE_IMPLEMENTATION=/root/boringtun/target/release/boringtun-cli WG_SUDO=1 wg-quick up wg0
> iperf3 -s
-----------------------------------------------------------
Server listening on 5201
-----------------------------------------------------------
Accepted connection from 10.8.0.2, port 39806
[  5] local 10.8.0.1 port 5201 connected to 10.8.0.2 port 39812
[ ID] Interval           Transfer     Bitrate
[  5]   0.00-1.00   sec  21.0 MBytes   176 Mbits/sec
[  5]   1.00-2.00   sec  23.1 MBytes   194 Mbits/sec
[  5]   2.00-3.00   sec  22.3 MBytes   187 Mbits/sec
[  5]   3.00-4.00   sec  21.7 MBytes   182 Mbits/sec
[  5]   4.00-5.00   sec  21.9 MBytes   184 Mbits/sec
[  5]   5.00-6.00   sec  21.3 MBytes   178 Mbits/sec
[  5]   6.00-7.00   sec  22.7 MBytes   191 Mbits/sec
[  5]   7.00-8.00   sec  23.1 MBytes   194 Mbits/sec
[  5]   8.00-9.00   sec  21.3 MBytes   179 Mbits/sec
[  5]   9.00-10.00  sec  21.8 MBytes   183 Mbits/sec
[  5]  10.00-10.04  sec   942 KBytes   177 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval           Transfer     Bitrate
[  5]   0.00-10.04  sec   221 MBytes   185 Mbits/sec                  receiver
-----------------------------------------------------------
Server listening on 5201
-----------------------------------------------------------

image

Without WG:

> iperf3 -s
-----------------------------------------------------------
Server listening on 5201
-----------------------------------------------------------
Accepted connection from 10.8.0.2, port 32888
[  5] local 10.8.0.1 port 5201 connected to 10.8.0.2 port 32894
[ ID] Interval           Transfer     Bitrate
[  5]   0.00-1.00   sec  21.1 MBytes   177 Mbits/sec
[  5]   1.00-2.00   sec  24.0 MBytes   201 Mbits/sec
[  5]   2.00-3.00   sec  22.7 MBytes   190 Mbits/sec
[  5]   3.00-4.00   sec  25.0 MBytes   210 Mbits/sec
[  5]   4.00-5.00   sec  24.3 MBytes   204 Mbits/sec
[  5]   5.00-6.00   sec  23.9 MBytes   201 Mbits/sec
[  5]   6.00-7.00   sec  24.1 MBytes   202 Mbits/sec
[  5]   7.00-8.00   sec  22.6 MBytes   189 Mbits/sec
[  5]   8.00-9.00   sec  21.2 MBytes   178 Mbits/sec
[  5]   9.00-10.00  sec  23.3 MBytes   196 Mbits/sec
[  5]  10.00-10.05  sec  1017 KBytes   181 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval           Transfer     Bitrate
[  5]   0.00-10.05  sec   233 MBytes   195 Mbits/sec                  receiver
-----------------------------------------------------------
Server listening on 5201
-----------------------------------------------------------

@grishy
Copy link
Author

grishy commented Jul 9, 2023

So it's OK in v0.5.2

@Noah-Kennedy
Copy link
Collaborator

Do we have CLI for v0.5.3?

> cargo install [email protected]
    Updating crates.io index
error: there is nothing to install in `boringtun v0.5.3`, because it has no binaries
`cargo install` is only for installing programs, and can't be used with libraries.
To use a library crate, add it as a dependency to a Cargo project with `cargo add`.

Oh, sorry, I should have mentioned, I pushed up a new library version, the cli will just use 0.5.3 since its the latest matching that semver.

@Noah-Kennedy
Copy link
Collaborator

So it's OK in v0.5.2

Interesting, I'll have a look at what changed

@r7vme
Copy link

r7vme commented Sep 15, 2023

I have similar issue with v0.6.0. With v0.6.0 I get 8.23 Mbits/sec vs v0.5.2 with ~ 1.10 Gbits/sec. Running on x84_64 KVM VMs with Ubuntu 22.04 (5.15.0-83-generic).

@grishy
Copy link
Author

grishy commented Nov 3, 2023

@Noah-Kennedy ping me if you want to recheck it with fixes 🙂

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants