Trellis supports most of Vagrant's common providers (opens new window) automatically. By default we recommend VirtualBox since it's free and open source. However, if you prefer some of the commercial products like VMWare or Parallels, feel free to use them.
This main exception here is for developers on Macs with Apple Silicon (M1) chips. Because these are ARM-based CPUs, VirtualBox won't work; it's limited to x86 CPUs like Intel and AMD.
# Parallels (Apple Silicon (M1) Macs)
Currently Parallels is the best solution for running virtual machines on Apple Silicon based Macs. Unfortunately, Parallels is a paid and commercial product unlike VirtualBox. Parallels Pro is required as well which has a yearly subscription price of $99 USD.
If you'd like to support Roots, please purchase Parallels Pro through our affiliate link (opens new window)
- Purchase Parallels Pro
- Install Parallels
- Install the Vagrant provider:
vagrant plugin install vagrant-parallels
See the Parallels site (opens new window) for more details.
As of January 2022, the Vagrant box needs to changed as well since the default one doesn't support Ubuntu for ARM yet.
Update the following two settings in
vagrant_box: 'jeffnoxon/ubuntu-20.04-arm64' vagrant_box_version: '>= 1.0.0'
Follow the GitHub issue (opens new window) for updates and discussion.
Vagrantfile directly should be avoided unless necessary. Instead,
you can easily set common settings in
To make local overrides, create a
vagrant.local.yml file with any overrides
you want. Note: this file is Git ignored.
Vagrantfile in this project can be kept in this folder or moved anywhere else such as a project/site folder. Generally, if you want to have multiple sites on 1 Vagrant VM, you should keep the
Vagrantfile where it is (in the trellis dir). If you want to have 1 Vagrant VM per project/site, you should make copies of the
Vagrantfile and put them into each project's dir. You'd then run
vagrant up from the project-specific directory.
For more NFS details and troubleshooting, see the official Vagrant docs (opens new window).