mirabelle.action

above-dt

(above-dt config & children)

Takes a number threshold and a time period in seconds duration. If the condition “the event metric is > to the threshold” is valid for all events received during at least the period duration, valid events received after the duration period will be passed on until an invalid event arrives. :metric should not be nil (it will produce exceptions).

(above-dt {:threshold 100 :duration 10}
  (debug))

In this example, if the events :metric field are greater than 100 for more than 10 seconds, events are passed downstream.

action->fn

aggregation*

(aggregation* _ {:keys [duration], :as config} & children)

async-queue!

(async-queue! queue-name & children)

Execute children into the specific async queue. The async queue should be defined in the I/O configuration file.

(async-queue! :my-queue
  (info))

async-queue!*

(async-queue!* context queue-name & children)

below-dt

(below-dt config & children)

Takes a number threshold and a time period in seconds duration. If the condition the event metric is < to the threshold is valid for all events received during at least the period duration, valid events received after the duration period will be passed on until an invalid event arrives. :metric should not be nil (it will produce exceptions).

(below-dt {:threshold 100 :duration 10}
(debug))

In this example, if the events :metric field are lower than 100 for more than 10 seconds, events are passed downstream.

between-dt

(between-dt config & children)

Takes two numbers, low and high, and a time period in seconds, duration. If the condition the event metric is > low and < high is valid for all events received during at least the period duration, valid events received after the duration period will be passed on until an invalid event arrives. :metric should not be nil (it will produce exceptions).

(between-dt {:low 50 :high 100 :duration 10}
  (debug))

In this example, if the events :metric field are between 50 ans 100 for more than 10 seconds, events are passed downstream.

bottom

(bottom config & children)

Get the min event from the last dt seconds.

(bottom {:duration 10}
  (info))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, events from previous windows will be flushed after this delay:

(bottom {:duration 10 :delay 5}
  (info))

by

(by config & children)

Split stream by field Every time an event arrives with a new value of field, this action invokes its child forms to return a new, distinct set of streams for that particular value.

(by {:fields [:host :service]}
  (fixed-time-window {:duration 60}))

This example generates a moving window for each host/service combination.

You can also pass the :gc-interval and :fork-ttl keys to the action. This will enable garbage collections of children actions, executed every :gc-interval (in seconds) and which will remove actions which didn’t receive events since :fork-ttl seconds

