WhereHows is a data discovery and lineage tool built at LinkedIn. It integrates with all the major data processing systems and collects both catalog and operational metadata from them.
Within the central metadata repository, WhereHows curates, associates, and surfaces the metadata information through two interfaces:
- a web application that enables data & linage discovery, and community collaboration
- an API endpoint that empowers automation of data processes/applications
WhereHows serves as the single platform that:
- links data objects with people and processes
- enables crowdsourcing for data knowledge
- provides data governance and provenance based on ownership and lineage
Here is a list of companies known to use WhereHows. Let us know if we missed your company!
How WhereHows is used inside of LinkedIn and other potential use cases.
The detailed information can be found in the Wiki
There is a pre-built vmware image (about 11GB) to quickly demonstrate the functionality of WhereHows. Check out the VM Guide
New to Wherehows? Check out the Getting Started Guide
First, please setup the metadata repository in MySQL.
CREATE DATABASE wherehows
DEFAULT CHARACTER SET utf8
DEFAULT COLLATE utf8_general_ci;
CREATE USER 'wherehows';
SET PASSWORD FOR 'wherehows' = PASSWORD('wherehows');
GRANT ALL ON wherehows.* TO 'wherehows'
Execute the DDL files to create the required repository tables in wherehows database.
- Get the source code:
git clone https://github.com/linkedin/WhereHows.git
- Put a few 3rd-party jar files to wherehows-etl/extralibs directory. Some of these jar files may not be available in Maven Central or Artifactory. See the download instrucitons for more detail.
cd WhereHows/wherehows-etl/extralibs
- From the WhereHows root directory and build all the modules:
./gradlew build
- Start the metadata ETL and API service:
./gradlew wherehows-backend:runPlayBinary
- In a new terminal, start the web front-end:
./gradlew wherehows-frontend:runPlayBinary
. The WhereHows UI is available at http://localhost:9000 by default. You can change the port number by editing the value ofproject.ext.httpPort
inwherehows-frontend/build.gradle
.
Check out the current roadmap for WhereHows.
Want to contribute? Check out the Contributors Guide
Want help? Check out the Gitter chat room and Google Groups