miniloops

command module
v0.0.1 Latest Latest
Warning

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

Go to latest
Published: Nov 22, 2020 License: Apache-2.0 Imports: 1 Imported by: 0

README

Miniloops

Docker image PkgGoDev Maintainability Test Coverage

Miniloops goal is to provide an easy to use time series related tasks workflow.

Getting started

Installation

To install the operator, run:

kubectl apply -f https://raw.githubusercontent.com/clever-telemetry/miniloops/master/config/crd/bases/clever-telemetry.io_loops.yaml
kubectl apply -f https://raw.githubusercontent.com/clever-telemetry/miniloops/master/config/operator/deployment.yml
Usage

Run your first loop !

kubectl apply ./config/examples

Debug your first loop !

kubectl describe loop -n loops

Loop in depth

A Loop is a script which run at regular intervals, its goal is to compute aggregated data from base data. As an example, we can use IOT temperature devices, each device write its own temperature on a database. Query a device data is pretty easy, query all data to compute an average data at each time is pretty time and resource consuming.

Then, each Loop has to query data, aggregate it and write it.

WarpScript

A WarpScript Loop is fully autonomous, in the WarpScript body you have to query, aggregate and persist the data

Ex:

---
apiVersion: clever-telemetry.io/v1
kind: Loop
metadata:
  namespace: loops
  name: test
spec:
  endpoint: https://warp10.gra1.metrics.ovh.net/api/v0/exec
  every: 10s
  script: |
    REV
    [ NEWGTS 'c' RENAME ] 
...
Secrets

This is a secret between us ;-)

You can inject real Kubernetes secrets into your Loop.

Use this syntax:

---
apiVersion: clever-telemetry.io/v1
kind: Loop
metadata:
  namespace: loops
  name: test
spec:
  ...
  imports:
  - secret:
      name: mysecret
  ... 
...

imports is an array of secrets/configs you can import in your Loop. Each import must be in the same namespace of the Loop. Each item must have a name.

The Runtime will read all secrets and inject them in your WarpScript, when it do it, it iterate over each Secret keys, and wrote a new variable with the key and the value. The Secret Namespace/Name is not kept, so, 2 imported secrets with the same key will be override by the last one.

Then you will be able to use them in your script.

Ex:

apiVersion: v1
kind: Secret
metadata:
  name: mysecret
  namespace: loops
type: Opaque
string:
  username: dG90bwo= 
  password: bXlwYXNzd29yZAo=
apiVersion: clever-telemetry.io/v1
kind: Loop
metadata:
  namespace: loops
  name: test
spec:
  endpoint: https://warp10.gra1.metrics.ovh.net/api/v0/exec
  every: 10s
  script: "[ $readToken '~.*' {} ] FIND"
  imports:
  - secret:
      name: mysecret 
...
Runner metrics

Each loop produce serveral metrics, this is the list. There are exposed with all controllers metrics on this endpoint

miniloops_runner_execution_count{ loop="LOOP_NAME", namespace="LOOP_NAMESPACE" } int
miniloops_runner_execution_duration{ loop="LOOP_NAME", namespace="LOOP_NAMESPACE",unit="ms" } int
miniloops_runner_execution_error_count{ loop="LOOP_NAME", namespace="LOOP_NAMESPACE" } int

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
apis
loops/v1
Package v1 contains API Schema definitions for the Loops v1 API group +kubebuilder:object:generate=true +groupName=clever-telemetry.io
Package v1 contains API Schema definitions for the Loops v1 API group +kubebuilder:object:generate=true +groupName=clever-telemetry.io
client
loops
This package has the automatically generated clientset.
This package has the automatically generated clientset.
loops/scheme
This package contains the scheme of the automatically generated clientset.
This package contains the scheme of the automatically generated clientset.
loops/typed/loops/v1
This package has the automatically generated typed clients.
This package has the automatically generated typed clients.
pkg
cli

Jump to

Keyboard shortcuts

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