14

ARM Mac: Why I'm Worried About Virtualization

 4 years ago
source link: https://bmalehorn.com/arm-mac/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

It's late 2020 and you just got a brand-new Mac with Apple's own ARM processors. Exciting! But what will development be like?

Docker

iyaIJbA.png!web

I would expect about a 5x slowdown running Docker images.

Docker on a Mac utilizes a hypervisor . Hypervisors rely on running the same architecture on the host as the guest , and are about about 1x - 2x as slow as running natively.

Since you're running ARM Mac, these hypervisors can only run ARM Linux. They can't run x86_64 Linux.

What will happen instead? These tools will fall back on emulators . Emulators can run a different architecture between the host and the guest , but simulate the guest operating system at about 5x-10x slowdown.

ueyeMv6.png!web

A basic performance test comparing gzip performance on amd64 (hypervisor) and arm64v8 (emulator). Note that the emulator is over 6x slower. On an ARM Mac, the amd64 image will instead be 6x slower.

Why can't you update the Docker image to also support ARM? You theoretically could switch your backend to run ARM Linux. However, this would take months - renting out ARM instances, re-building all repositories, and a tense switch over. Worse, it might be impossible if your images include files downloaded off the internet, as those are often only compiled for x86_64. Getting a new laptop isn't enough justification to switch you backend architecture.

fY7FnuU.png!web

An example of a Docker command that will only work on x86_64. PhantomJS does not release an arm build.

Another option is to run Docker remotely . You set up an x86_64 Linux server, then allow Docker to connect to it remotely. From then on, all Docker commands instead run on the server. This is also supported in Docker, here is a tutorial on setting it up. This is what heavy Docker users will want to do.

VirtualBox

36zymqA.png!web

VirtualBox won't work.

VirtualBox is a hypervisor . Therefore, it won't be able to run x86 Windows or x86 Linux .

You could use VirtualBox to run ARM Windows. Windows already supports ARM, and has a similar binary translation system to Apple's, so it can run x86 binaries. However, VirtualBox only supports x86 hosts and guests and is unlikely to be ported by ARM .

VMWare Fusion similarly is a hypervisor that only support x86, but they're thinking about supporting ARM .

Instead of VirtualBox you might use QEMU, an emulator. However, QEMU is pretty low level and not often used to emulate Windows.

Boot Camp

qAr6z2b.png!web

Boot Camp won't work.

Boot Camp is an Apple-approved way to dual-boot Mac OS and Windows. Boot Camp will not be available on ARM Macs. It might be added later with the ability to run ARM Windows, though Microsoft would have to approve .

Should I get an ARM Mac?

The point of this post isn't to say that ARM Mac is a bad idea, but to give a realistic idea of what it will be like developing on one.

Should you get an ARM Mac if you're a developer? if you use virtualization often, I wouldn't recommend it. There will be a lot of problems early on, and not all of them will have solutions. My biggest concern is getting an ARM Mac and realizing I simply can't run an essential application on it.

However if you like troubleshooting these issues and are excited about ARM Mac, go for it! My plan is for those kinds of people to fix these issues.

Know something I don't? Have questions? Email me at [email protected] .


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK