All Projects → MarquezProject → Marquez

MarquezProject / Marquez

Licence: apache-2.0
Collect, aggregate, and visualize a data ecosystem's metadata

Programming Languages

java
68154 projects - #9 most used programming language

Labels

Projects that are alternatives of or similar to Marquez

Resh
Rich Enhanced Shell History - Contextual shell history for zsh and bash
Stars: ✭ 310 (-41.51%)
Mutual labels:  metadata
Torsniff
torsniff - a sniffer that sniffs torrents from BitTorrent network
Stars: ✭ 3,800 (+616.98%)
Mutual labels:  metadata
Seqbox
A single file container/archive that can be reconstructed even after total loss of file system structures
Stars: ✭ 480 (-9.43%)
Mutual labels:  metadata
Irods
Open Source Data Management Software
Stars: ✭ 321 (-39.43%)
Mutual labels:  metadata
Vue Meta
Manage HTML metadata in Vue.js components with SSR support
Stars: ✭ 3,807 (+618.3%)
Mutual labels:  metadata
Specs
Technical specifications and guidelines for implementing Frictionless Data.
Stars: ✭ 403 (-23.96%)
Mutual labels:  metadata
Spotiflyer
Spotify/Gaana/Youtube Music Downloader For Android!
Stars: ✭ 231 (-56.42%)
Mutual labels:  metadata
Metadata Extractor Dotnet
Extracts Exif, IPTC, XMP, ICC and other metadata from image, video and audio files
Stars: ✭ 518 (-2.26%)
Mutual labels:  metadata
Python Us
A package for easily working with US and state metadata
Stars: ✭ 376 (-29.06%)
Mutual labels:  metadata
Rv8
RISC-V simulator for x86-64
Stars: ✭ 476 (-10.19%)
Mutual labels:  metadata
The Seo Framework
The SEO Framework WordPress plugin.
Stars: ✭ 329 (-37.92%)
Mutual labels:  metadata
Tropy
Research photo management
Stars: ✭ 337 (-36.42%)
Mutual labels:  metadata
Exifr
📷 The fastest and most versatile JS EXIF reading library.
Stars: ✭ 448 (-15.47%)
Mutual labels:  metadata
Steedos Platform
华炎魔方低代码/无代码平台。内核采用了元数据、微服务、微前端、K8S等最新的技术架构。Steedos Low-Code / No-Code Platform in nodejs and mongodb.
Stars: ✭ 310 (-41.51%)
Mutual labels:  metadata
Fatt
FATT /fingerprintAllTheThings - a pyshark based script for extracting network metadata and fingerprints from pcap files and live network traffic
Stars: ✭ 490 (-7.55%)
Mutual labels:  metadata
Mnamer
media file renamer and organizion tool
Stars: ✭ 299 (-43.58%)
Mutual labels:  metadata
Ytmdl Web V2
Web version of ytmdl. Allows downloading songs with metadata embedded from various sources like itunes, gaana, LastFM etc.
Stars: ✭ 398 (-24.91%)
Mutual labels:  metadata
Popcorn Api
Popcorn Time is a multi-platform, free software BitTorrent client that includes an integrated media player. Compatible API Anime/Movies/Show Scrapper
Stars: ✭ 529 (-0.19%)
Mutual labels:  metadata
Multiscanner
Modular file scanning/analysis framework
Stars: ✭ 494 (-6.79%)
Mutual labels:  metadata
Music Metadata
Stream and file based music metadata parser for node. Supporting a wide range of audio and tag formats.
Stars: ✭ 455 (-14.15%)
Mutual labels:  metadata

Marquez is an open source metadata service for the collection, aggregation, and visualization of a data ecosystem's metadata. It maintains the provenance of how datasets are consumed and produced, provides global visibility into job runtime and frequency of dataset access, centralization of dataset lifecycle management, and much more. Marquez was released and open sourced by WeWork.

Badges

CircleCI codecov status Slack license Contributor Covenant maven docker Known Vulnerabilities

Status

Marquez is an LF AI & Data Foundation incubation project under active development and we'd love your help!

Quickstart

Marquez provides a simple way to collect and view dataset and job metadata. The easiest way to get up and running is with Docker. From the base of the Marquez repository run:

$ ./docker/up.sh

Tip: Use the --build flag to build images from source, and/or --seed to load with seed data.

WEB UI

You can open http://localhost:3000 to begin exploring the web UI. The UI enables you to discover dependencies between jobs and the datasets they produce and consume via the lineage graph, view run metadata of current and previous job runs, and much more!

HTTP API

The HTTP API listens on port 5000 for all calls and port 5001 for the admin interface. The admin interface exposes helpful endpoints like /healthcheck and /metrics. To verify the HTTP API server is running and listening on localhost browse to http://localhost:5001.

Note: By default, the HTTP API does not require any form of authentication or authorization.

GRAPHQL

To explore metadata via graphql, browse to http://localhost:5000/graphql-playground. The graphql endpoint is currently in beta and is located at http://localhost:5000/api/v1-beta/graphql.

Documentation

We invite everyone to help us improve and keep documentation up to date. Documentation is maintained in this repository and can be found under docs/.

Note: To begin collecting metadata with Marquez, follow our quickstart guide. Below you will find the steps to get up and running from source.

Modules

Marquez uses a multi-project structure and contains the following modules:

Requirements

Note: To connect to your running PostgreSQL instance, you will need the standard psql tool.

Building

You can build most of the project modules using Java 11. We recommend setting JAVA_HOME to your local JDK 11 installation and invoking ./gradlew :<module>:shadowJar with the specific module you'd like to build. For example, to build the api module run:

$ ./gradlew :api:shadowJar

The executable can be found under api/build/libs/

The spark integration requires Java 8 to build. The module can be built separately by setting JAVA_HOME to your local JDK 8 installation and invoking ./gradlew :integrations:spark:shadowJar.

To build the entire project, set JAVA_HOME to your local JDK 11 installation and JDK8_HOME to your local JDK 8 installation. Then, build all modules with:

$ ./gradlew build

Configuration

To run Marquez, you will have to define marquez.yml. The configuration file is passed to the application and used to specify your database connection. The configuration file creation steps are outlined below.

Step 1: Create Database

When creating your database using createdb, we recommend calling it marquez:

$ createdb marquez

Step 2: Create marquez.yml

With your database created, you can now copy marquez.example.yml:

$ cp marquez.example.yml marquez.yml

You will then need to set the following environment variables (we recommend adding them to your .bashrc): POSTGRES_DB, POSTGRES_USER, and POSTGRES_PASSWORD. The environment variables override the equivalent option in the configuration file.

By default, Marquez uses the following ports:

  • TCP port 8080 is available for the HTTP API server.
  • TCP port 8081 is available for the admin interface.

Note: All of the configuration settings in marquez.yml can be specified either in the configuration file or in an environment variable.

Running the Application

$ ./gradlew :api:runShadow

Then browse to the admin interface: http://localhost:8081

Related Projects

  • OpenLineage: open standard for metadata and lineage collection

Getting Involved

Contributing

See CONTRIBUTING.md for more details about how to contribute.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].