fruition / mac-dev-shim
A performance and DX shim for Mac OS users utilizing docker-compose.
Installs: 17
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 0
Open Issues: 0
pkg:composer/fruition/mac-dev-shim
Requires
- php: ^7.2
- symfony/filesystem: ^5.0
- symfony/finder: ^5.0
- symfony/yaml: ^5.0
This package is auto-updated.
Last update: 2022-08-14 23:28:57 UTC
README
About this package: Do I need this?
Motivation
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.
Mac OS and bind-mount filesystem performance
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.
What this package does
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.
Installation
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.
Install/Transition to Docker Desktop for Mac
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.
NFS debugging
- Use showmount -eto 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 checkexportsand read carefully for errors.
- Use ps -ef | grep nfsdto 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 restartand read the messages carefully.
Shim debugging
To view the "combined" compose file Yaml, run docker-compose config.
Usage
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 and Licenses.
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.