Fruition has standardized local development on to a "native" Docker workflow with docker-compose
; that is, we intend
as much as possible to run the same images locally as in production, and in doing so avoid the unavoidable environment
disparity when using various "Docker Plus" solutions such as Lando, DDEV, Docksal and others. This is not to disparage
these other tools - as they have their utility and are employed successfully by many users - but a more native workflow
is best suited toward our needs. Many of the above tools utilize docker-compose
under the hood, anyway, and add
various syntactic and runtime sugar to enhance user experience.
As explained well elsewhere, bind-mount performance in Docker
for Mac is, well, so poor as to border unusable. Using the cached
or delegated
options for such mounts help improve
performance marginally, however our developers have found it to remain unacceptable for daily use.
Sean Handley,
Jeff Geerling and others have
described methods to configure and use NFS mounts with docker-compose
, and DDEV-local
includes automatic NFS mount configuration as part of its Mac OS
localization. However, the former approaches require manual configuration for every project, and the latter is fully
integrated into a heavier toolchain than we wish to employ.
This package exists to provide a wrapper around docker-compose
invocation to create and utilize a Docker Compose
override file to utilize NFS instead
of bind-mounts, and provide simple tooling to perform one-time NFS setup.
Fruition is a PHP shop and as such we assume our developers have PHP and composer
installed locally at a minimum.
This package uses the Symfony Yaml component and thus must be installed using Composer. Beyond this packaging,
the shim must only be available in a known location that can be added to the developer's PATH
to be selected by the
shell ahead of of the globally-installed docker-compose
executable. This could be done per project with
direnv, or (simplest way) by including your global composer bin
directory, per below.
If you haven't already, install Docker Desktop For Mac. If you
previously used Docker Toolbox, follow the instructions for transitioning. The Docker installer for Mac OS includes
docker-compose
.
Install the shim with Composer:
composer global require fruition/mac-dev-shim
Add (if you haven't already) the following to your ~/.bash_profile
(if using Bash, which is the Mac OS X default):
PATH="$HOME/.composer/vendor/bin:$PATH"
You will need to restart your Terminal session for the new value to work.
- Use
showmount -e
to find out what is exported via NFS. If you don't see a parent of your project directory in there, then NFS can't work. - If nothing is showing, use
nfsd checkexports
and read carefully for errors. - Use
ps -ef | grep nfsd
to make sure nfsd is running. - Restart nfsd with
sudo nfsd restart
- Run Console.app and put "nfsd" in the search box at the top.
sudo nfsd restart
and read the messages carefully.
To view the "combined" compose file Yaml, run docker-compose config
.
After installing, call docker-compose
as usual.
The shim additionally sets the HOST_OS
environment variable to Darwin
if your application is sensitive to the use
of NFS; e.g., chown operations (which will be rejected by the NFS server.)
Copyright 2020 Fruition Growth LLC. MIT licensed.
Some components incorporated and licensed from:
- DDEV-local: Apache 2.0 license. See incorporated files for list of modifications.