sapk / armada

A multi-cluster batch queuing system for high-throughput workloads on Kubernetes.

Home Page:https://armadaproject.io

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Armada

CircleCI Go Report Card

Armada is an application to achieve high throughput of run-to-completion jobs on multiple Kubernetes clusters.

It stores queues for users/projects with pod specifications and creates these pods once there is available resource in one of the connected Kubernetes clusters.

Documentation

Key features

  • Armada maintains fair resource share over time (inspired by HTCondor priority)
  • It can handle large amounts of queued jobs (million+)
  • It allows adding and removing clusters from the system without disruption
  • By utilizing multiple Kubernetes clusters the system can scale beyond the limits of a single Kubernetes cluster

Key concepts

Queue: Represents a user or project, used to maintain fair share over time, with a priority factor

Job: Unit of work to be run (described as a Kubernetes PodSpec)

Job Set: Group of related jobs. The API allows observing progress of a job set together

Try it out locally

Follow the quickstart guide to get Armada up and running locally.

About

A multi-cluster batch queuing system for high-throughput workloads on Kubernetes.

https://armadaproject.io

License:Apache License 2.0


Languages

Language:Go 70.3%Language:C# 20.0%Language:TypeScript 7.7%Language:CSS 0.5%Language:Shell 0.4%Language:Dockerfile 0.4%Language:Smarty 0.3%Language:Makefile 0.3%Language:HTML 0.1%