Interested in a formal Proof-Of-Concept of EC2 Mac instances? Awesome!
Here's some tips from our experiences - please feel free to open an issue or even submit a PR if you'd like to add yours!
- Determine PoC duration and timing, ensuring all team members have schedule availability to put towards evaluing EC2 Mac.
- Determine success criteria, what you'd like to see from EC2 Mac compared to existing systems. Depending on the length of the PoC, these may include interim milestones.
- Schedule cadence calls and/or email reports with the larger team to discuss progress and any concerns that may arise.
- To your AWS Account Team: Confirm the AWS account ID and region you would like to use for the POC. AWS will ensure the account’s soft quota limit in that region is sized for your PoC and beyond.
- To your AWS Account Team: Confirm the potential capacity (number of EC2 Mac instances) needed in which regions for the PoC - and for any production workloads post-PoC. AWS would like to capture this to drive EC2 Mac capacity planning across our global regions and on-going expansion.
- Review example workflows from EC2 Mac SMEs at AWS, our partners, and our customers.
- Identify Regions and AZs for PoC, and communicate those to your AWS Account Team.
- Identify macOS version(s) and Xcode version(s) needed
- Identify CI/CD tooling needed (Jenkins, Fastlane,, Terraform, Buildkite, etc)
- Identify size (in GB) and throughput (in IOPs) of boot volume needed
- Start with our vended AMI, configure as necessary, then create a derivative AMI (alternatively, use Packer)
- Determine any dynamic configuration needed via ec2-macos-init
- Allocate host(s), launch instance(s), and test it out!
- Percentage change in build speed, build performance, number of build failures, and number of parallel builds
- Percentage of your macOS compute that needs to be always-on 24/7 or 24/5 vs percentage of your macOS compute that consists of burst capacity whenever the need arises These observations will drive a possible reduction in the number of Macs you would need with EC2 Mac. For example, we have customers reporting up to 4x improvement in build performance, up to 3x increase in parallel builds, and up to 80% reduction in build failures, and these results increase developer productivity, operational efficiency, and more efficient usage of macOS compute.
After every stop/terminate of EC2 Mac instances, we run a scrubbing workflow that sanitizes the internal SSD, clears NVRAM variables, and optionally updates the bridgeOS on the underlying Mac mini’s T2 chip (on x86 instances) or firmware (on Apple silicon instances) if needed. This ensures that EC2 Mac instances have the same security bar as other Nitro instances. In addition, you don’t need to worry about keeping firmware up-to-date to run the latest macOS AMIs. During this scrubbing process, the EC2 Mac Dedicated Host itself goes into a pending state, and can take 40-65 minutes to complete (or ~3 hours if bridgeOS update is required). You can view the newest versions of macOS an EC2 Mac host is able to run based on its firmware on the AWS console or via command line aws ec2 describe-hosts
.
During this scrubbing period, when the Dedicated Host goes into pending state – AWS metering and billing stops, and you aren't charged for that duration. (The pending state does count towards the 24-hour minimum allocation time, however.)