Software networking with isolation for Tart
Go to file
Nikolay Edigaryev 717e6b0f89
Increase the default bootpd(8) lease time from 1 to 10 minutes (#8)
2022-10-21 19:09:18 +04:00
lib Allow host communication (#7) 2022-08-12 17:50:10 +03:00
src Increase the default bootpd(8) lease time from 1 to 10 minutes (#8) 2022-10-21 19:09:18 +04:00
.cirrus.yml Release on Homebrew using GoReleaser (#5) 2022-06-21 20:56:57 +03:00
.gitignore Initial revision of Softnet, a software networking for Tart 2022-06-10 16:53:03 +03:00
.goreleaser.yml Release on Homebrew using GoReleaser (#5) 2022-06-21 20:56:57 +03:00
Cargo.lock Initial revision of Softnet, a software networking for Tart 2022-06-10 16:53:03 +03:00
Cargo.toml Initial revision of Softnet, a software networking for Tart 2022-06-10 16:53:03 +03:00
LICENSE License under AGPL-3.0 (#4) 2022-06-21 15:59:35 +03:00
README.md README.md: clarify installation instructions a bit 2022-10-13 18:30:30 +04:00

README.md

Softnet

Softnet is a software networking for Tart which provides better network isolation and alleviates DHCP shortage on production systems.

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 --with-softnet flag is present when calling tart run.