Overview Orka Cluster 3.0
What is the typical user journey with Orka? Orka offers a seamless and consistent user experience that caters to various use cases and requirements.
Time to read: 5 minutes, 22 seconds
Every Orka user has unique use cases and requirements. Whether looking to run single Xcode builds or create an automated CI/CD pipeline with daily and nightly builds, the Orka journey goes through the following simple steps.
1. Get Ready
-
Get an Orka Subscription
Contact MacStadium to discuss requirements. Based on specific use cases, the team recommends and provides the best hardware options. -
Choosing Tools
- The Orka Web UI provides a quick and user-friendly way to manage an Orka cluster. Currently, the Web UI offers limited functionality compared to the Orka3 CLI and the Orka3 API.
- The Orka3 CLI is the easiest way to start with Orka. It is perfect for both manual use and automation alike.
- To build an automated CI/CD system, look into the available Orka integrations - from Jenkins to Drone, the Orka team continuously adds to the list of supported solutions.
- The Orka3 API enables users to be tool-agnostic or to develop an in-house solution.
-
Learn Orka Terminology
Тerm | Definition |
---|---|
Cluster Also: environment | A group of nodes that represents an Orka environment. A cluster is hosted in a MacStadium data center and sits behind a Cisco firewall. To reach it, there must be an active VPN connection. |
Node | A genuine Apple physical host that provides computational resources (RAM and CPU) for workloads. A host OS runs on top, with no direct access (via VNC, SSH, or Screen Sharing). |
VM config Also: VM template | A template for an Orka virtual machine. Deploy multiple VM instances (VMs) from a single VM config. Starting with Orka 3.0.0 using VM configs is optional. |
VM Also: VM instance | VMs take up resources from nodes and require a certain amount of CPU and memory. |
Image Related: base image, empty image | A disk image that represents VM storage. Base images are bootable disk images that provide the OS, file system, and storage for the VM configs and VMs. Empty images provide added storage or serve as the base image during manual OS installs from ISO. |
ISO | (Intel-only) A disk image used exclusively to install macOS on a virtual machine. |
2. Get Set
-
Make sure the added as a user to the MacStadium Customer Portal account for your cluster.
-
Connect to your cluster via VPN. Ensure there is an up-and-running VPN connection when working with Orka.
- Get your IP Plan.
- Get a VPN client and use it to connect to your cluster using the firewall IP and credentials you obtained in the previous step.
- Keep the VPN connection to your cluster live.
-
Configure your environment. This step is a one-time effort.
- In the Orka3 CLI, run
orka3 config set --api-url <ORKA_API_URL>
. - For Orka3 API calls, target your Orka API endpoint or use the Swagger UI at
<ORKA_API_URL>/api/v1/swagger
. - For the Orka Web UI, go to
<ORKA_API_URL>
in your browser. - For CI/CD integrations, configure your Orka API URL as prompted during the setup.
- In the Orka3 CLI, run
What's your Orka API URL?
If you are an Orka Enterprise user, you can get your Orka API URL from your IP Plan:
- For clusters deployed before Orka 2.1, it's the
.100
address for yourPrivate-1
network (usually,10.221.188.100
), prefixed withhttp
. For example:http://10.221.188.100
.- For clusters deployed with Orka 2.1 or later, it's the
.20
address for yourPrivate-1
network (usually10.221.188.20
). prefixed withhttp
. For example:http://10.221.188.20
.- You can also use
https://<orka-domain>
andhttps://<custom-domain>
(if configured). To get the Orka domain for your Orka cluster, contact MacStadium. To use an external custom domain, see here.Note that you can use
http://<orka-IP>
,https://<orka-domain>
, andhttps://<custom-domain>
interchangeably in your workflows.If you are an Orka Small Teams user, you can get the Orka API URL from the How to tab for your cluster in the MacStadium Customer Portal. It's your Controller IP prefixed with
http://
. Usuallyhttp://10.221.188.20
.
-
If you want to use the Orka3 CLI, log in to your cluster and obtain an authentication token.
Your token authenticates you uniquely with Orka. This operation stores your token locally in your~/.kube/config
file.orka3 login
When prompted, provide your MacStadium Customer Portal credentials in the login form in the browser.
-
If you want to use the Orka3 API, provide the
Authorization: Bearer <TOKEN>
header in your API calls or authorize the Swagger UI at<ORKA_API_URL>/api/v1/swagger
. Use your authentication token.
In the Orka3 CLI, obtain a token by running:orka3 user get-token
-
If you want to use the Orka Web UI, log in with your authentication token.
In the Orka3 CLI, obtain a token by running:orka3 user get-token
-
For CI/CD integrations, authenticate based on the integration version.
-
If running a 2.x-compatible version, continue using your old user and password.
-
If you are running a 3.0.0-compatible version, authenticate with a dedicated service account.
orka3 sa create <SERVICE_ACCOUNT_NAME> orka3 sa token <SERVICE_ACCOUNT_NAME> [--duration <DURATION>]
curl --request POST \ --url <ORKA_API_URL>/api/v1/namespaces/{namespace}/serviceaccounts/{serviceaccount} \ --header 'Authorization: Bearer <TOKEN>' \ --header 'accept: application/json' curl --request POST \ --url <ORKA_API_URL>/api/v1/namespaces/{namespace}/serviceaccounts/{serviceaccount}/token \ --header 'Authorization: Bearer <TOKEN>' \ --header 'accept: application/json' \ --header 'content-type: application/json'
-
First Time Creating VM
NOTE: The first time a user creates a new Orka VM, a new interface called bridge 100 is configured and assigned a private IPv4 address, which is used for MacStadium Admins and management purposes. The network range used by Orka falls within 192.168.0.0/16. Users who also utilize this private IP range within their network may experience address conflict within the MacStadium VPN. Currently, Orka does not support changing the management and administration of the IPv4 network address range used. A workaround for this situation is to employ Network Address Translation (NAT), which avoids IP address conflicts within 192.168.0.0/16.
3. Go
- Deploy VMs. Deploy as many or as few as you need.
To deploy a VM, you need an image. Check what images are available locally in your cluster. Check out the remote and pull an image if the local image list is empty. Or, even better, use an image from an OCI-compatible registry. Check https://github.com/macstadium/orka-images for the latest available OCI-compatible images provided by MacStadium. The images available out-of-the-box provide a pre-configured disk size and a pre-installed OS.
(Intel-only) If you want to use a different disk size or prefer to install an OS yourself, you can go the ISO way. Create an empty image of sufficient size and attach an ISO to your VM.
- Work with your VMs.
You can connect to your VMs via VNC, SSH, or Apple Screen Sharing. Once connected, you can change the VM by installing extra software, enabling OS features, and others. For more information, see VNC, SSH, and Screen Sharing for Orka VMs.
You can preserve the changes from one VM and deploy new VMs with these exact changes. Save
or commit
your changes, or push them to a remote OCI-compatible registry, to preserve and make them available for future configs and deployments.
- (Optional) Delete unused VMs.
What's next
Choose how you want to get started with Orka.
Updated 7 days ago