17 breaking releases

new 0.21.0 Jan 13, 2025
0.20.1 Dec 9, 2024
0.20.0 Nov 27, 2024
0.17.0 Jul 24, 2024
0.5.0 Jun 28, 2023

#54 in Programming languages

Download history 1800/week @ 2024-09-23 2185/week @ 2024-09-30 2019/week @ 2024-10-07 2172/week @ 2024-10-14 1819/week @ 2024-10-21 1493/week @ 2024-10-28 1763/week @ 2024-11-04 4671/week @ 2024-11-11 4862/week @ 2024-11-18 4414/week @ 2024-11-25 4978/week @ 2024-12-02 5305/week @ 2024-12-09 4401/week @ 2024-12-16 1860/week @ 2024-12-23 2300/week @ 2024-12-30 3807/week @ 2025-01-06

12,558 downloads per month
Used in cdviz-collector

MPL-2.0 license

2.5MB
62K SLoC

Vector Remap Language (VRL)

Crates.io docs.rs GitHub Workflow Status

VRL is a scripting language for processing observability data (logs, metrics, traces). Although VRL was originally created for use in Vector, it was designed to be generic and re-usable in many contexts.

Features

VRL is broken up into multiple components, which can be enabled as needed.

Feature Default Description
compiler yes The contains the core functionality of VRL. Compiling and running VRL programs.
parser yes Creates an abstract syntax tree (AST) from VRL source code.
value yes Contains the primary data type used in VRL.
diagnostic yes Logic related to errors and displaying info about them.
path yes Contains the parser, datatypes, and functions related to VRL paths.
stdlib yes All of the VRL functions from the standard library.
core yes Various data structures and utility methods (these may be renamed / moved in the future).
datadog_filter yes Implements the Datadog log search query filter syntax.
datadog_grok yes Implements the Datadog grok parser. (used with parse_grok and parse_groks in the stdlib).
datadog_search yes Implements the Datadog log search syntax.
cli no Contains functionality to create a CLI for VRL.
test_framework no Contains the test framework for testing VRL functions. Useful for testing custom functions.
lua no Makes the Value type compatible with the mlua crate.
arbitrary no Implements Arbitrary (from the quickcheck crate) for the Value type

Webassembly

All of the core features, and most of the standard library functions can be compiled with the wasm32-unknown-unknown target. There are a few stdlib functions that are unsupported. These will still compile, but abort at runtime.

Unsupported functions:

  • parse_grok
  • parse_groks
  • log
  • get_hostname
  • reverse_dns

Dependencies

~5–47MB
~683K SLoC