(by {:fields [:host :service [:a :nested-key]
     :gc-interval 3600
     :fork-ttl 1800}
  (fixed-time-window {:duration 60}))

by-fn

(by-fn {:keys [fields gc-interval fork-ttl]} new-fork)

by-get-field-fn

(by-get-field-fn field)

call-rescue

(call-rescue event children)

changed

(changed config & children)

Passes on events only if the field passed as parameter differs from the previous one. The init parameter is the default value for the stream.

(changed {:field :state :init "ok"})

For example, this action will let event pass if the :state field vary, the initial value being ok.

This stream is useful to get only events making a transition.

It also supported nested fields:

(changed {:field [:nested :field] :init "ok"})

changed*

(changed* _ {:keys [field init]} & children)

clear-forks

(clear-forks state current-time fork-ttl)

coalesce

(coalesce config & children)

Returns a list of the latest non-expired events (by fields) every dt seconds (at best).

(coalesce {:duration 10 :fields [:host :service]}
  (debug)

In this example, the latest event for each host/service combination will be kept and forwarded downstream. The debug action will then receive this list of events. Expired events will be removed from the list.

coalesce supports nested fields:

(coalesce {:duration 10 :fields [:host [:nested :field]]}
  (debug)

coalesce*

(coalesce* _ {:keys [duration fields]} & children)

coll-bottom

(coll-bottom nb-events & children)

Receives a list of events, returns the bottom N events with the lowest metrics.

(fixed-time-window {:duration 60}
  (coll-bottom 5
    (info)))

coll-bottom*

(coll-bottom* _ nb-events & children)

coll-count

(coll-count & children)

Count the number of events. Should receive a list of events from the previous stream. The most recent event is used as a base to create the new event, and its :metric field is set to the number of events received as input.

(fixed-time-window {:duration 60}
  (coll-count
    (debug)))

coll-count*

(coll-count* _ & children)

coll-increase

(coll-increase & children)

Receives a list of events which should represent an always-increasing counter and returns the latest event with its :metric field set to the value of the increase between the oldest and the latest event.

If it receives for example:

[{:time 1 :metric 10} {:time 9 :metric 20} {:time 20 :metric 30}}

It will produces (30-10 = 20):

{:time 20 :metric 20}

Events produced with a negative metric (which can happen if the counter is resetted) are not send downstream.

coll-increase*

(coll-increase* _ & children)

coll-max

(coll-max & children)

Returns the event with the biggest metric. Should receive a list of events from the previous stream.

(fixed-event-window {:size 10}
  (coll-max
    (debug)))

Get the event the biggest metric on windows of 10 events.

Check top and smax as well.

coll-max*

(coll-max* _ & children)

coll-mean

(coll-mean & children)

Computes the events mean (on metric). Should receive a list of events from the previous stream. The most recent event is used as a base to create the new event

(fixed-event-window {:size 10}
  (coll-mean
    (debug)))

Computes the mean on windows of 10 events

coll-mean*

(coll-mean* _ & children)

coll-min

(coll-min & children)

Returns the event with the smallest metric. Should receive a list of events from the previous stream.

(fixed-event-window {:size 10}
  (coll-min
    (debug)))

Get the event the smallest metric on windows of 10 events.

Check bottom and smin as well.

coll-min*

(coll-min* _ & children)

coll-percentiles

(coll-percentiles points & children)

Receives a list of events and selects one event from that period for each point. If point is 0, takes the lowest metric event. If point is 1, takes the highest metric event. 0.5 is the median event, and so forth. Forwards each of these events to children. The event has the point appended the :quantile key. Useful for extracting histograms and percentiles.

(fixed-event-window {:size 10}
  (coll-percentiles [0.5 0.75 0.98 0.99]))

coll-percentiles*

(coll-percentiles* _ points & children)

coll-quotient

(coll-quotient & children)

Divide the first event :metrìc field by all subsequent events :metric. Return a new event containing the new :metric.

Should receive a list of events from the previous stream.

coll-quotient*

(coll-quotient* _ & children)

coll-rate

(coll-rate & children)

Computes the rate on a list of events. Should receive a list of events from the previous stream. The latest event is used as a base to build the new event.

(fixed-event-window {:size 3}
  (coll-rate
    (debug)))

If this example receives the events:

{:metric 1 :time 1} {:metric 2 :time 2} {:metric 1 :time 3}

The stream will return {:metric 2 :time 3}

Indeed, (1+2+1)/2 = 3 (we divide by 2 because we have 2 seconds between the min and max events time).

coll-rate*

(coll-rate* _ & children)

coll-sort

(coll-sort field & children)

Sort events based on the field passed as parameter Should receive a list of events from the previous stream.

(fixed-event-window {:size 10}
  (coll-sort :time
    (debug)))

coll-sort*

(coll-sort* _ field & children)

coll-sum

(coll-sum & children)

Sum all the events :metric fields Should receive a list of events from the previous stream.

(fixed-event-window {:size 10}
  (coll-sum
    (debug)))

Sum all :metric fields for windows of 10 events

coll-sum*

(coll-sum* _ & children)

coll-top

(coll-top nb-events & children)

Receives a list of events, returns the top N events with the highest metrics.

(fixed-time-window {:duration 60}
  (coll-top 5
    (info)))

coll-top*

(coll-top* _ nb-events & children)

coll-where

(coll-where conditions & children)

Like where but should receive a list of events.

(fixed-time-window {:duration 60}
  (coll-where [:and [:= :host "foo"]
                    [:> :metric 10]))

coll-where*

(coll-where* _ conditions & children)

cond-dt

(cond-dt config & children)

Takes a time period in seconds duration. If all events received during at least the period duration matches the condition, events will be passed on until

(cond-dt {:duration 10 :condition [:= :state "error"]}
  (debug))

In this example, if the events :state are “error” for more than 10 seconds, events are passed downstream.

cond-dt*

(cond-dt* _ conditions dt & children)

A stream which detects if a condition (f event) is true during dt seconds. Takes conditions (like in the where action) and a time period dt in seconds. If the condition is valid for all events received during at least the period dt, valid events received after the dt period will be passed on until an invalid event arrives. Skips events that are too old or that do not have a timestamp.

custom

(custom action-name params & children)

Executes a custom action. Custom actions are defined in the Mirabelle configuration file. The actomn can then be called (by name) using this custom action.

(custom :my-custom-action ["parameters"]
  (info))

ddt

(ddt & children)

Differentiate metrics with respect to time. Emits an event for each event received, but with metric equal to the difference between the current event and the previous one, divided by the difference in their times. Skips events without metrics.

(ddt
  (info))

If ddt receives {:metric 1 :time 1} and {:metric 10 :time 4}, it will produce {:metric (/ 9 3) :time 4}.

ddt*

(ddt* _ remove-neg? & children)

ddt-pos

(ddt-pos & children)

Like ddt but do not forward events with negative metrics. This can be used for counters which may be reseted to zero for example.

debug

(debug)

Print the event in the logs using the debug level

(increment
  (debug))

debug*

(debug* ctx)

decrement

(decrement & children)

Decrement the event :metric field.

(decrement
  (debug))

decrement*

(decrement* _ & children)

default

(default field value & children)

Set a default value for an event

(default :state "ok"
  (info))

In this example, all events where :state is not set will be updated with :state to “ok”.

It also supports nested keys:

(default [:nested :key] "ok"
  (info))

default*

(default* _ field value & children)

default-aggr-finalizer

(default-aggr-finalizer _ event)

dissoc-in

(dissoc-in m [k & ks :as keys])

Dissociates an entry from a nested associative structure returning a new nested structure. keys is a sequence of keys. Any empty maps that result will not be present in the new structure.

duration->ns

(duration->ns config)

converts the :duration key to nanoseconds if it exists

error

(error)

Print the event in the logs using the error level

(increment
  (debug))

error*

(error* ctx)

ewma-timeless

(ewma-timeless r & children)

Exponential weighted moving average. Constant space and time overhead. Passes on each event received, but with metric adjusted to the moving average. Does not take the time between events into account. R is the ratio between successive events: r=1 means always return the most recent metric; r=1/2 means the current event counts for half, the previous event for 1/4, the previous event for 1/8, and so on.

ewma-timeless*

(ewma-timeless* _ r & children)

exception->event

(exception->event e base-event)

Build a new event from an Exception and from the event which caused it.

exception-stream

(exception-stream & children)

Takes two actions. If an exception is thrown in the first action, an event representing this exception is emitted in in the second action.

(exception-stream
  (bad-action)
  (error))

Here, if bad-action throws, an event will be built (using the exception->event function) and sent to the error action (which will log it).

exception-stream*

(exception-stream* _ success-child failure-child)

expired

(expired & children)

Keep expired events.

(expired
  (increment))

In this example, all expired events will be forwarded to the incrementstream.

expired*

(expired* _ & children)

Keep expired events.

extract

(extract k & children)

Takes a key as parameter and send downstream the content of this key.

(extract :base-event
  (info))

If extract receives in this example {:time 1 :base-event {:time 1 :service "foo" :host "bar"}, info will receive the content of :base-time.

It also supports nested keys:

(extract [:foo :bar]
  (info))

extract*

(extract* _ k & children)

fixed-event-window

(fixed-event-window config & children)

Returns a fixed-sized window of events.

(fixed-event-window {:size 5}
  (debug))

This example will return a vector events partitioned 5 by 5.

fixed-event-window*

(fixed-event-window* _ {:keys [size]} & children)

fixed-time-window

(fixed-time-window config & children)

A fixed window over the event stream in time. Emits vectors of events, such that each vector has events from a distinct n-second interval. Windows do not overlap; each event appears at most once in the output stream.

(fixed-time-window {:duration 60}
  (coll-max
    (info)))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, previous windows will be flushed after this delay:

(fixed-time-window {:duration 60 :delay 30}
  (coll-max
    (info)))

from-base64

(from-base64 field & children)

Decode a base64 field.

(sdo
  ;; you can pass one field
  (from-base64 :host)
  ;; or a list to update a nested keys
  (from-base64 [:host :service]))

from-base64*

(from-base64* _ fields & children)

from-json

(from-json k & children)

Takes a field or a list of fields, and converts the values associated to these fields from a json string to edn.

(with :my-field "{"foo": "bar"}
  (from-json :my-field))

In this example, we associate to :my-field a json string and then we call from-json on it. :my-field will now contain an edn map built from the json data, with keywords as keys.

This action also supports nested keys by passing an array of keys (for example (from-json [:nested :key]))

from-json*

(from-json* _ k & children)

gen-doc

(gen-doc)

get-env-profile

(get-env-profile)

get-fork-and-gc

(get-fork-and-gc state new-fork fork-name current-time fork-ttl gc-interval)

get-window

(get-window event start-time duration)

include

(include path config)

Include an configuration file by path into the configuration. The file will be read using the aero (https://github.com/juxt/aero/) library. The config variable supports these optional options:

  • :profile: the aero profile to use. By default, Mirabelle will read (and convert to a Clojure keyword) the PROFILE environment variable during compilation. You can override this value by setting :profile.
  • :variables: variables to pass to the configuration file. You can use the #mirabelle/var reader in order to define variables in your EDN file.

This allows you to use the same configuration snippet (eventually templated) from multiple streams (or multiple parts of the same stream)

(includes"/etc/mirabelle/includes/my-actions.clj {:profile :dev
                                                   :variables {:foo "bar"})

increment

(increment & children)

Increment the event :metric field.

(increment
  (debug))

increment*

(increment* _ & children)

info

(info)

Print the event in the logs using the info level

(increment
  (info))

info*

(info* ctx)

io

(io & children)

Discard all events in test mode. Else, forward to children. You can use this stream to avoid side effects in test mode.

io*

(io* context & children)

iterate-on

(iterate-on config & children)

iterate-on*

(iterate-on* _ {:keys [source destination]} & children)

keep-keys

(keep-keys keys-to-keep & children)

Keep only the specified keys for events.

(keep-keys [:host :metric :time :environment :description]
  (info))

Also works with nested keys:

(keep-keys [:host :metric :time [:a :nested-key]]
  (info))

keep-keys*

(keep-keys* _ keys-to-keep & children)

keyword->aggr-finalizer-fn

keyword->aggr-fn

log-action

(log-action source-stream level)

Generic logger

mean

(mean config & children)

Get the mean of event metrics from the last dt seconds.

(mean {:duration 10}
  (info))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, events from previous windows will be flushed after this delay:

(mean {:duration 10 :delay 5}
  (info))

moving-event-window

(moving-event-window config & children)

A sliding window of the last few events. Every time an event arrives, calls children with a vector of the last n events, from oldest to newest. Ignores event times. Example:

(moving-event-window {:size 5}
  (coll-mean (info))

moving-event-window*

(moving-event-window* _ config & children)

moving-time-window

(moving-time-window config & children)

A sliding window of all events with times within the last n seconds. Uses the maximum event time as the present-time horizon. Every time a new event arrives within the window, emits a vector of events in the window to children.

Events without times accrue in the current window.

moving-time-window*

(moving-time-window* _ {:keys [duration]} & children)

not-expired

(not-expired & children)

Keep non-expired events.

(not-expired
  (increment))

In this example, all non-expired events will be forwarded to the `increment`stream.

not-expired*

(not-expired* _ & children)

Keep non-expired events.

output!

(output! output-name)

Push events to an external system.

Outputs are configured into the main Mirabelle configuration file. If you create a new output named :elasticsearch for example, you can use output! to push all events into this I/O:

(output! :elasticsearch)

Outputs are automatically discarded in test mode.

output!*

(output!* context output-name)

outside-dt

(outside-dt config & children)

Takes two numbers, low and high, and a time period in seconds, duration. If the condition the event metric is < low or > high is valid for all events received during at least the period duration, valid events received after the duration period will be passed on until an invalid event arrives. :metric should not be nil (it will produce exceptions).

(outside-dt {:low 50 :high 100 :duration 10}
  (debug))

In this example, if the events :metric field are outside the 50-100 range for more than 10 seconds, events are passed downstream.

over

(over n & children)

Passes on events only when their metric is greater than x.

(over 10
  (info))

over*

(over* _ n & children)

percentiles

(percentiles config & children)

Computes quantiles based on a stream of events. Results are flushed periodically downstreal based on the action configuration

(a/percentiles {:percentiles [0.5 0.75 0.99]
                :duration 10})

:percentiles contains a list of quantiles to compute, :duration is the duration before sending the result downstream, :nb-significant-digits is the precision for the computation (default to 3).

After the end of the period, the action will generate one event for each percentile that is computed, with the key :quantile set to the percentile value. In this example, it would generate 3 events with :quantile equal to 0.5, 0.75 or 0.99.

The action also supports optinal options: a :delay option to tolerate late events (in that case the current window will be flushed :delay seconds after its end), and :highest-trackabe-value and :lowest-discernible-value to configure the histogram computation.

See hdrhistogram documentation (http://hdrhistogram.org/) for more information about these settings.

percentiles*

(percentiles* _ {:keys [duration percentiles delay highest-trackable-value nb-significant-digits lowest-discernible-value], :or {nb-significant-digits 3}} & children)

project

(project conditions & children)

Takes a list of conditions. Like coalesce, project will return the most recent events matching the conditions.

(project [[:= :service "enqueues"]
          [:= :service "dequeues"]]
  (coll-quotient
    (with :service "enqueues per dequeue"
      (info))))

We divide here the latest event for the “enqueues” :service by the latest event from the “dequeues” one.

project*

(project* _ conditions & children)

publish!

(publish! channel)

Publish events in the given channel.

(publish! :my-channel)

Users can then subscribe to channels using the websocket engine.

publish!*

(publish!* context channel)

rate

(rate config & children)

Computes the rate of received events (by counting them) and emits the result at a periodic interval

ratio

(ratio config & children)

Computes the ratio for 2 conditions:

(ratio {:duration 30
        :conditions [[:= :state "error"] [:true]]}
  (info))

In this example, the action will count the number of events matching each conditions (:state = "error, and :true matching all events).

Every 30 seconds, an event will be send downstream with the :metric field set to the ratio between the count of events for the second condition and the count for the first one. For example, if the action received 30 events in total during the interval, and with 5 with :state = “error”, :metric will be equal to 5/30.

The latest event is used as a base to build the event that is sent downstream.

It also supports a :metric option. If set to true, the action will sum the :metric value of events matching conditions instead of counting them.

(ratio {:duration 30
        :conditions [[:= :state "error"] [:true]]
        :metric true}
  (info))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, events from previous windows will be flushed after this delay.

ratio-state-update

(ratio-state-update state event state-fn cond1 cond2)

reinject!

(reinject!)(reinject! destination-stream)

Reinject an event into the streaming system. By default, events are reinject into the real time engine. You can reinject events to a specific stream by passing the destination stream as parameter.

(reinject)

This example reinjects events into the real stream engine.

(reinject :foo)

This example reinjects events into the stream named :foo.

reinject!*

(reinject!* context destination-stream)

rename-keys

(rename-keys replacement & children)

Rename events keys.

(rename-keys {:host :service
              :environment :env}

In this example, the :host key will be renamed :service and the :environment key is renamed :env.

You can also pass a list of keys as source or destination to rename nested attributes:

(rename-keys {[:attribute source] [:attribute: destination]
              :state [:attribute :state]
              [:attribute :host] :host})

Existing values will be overrided.

rename-keys*

(rename-keys* _ replacement & children)

scale

(scale factor & children)

Multiplies the event :metric field by the factor passed as parameter.

(scale 1000
  (info

This example will multiply the :metric field for all events by 1000.

scale*

(scale* _ factor & children)

scondition*

(scondition* _ {:keys [condition]} & children)

sdissoc

(sdissoc fields & children)

Remove a key (or a list of keys) from the events.

(sdissoc :host (info))

(sdissoc [:environment :host] (info))

(sdissoc [:environment [:nested :key]] (info))

sdissoc*

(sdissoc* _ fields & children)

sdo

(sdo & children)

Send events to children. useful when you want to send the same events to multiple downstream actions.

(sdo
  (increment)
  (decrement))

Here, events arriving in sdo will be forwarded to both increment and decrement.

sdo*

(sdo* _ & children)

select-keys-nested

(select-keys-nested event keyseq)

sflatten

(sflatten & children)

Streaming flatten. Calls children with each event in events. Events should be a sequence.

This stream can be used to “flat” a sequence of events (emitted by a time window stream for example).

(fixed-event-window {:size 5}
  (sflatten
    (info)))

sflatten*

(sflatten* _ & children)

sformat

(sformat template target-field fields & children)

Takes the content of multiple event keys, and use them to build a string value and assign it to a given key.

(sformat "%s-foo-%s" :format-test [:host :service])

If the event {:host "machine" :service "bar"} is passed to this action the event will become {:host "machine" :service "bar" :format-test "machine-foo-bar"}.

It also supports nested keys both for the destination or the fields to extract:

(sformat "%s-foo-%s" [:nested :key] [[:host :name] :service])

More information about availables formatters in the Clojure documentation: https://clojuredocs.org/clojure.core/format

sformat*

(sformat* _ template target-field fields & children)

smax

(smax & children)

Send downstream the event with the biggest :metric every time it receives an event

(smax
  (info))

If the events {:time 1 :metric 10} {:time 2 :metric 3} {:time 3 :metric 11} are injected, info will receive:

{:time 1 :metric 10} {:time 1 :metric 10} {:time 3 :metric 11}

smin

(smin & children)

Send downstream the event with the lowest :metric every time it receives an event

(smin
  (info))

If the events {:time 1 :metric 10} {:time 2 :metric 3} {:time 3 :metric 11} are injected, info will receive:

{:time 1 :metric 10} {:time 2 :metric 3} {:time 3 :metric 11}

split

(split & clauses)

Split by conditions.

(split
  [:> :metric 10] (debug)
  [:> :metric 5] (info)
  (error)

In this example, all events with :metric > 10 will go into the debug stream, all events with :metric > 5 in the info stream, and other events will to the default stream which is “error”.

The default stream is optional, if not set all events not matching a condition will be discarded.

split*

(split* _ clauses & children)

ssort

(ssort config & children)

Streaming sort. Takes a configuration containing a :duration and a :field key. The action will buffer events during :duration seconds and then send the events downstream one by one, sorted by :field.

(ssort {:duration 10 :field :time}
  (info))

This example will sort events based on the :time field.

For example, if it get as input:

{:time 1} {:time 10} {:time 4} {:time 9} {:time 13} {:time 31}

Info will receive these events:

{:time 1} {:time 4} {:time 9} {:time 10} {:time 13}

You can add a :delay key to the action configuration in order to tolerate late events:

(ssort {:duration 10 :field :time :delay 10}
  (info))

In this example, events from previous windows will be sent with a delay of 10 seconds.

ssort supports sorting on a nested field (example :field [:nested :field])

stable

(stable dt field & children)

Takes a duration (dt) in second and a field name as parameter. Returns events where the value of the field specified as second argument is equal to the value of the field for the last event, for at least dt seconds. Events can be buffered for dt seconds before being forwarded in order to see if they are stable or not.

Events should arrive in order (old events will be dropped).

You can use this stream to remove flapping states for example.

(stable 10 :state
  (info))

In this example, events will be forwarded of the value of the :state key is the same for at least 10 seconds.

Support nested fields:

(stable 10 [:nested :field]
  (info))
```.

stable*

(stable* _ dt field & children)

stream

(stream config & children)

Creates a new stream. This action takes a map where the :name key, which will be the name of the stream, is mandatory.

streams

(streams & streams)

Entrypoint for all streams.

(streams
  (stream {:name :fobar}
    (info))
  (stream {:name :foo}
    (info)))

sum

(sum config & children)

Sum the events field from the last dt seconds.

(sum {:duration 10}
  (info))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, events from previous windows will be flushed after this delay:

(sum {:duration 10 :delay 5}
  (info))

tag

(tag tags & children)

Adds a new tag, or set of tags, to events which flow through.

(tag "foo"
  (info))

This example adds the tag “foo” to events.

(tag ["foo" "bar"] (info))

This example adds the tag “foo” and “bar” to events.

tag*

(tag* _ tags & children)

tagged-all

(tagged-all tags & children)

Passes on events where all tags are present.

(tagged-all "foo"
  (info))

This example keeps only events tagged “foo”.

(tagged-all ["foo" "bar"] (info))

This example keeps only events tagged “foo” and “bar”.

tagged-all*

(tagged-all* _ tags & children)

tap

(tap tap-name)

Save events into the tap. Noop outside tests.

(where [:= :service "foo"]
  (tap :foo)

In test mode, all events with :service “foo” will be saved in a tap named :foo

tap*

(tap* context tape-name)

test-action

(test-action state & children)

Bufferize all received events in the state (an atom) passed as parameter

test-action*

(test-action* _ state)

throttle

(throttle config & children)

Let N event pass at most every duration seconds. Can be used for example to avoid sending to limit the number of alerts sent to an external system.

(throttle {:count 3 :duration 10}
  (error))

In this example, throttle will let 3 events pass at most every 10 seconds. Other events, or events with no time, are filtered.

throttle*

(throttle* _ config & children)

to-base64

(to-base64 field & children)

Convert a field to base64. Field value should be string.

(sdo
  ;; you can pass one field
  (to-base64 :host)
  ;; or a list to update a nested keys
  (to-base64 [:host :service]))

to-base64*

(to-base64* _ fields & children)

to-string

(to-string keys & children)

Converts values associated to keys to string. nil values are converted to an empty string. The parameter is a list of keys. It supports updating nested keys by passing a list of keywords.

(to-string [:service :state]
  (info))
(to-string [[:attributes :name] :quantile]
  (info))

to-string*

(to-string* _ keys & children)

top

(top config & children)

Get the max event from the last dt seconds.

(top {:duration 10}
  (info))

You can pass a :delay key to the configuration in order to tolerate late events. In that case, events from previous windows will be flushed after this delay:

(top {:duration 10 :delay 5}
  (info))

under

(under n & children)

Passes on events only when their metric is under than x.

(under 10
  (info))

under*

(under* _ n & children)

untag

(untag tags & children)

Removes a tag, or set of tags, from events which flow through.

(untag "foo" (debug))

This example removes the tag “foo” from events.

(untag ["foo" "bar"] (debug))

This example removes the tags “foo” and “bar” from events

untag*

(untag* _ tags & children)

where

(where conditions & children)

Filter events based on conditions. Each condition is a vector composed of the function to apply on the field, the field to extract from the event, and the event itself. Multiple conditions can be added by using :or or :and.

(where [:= :metric 4])

Here, we keep only events where the :metric field is equal to 4.

(where [:and [:= :host "foo"]
             [:> :metric 10])

Here, we keep only events with :host = foo and with :metric > 10

where*

(where* _ conditions & children)

with

(with & args)

Set an event field to the given value.

(with :state "critical"
  (debug))

This example set the field :state to “critical” for events.

A map can also be provided:

(with {:service "foo" :state "critical"}
  (debug))

This example set the the field :service to “foo” and the field :state to “critical” for events.

This action also supports updated nested keys:

(with [:nested :key] "critical"
  (debug))
(with {[:nested :key] "critical"}
  (debug))

with*

(with* _ fields & children)