Using Orchard CLI
Installation¶
The easiest way to install Orchard CLI is through the Homebrew:
Binaries and packages for other architectures can be found in GitHub Releases.
Setting up a context¶
The first step after installing the Orchard CLI is to configure its context. Configuring context is like pairing with the specified Orchard Controller, so that the commands like orchard create vm
, orchard ssh vm
will work.
To configure a context, orchard context
has a subfamily of commands:
orchard context create <CONTROLLER ADDRESS>
— creates a new context to communicate with Orchard Controller available on the specified addressorchard context default <CONTROLLER ADDRESS>
— sets a context with a given Orchard Controller address as default (in case there's more than one context configured)orchard context list
— lists all the configured contexts, indicating the default oneorchard context delete <CONTROLLER ADDRESS>
— deletes a context for the specified Orchard Controller address
Most of the time, you'll only need the orchard context create
. For example, if you've deployed your Orchard Controller to orchard-controller.example.com
, a new context can be configured like so:
orchard context create
assumes port 6120 by default, so if you use a different port for the Orchard Controller, simply specify the port explicitly:
When creating a new context you will be prompted for the service account name and token, which can be obtained from:
orchard controller run
logs- if this is a first start
orchard get service-account
- from an already configured Orchard CLI
Using labels when creating VMs¶
Labels are useful if you want to restrict scheduling of a VM to workers whose labels include a subset of the VM's specified labels.
For example, you might have an Orchard Cluster consisting of the following workers:
- Mac Minis (
orchard worker run --labels location=DC1-R12-S4,model=macmini
) - Mac Studios (
orchard worker run --labels location=DC1-R18-S8,model=macstudio
)
To create and run a VM specifically on Mac Studio machines, pass the --labels
command-line argument to orchard create vm
when creating a VM:
When processing this VM, the scheduler will only place it on available Mac Studio workers.
Using resources when creating VMs¶
Resources are useful if you want to restrict scheduling of a VM to workers that still have enough of the specified resource to fit the VM's requirements.
The difference between the labels is that the resources are finite and are automatically accounted by the scheduler.
To illustrate this with an example, let's say you have an Orchard Cluster consisting of the following workers:
- Mac Mini with 1 Gbps bandwidth (
orchard worker run --resources bandwidth-mbps=1000
) - Mac Studio with 10 Gbps bandwidth (
orchard worker run --resources bandwidth-mbps=10000
)
VM created using the command below will only be scheduled on a Mac Studio with 10 Gbps bandwidth:
However, after this VM is scheduled, the 10 Gbps Mac Studio will only be able to accommodate one more VM (due to internal Apple EULA limit for macOS virtualization) with bandwidth-mbps=2500
or less.
After the VM finishes, the unused resources will be available again.