Giter Club home page Giter Club logo

metronomikon's Introduction

Metronomikon

Overview

Metronomikon is a Metronome API compatibility layer for Kubernetes. It responds to the Metronome V2 API and maps requests into equivalent Kubernetes API calls.

Why would anyone want this?

Our motivation for writing this was to ease our transition from DC/OS to Kubernetes. Many of our applications are designed to interact with the Metronome API in DC/OS, and it was easier to transition these services to Kubernetes if they didn't need to be modified and could work as-is in both DC/OS and Kubernetes.

What about the differences between the way that Metronome and Kubernetes CronJobs work?

While it's true that Metronome and Kubernetes CronJobs work in fairly different ways, Metronomikon provides various methods to help work around these differences. In places where the Kubernetes API provides a richer variety of knobs and dials, Metronomikon has configurable defaults for these various values where needed. In cases where Metronome provides greater functionality (such as the ability to trigger a job "now"), the feature will be approximated in Kubernetes (by creating a Job based on a CronJob template in the case of triggering a job "now").

Unfortunately, it won't be possible to expose the Kubernetes only options through the Metronome API for compatibility reasons. It's also possible that some of the Metronome functionality may not be available due to an inability to reasonable approximate that behavior in Kubernetes.

One such unsupported Metronome feature, is job "stop" functionality. Kubernetes CronJobs does not support stopping a running CronJob without also deleting the job instance itself, which would in turn destroy history of said job.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.