Software networking with isolation for Tart
Go to file
fedor a540299219 fixed build 2024-03-07 07:25:01 -05:00
lib fixed build 2024-03-07 07:25:01 -05:00
src Added a way to enable host-only networking through tart using --net-host (#32) 2024-03-01 11:25:19 -05:00
.cirrus.yml Build for `x86_64` (#28) 2024-01-24 15:23:04 +04:00
.gitignore Goreleaser Fix (#30) 2024-01-24 19:09:59 +04:00
.goreleaser.yml Goreleaser Fix (#30) 2024-01-24 19:09:59 +04:00
Cargo.lock Fix unaligned read by switching from unmaintained users crate (#26) 2023-09-12 06:59:02 -04:00
Cargo.toml Fix unaligned read by switching from unmaintained users crate (#26) 2023-09-12 06:59:02 -04:00
LICENSE License under AGPL-3.0 (#4) 2022-06-21 15:59:35 +03:00
README.md Add link to the blog post (#25) 2023-05-05 03:19:40 +04:00
rust-toolchain Switch back to nightly toolchain (#16) 2022-12-14 23:18:24 +04:00

README.md

Softnet

Softnet is a software networking for Tart which provides better network isolation and alleviates DHCP shortage on production systems. Please check out this blog post for backstory.

Working model

Softnet solves two problems:

  1. VM network isolation
  1. DHCP exhaustion
  • macOS built-in DHCP-server allocates a /24 subnet with 86400 seconds lease time by default, which only allows for ~253 VMs a day (or 1 VM every ~6 minutes) to be spawned without causing a denial-of-service, which is pretty limiting for CI services like Cirrus CI

And assumes that:

  1. Tart gives it's VMs unique MAC-addresses
  2. macOS built-in DHCP-server won't re-use the IP-addresses from it's pool until their lease expire

...otherwise it's possible for two VMs to receive an identical IP-address from the macOS built-in DHCP-server (even in the presence of Softnet's packet filtering) and thus bypass the protections offered by Softnet.

Installing

For proper functioning, Softnet binary requires two things:

  • a SUID-bit to be set on the binary or a passwordless sudo to be configured, which effectively gives the binary root privileges
    • these privileges are needed to create vmnet.framework interface and perform DHCP-related system tweaks
    • the privileges will be dropped automatically to that of the calling user (or those represented by the --user and --group command-line arguments) once all of the initialization is completed
  • the binary to be available in PATH
    • so that the Tart will be able to find it

Running

Softnet is started and managed automatically by Tart if --net-softnet flag is provided when calling tart run.