geranos

module
v0.7.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 2, 2024 License: Apache-2.0

README

Geranos

Build Status Build Status License

Introduction

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.

Features

  • 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.

Table of Contents

Installation

Geranos can be downloaded from the GitHub releases page.

Prerequisites
  • Go: If you plan to build Geranos from source, ensure you have Go installed.
  • Curie: For running pulled VM images, install Curie.
Download Binary
  1. Visit the Releases Page: Go to the Geranos Releases page.
  2. Download the Binary: Choose the appropriate binary for your operating system.
  3. 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
      
Build from Source (Optional)

If you prefer to build from source:

git clone https://github.com/macvmio/geranos.git
cd geranos
go build -o geranos main.go

Usage

Configuration

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)

Pulling a VM Image

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.

Running a Pulled VM Image with Curie

After pulling the image, run it using Curie:

curie run ghcr.io/macvmio/macos-sonoma:14.5-agent-v1.6
Available Commands

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
Examples
  • 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
    

Contributing

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.

License

Geranos is licensed under the Apache 2.0 License. See the LICENSE file for details.

Acknowledgments

Future Plans

  • Integration with the upcoming macvm.io website.
  • Enhanced filesystem optimization features.
  • Support for additional VM formats and platforms.

Contact and Support

Directories

Path Synopsis
cmd
pkg

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL