2020-10-20 22:11:17 +01:00
|
|
|
# balena CLI Installation Instructions for macOS
|
2020-09-16 14:53:46 +01:00
|
|
|
|
|
|
|
These instructions are for the recommended installation option. Advanced users may also be
|
|
|
|
interested in [advanced installation options](./INSTALL-ADVANCED.md).
|
|
|
|
|
|
|
|
Selected operating system: **macOS**
|
|
|
|
|
|
|
|
1. Download the installer from the [latest release
|
|
|
|
page](https://github.com/balena-io/balena-cli/releases/latest).
|
|
|
|
Look for a file name that ends with "-installer.pkg":
|
|
|
|
`balena-cli-vX.Y.Z-macOS-x64-installer.pkg`
|
|
|
|
|
|
|
|
2. Double click the downloaded file to run the installer. After the installation completes,
|
|
|
|
close and re-open any open [command
|
|
|
|
terminal](https://www.balena.io/docs/reference/cli/#choosing-a-shell-command-promptterminal)
|
|
|
|
windows (so that the changes made by the installer to the PATH environment variable can take
|
|
|
|
effect).
|
|
|
|
|
|
|
|
3. Check that the installation was successful by running the following commands on a
|
|
|
|
command terminal:
|
2020-10-20 22:11:17 +01:00
|
|
|
* `balena version` - should print the CLI's version
|
2020-09-18 15:35:36 +01:00
|
|
|
* `balena help` - should print a list of available commands
|
2020-09-16 14:53:46 +01:00
|
|
|
|
2020-10-20 22:11:17 +01:00
|
|
|
No further steps are required to run most CLI commands. The `balena ssh`, `build`, `deploy`
|
2020-09-16 14:53:46 +01:00
|
|
|
and `preload` commands may require additional software to be installed, as described below.
|
|
|
|
|
|
|
|
## Additional Dependencies
|
|
|
|
|
|
|
|
### build and deploy
|
|
|
|
|
|
|
|
These commands require [Docker](https://docs.docker.com/install/overview/) or
|
|
|
|
[balenaEngine](https://www.balena.io/engine/) to be available (on a local or remote machine). Most
|
|
|
|
users will simply follow [Docker's installation
|
|
|
|
instructions](https://docs.docker.com/install/overview/) to install Docker on the same laptop (dev
|
2020-10-20 22:11:17 +01:00
|
|
|
machine) where the balena CLI is installed. The [advanced installation
|
2020-09-16 14:53:46 +01:00
|
|
|
options](./INSTALL-ADVANCED.md) document describes other possibilities.
|
|
|
|
|
|
|
|
### balena ssh
|
|
|
|
|
|
|
|
The `balena ssh` command requires the `ssh` command-line tool to be available. To check whether
|
|
|
|
it is already installed, run `ssh` on a Terminal window. If it is not yet installed, the options
|
|
|
|
include:
|
|
|
|
|
|
|
|
* Download the Xcode Command Line Tools from https://developer.apple.com/downloads
|
|
|
|
* Or, if you have Xcode installed, open Xcode, choose Preferences → General → Downloads →
|
|
|
|
Components → Command Line Tools → Install.
|
|
|
|
* Or, install [Homebrew](https://brew.sh/), then `brew install openssh`
|
|
|
|
|
|
|
|
The `balena ssh` command also requires an SSH key to be added to your balena account: see [SSH
|
|
|
|
Access documentation](https://www.balena.io/docs/learn/manage/ssh-access/). The `balena key*`
|
|
|
|
command set can also be used to list and manage SSH keys: see `balena help -v`.
|
|
|
|
|
|
|
|
### balena preload
|
|
|
|
|
|
|
|
Like the `build` and `deploy` commands, the `preload` command requires Docker, with the additional
|
|
|
|
restriction that Docker must be installed on the local machine (because Docker's bind mounting
|
|
|
|
feature is used). Also, for some device types (such as the Raspberry Pi), the `preload` command
|
|
|
|
requires Docker to support the [AUFS storage
|
|
|
|
driver](https://docs.docker.com/storage/storagedriver/aufs-driver/). Unfortunately, Docker Desktop
|
|
|
|
for Windows dropped support for the AUFS filesystem in Docker CE versions greater than 18.06.1. The
|
|
|
|
present workaround is to either:
|
|
|
|
|
|
|
|
* Downgrade Docker Desktop to version 18.06.1. Link: [Docker CE for
|
|
|
|
Mac](https://docs.docker.com/docker-for-mac/release-notes/#docker-community-edition-18061-ce-mac73-2018-08-29)
|
2020-10-20 22:11:17 +01:00
|
|
|
* Install the balena CLI on a Linux machine (as Docker for Linux still supports AUFS). A Linux
|
|
|
|
Virtual Machine also works, but a Docker container is _not_ recommended.
|
2020-09-16 14:53:46 +01:00
|
|
|
|
|
|
|
Long term, we are working on replacing AUFS with overlay2 for the affected device types.
|