Skip to main content

Simplified MetricFlow integration for Datus Agent - One-command setup for semantic metrics

Project description

metricflow logo

Build and maintain all of your metric logic in code.


Welcome to MetricFlow

See our latest updates in the Metricflow Changelog!

MetricFlow is a semantic layer that makes it easy to organize metric definitions. It takes those definitions and generates legible and reusable SQL. This makes it easy to get consistent metrics output broken down by attributes (dimensions) of interest.

The name comes from the approach taken to generate metrics. A query is compiled into a query plan (represented below) called a dataflow that constructs metrics. The plan is then optimized and rendered to engine-specific SQL.



MetricFlow provides a set of abstractions that help you construct complicated logic and dynamically generate queries to handle:

  • Multi-hop joins between fact and dimension sources
  • Complex metric types such as ratio, expression, and cumulative
  • Metric aggregation to different time granularities
  • And so much more

As a developer, you can also use MetricFlow's interfaces to construct APIs for integrations to bring metrics into downstream tools in your data stack.

To get up and running with your own metrics, you should rely on MetricFlow’s documentation available at MetricFlow docs.

Getting Started

Install MetricFlow

MetricFlow can be installed from PyPi for use as a Python library with the following command:

pip install metricflow

Once installed, MetricFlow can be setup and connected to a data warehouse by following the instructions after issuing the command:

mf setup

In case you don't have a connection to a data warehouse available and want a self-contained demo, DuckDB can be selected.

You may need to install Postgres or Graphviz. You can do so by following the install instructions for Postgres or Graphviz. Mac users may prefer to use brew: brew install postgresql or brew install graphviz.

Tutorial

The best way to get started is to follow the tutorial steps:

mf tutorial

There are several examples of MetricFlow configs on common data sets in the config-templates folder. The tutorial will rely on a small set of sample configs.

Resources

Contributing and Code of Conduct

This project will be a place where people can easily contribute high-quality updates in a supportive environment.

You might wish to read our code of conduct and engineering practices before diving in.

To get started on direct contributions, head on over to our contributor guide.

License

MetricFlow is open source software. The project relies on several licenses including AGPL-3.0-or-later and Apache (specified at folder level).

MetricFlow is built by Transform.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

datus_metricflow-0.1.10.tar.gz (837.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

datus_metricflow-0.1.10-py3-none-any.whl (1.7 MB view details)

Uploaded Python 3

File details

Details for the file datus_metricflow-0.1.10.tar.gz.

File metadata

  • Download URL: datus_metricflow-0.1.10.tar.gz
  • Upload date:
  • Size: 837.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.10 Darwin/25.2.0

File hashes

Hashes for datus_metricflow-0.1.10.tar.gz
Algorithm Hash digest
SHA256 7cbcf586dcb9fbd14a977b36735e091b13b7feebe2453e03f7725cd1cf905f4c
MD5 7dd479ed5ea4d073be06ab1928002e3c
BLAKE2b-256 a684d0fa034dd237c15730b4d6a5fe01e65bd5e30899a3c8e9d7e4a1f68cad19

See more details on using hashes here.

File details

Details for the file datus_metricflow-0.1.10-py3-none-any.whl.

File metadata

  • Download URL: datus_metricflow-0.1.10-py3-none-any.whl
  • Upload date:
  • Size: 1.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.10 Darwin/25.2.0

File hashes

Hashes for datus_metricflow-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 36fdb59178da461b01a4fbdb818b0cdc1867bfa096222cd659f4dbf3671a4c4d
MD5 6721b27d5f82d84fd37e48494a4cc73b
BLAKE2b-256 ea4366aeb84cdf3cbea6eedc49a1b503e5e5aa00321af869f2a841cb22fcba2c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page