Geranos is a command-line tool written in Go for efficiently transferring macOS virtual machine images to and from OCI-compliant container registries. Specifically designed for macOS VMs utilizing the APFS Copy-on-Write filesystem, Geranos optimizes both bandwidth and disk usage by leveraging sparse files and filesystem cloning capabilities.
Geranos integrates seamlessly with Curie, a macOS VM virtualization program, allowing users to pull VM images and run them with minimal effort.
- Efficient Transfer of Large VM Images: Handles VM images typically over 30GB in size.
- Bandwidth Optimization: Verifies local hashes in
disk.img
files to minimize data transfer. - Disk Usage Optimization: Utilizes clone operations for efficient cloning and skips writing zeros to save disk space.
- Integration with Curie: Easily pull VM images with Geranos and run them using Curie.
- OCI Registry Support: Push and pull VM images from any OCI-compliant container registry.
- Familiar Interface: Command-line interface similar to Docker and
crane
, making it easy for users familiar with these tools.
Geranos can be downloaded from the GitHub releases page.
- Go: If you plan to build Geranos from source, ensure you have Go installed.
- Curie: For running pulled VM images, install Curie.
- Visit the Releases Page: Go to the Geranos Releases page.
- Download the Binary: Choose the appropriate binary for your operating system.
- Install the Binary:
- Move the binary to a directory in your
$PATH
, such as/usr/local/bin
. - Make the binary executable:
chmod +x /usr/local/bin/geranos
- Move the binary to a directory in your
If you prefer to build from source:
git clone https://github.com/macvmio/geranos.git
cd geranos
go build -o geranos ./cmd/geranos/main.go
Geranos requires a configuration file located at ~/.geranos/config.yaml
. This file specifies where images are stored locally.
Example ~/.geranos/config.yaml
:
images_directory: /Users/yourusername/.curie/.images
Replace /Users/yourusername
with your actual username or the path where Curie stores images.
NOTE: For curie up to 3.0, you have to specify ".curie/images" (without a dot)
To pull a macOS VM image from an OCI registry:
geranos pull ghcr.io/macvmio/macos-sonoma:14.5-agent-v1.6
This command downloads the VM image while optimizing bandwidth and disk usage.
After pulling the image, run it using Curie:
curie run ghcr.io/macvmio/macos-sonoma:14.5-agent-v1.6
Geranos provides several commands:
- adopt: Adopt a directory as an image under the current local registry.
- clone: Locally clone one reference to another name.
- completion: Generate the autocompletion script for the specified shell.
- context: Manage contexts.
- help: Help about any command.
- inspect: Inspect details of a specific OCI image.
- list: List all OCI images in a specific local registry.
- login: Log in to a registry.
- logout: Log out of a registry.
- pull: Pull an OCI image from a registry and extract the file.
- push: Push a large file as an OCI image to a registry.
- remote: Manipulate remote repositories.
- remove: Remove locally stored images.
- version: Print the version.
General Flags:
-h
,--help
: Help for Geranos.-v
,--verbose
: Enable verbose output.--version
: Show Geranos version.
Get Help for a Command:
geranos [command] --help
-
List remote images
geranos remote images ghcr.io/macvmio/macos-sonoma
-
Push an Image to a Registry:
geranos push registry.example.com/namespace/myimage:tag
-
List Images in Local Registry:
geranos list
Contributions are welcome! Please see the CONTRIBUTING.md for guidelines.
- Reporting Issues: Use the issue tracker to report bugs or request features.
- Pull Requests: Submit pull requests to the
main
branch.
Geranos is licensed under the Apache 2.0 License. See the LICENSE file for details.
- Inspired by go-containerregistry.
- Utilizes Cobra and Viper for command-line interface and configuration management.
- Integration with the upcoming macvm.io website.
- Enhanced filesystem optimization features.
- Support for additional VM formats and platforms.
- GitHub Repository: github.com/macvmio/geranos
- Issues: github.com/macvmio/geranos/issues
- Email: [email protected]