Orchestrator for running Tart Virtual Machines on a cluster of Apple Silicon devices
Go to file
Nikolay Edigaryev af074f499d
Remove UID for now and use machine ID to differentiate workers (#48)
* Remove UID for now and use machine ID to differentiate workers

* Rename MetadataWorkerKey back to MetadataWorkerNameKey
2023-03-23 23:38:54 +04:00
api Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
cmd/orchard Initial version of the Orchard orchestration system (#3) 2023-01-26 23:46:23 +04:00
internal Remove UID for now and use machine ID to differentiate workers (#48) 2023-03-23 23:38:54 +04:00
pkg Remove UID for now and use machine ID to differentiate workers (#48) 2023-03-23 23:38:54 +04:00
rpc Remove UID for now and use machine ID to differentiate workers (#48) 2023-03-23 23:38:54 +04:00
.cirrus.star Use golangci-lint (#15) 2023-01-31 22:22:28 +04:00
.cirrus.yml Prepare for release (#37) 2023-03-20 15:28:24 -04:00
.gitignore Better state syncing and other improvements (#24) 2023-03-01 11:42:16 -05:00
.golangci.yml Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
.goreleaser.yml Prepare for release (#37) 2023-03-20 15:28:24 -04:00
Dockerfile Consolidate controller bootstrap login in `run` command (#38) 2023-03-21 15:36:55 -04:00
LICENSE Prepare for release (#37) 2023-03-20 15:28:24 -04:00
README.md Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
buf.gen.yaml Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
buf.work.yaml Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
buf.yaml Port forwarding support (#30) 2023-03-14 11:31:13 -04:00
go.mod Remove UID for now and use machine ID to differentiate workers (#48) 2023-03-23 23:38:54 +04:00
go.sum Remove UID for now and use machine ID to differentiate workers (#48) 2023-03-23 23:38:54 +04:00

README.md

Orchard

Orchard is an orchestration system for Tart.

Create a cluster of bare-metal Apple Silicon machines and manage dozens of VMs with ease!

Installation

go install github.com/cirruslabs/orchard/...@latest

Quick start

Start the Orchard Controller and the Worker in a single inocation:

orchard dev

Create a Virtual Machine resource:

orchard create vm --image ghcr.io/cirruslabs/macos-ventura-base:latest ventura-base

Check a list of VM resources to see if the Virtual Machine we've created above is already running:

orchard list vms

Development

Development is done as one would normally develop any Golang package, however, if you did modify any *.proto files in the rpc/ directory, install Buf and run the following command from the project's root directory to re-generate the code:

buf generate