Skip to content

europace/openmetadata-helm-charts

 
 

Repository files navigation

OpenMetadata

Open Metadata Helm Charts Artifact Hub

Introduction

This Repository houses Kubernetes Helm charts for deploying Open Metadata and it's dependencies (Elastic Search and MySQL) on a Kubernetes Cluster.


Setup

Set up a Kubernetes Cluster

Install the below tools:

  • Kubectl to manage Kubernetes Resources
  • Helm to deploy resources based on Helm Charts from this repository. Note, we only support Helm 3

Quickstart

Assuming kubectl context points to the correct kubernetes cluster, first create kubernetes secrets that contain MySQL and Airflow passwords as secrets.

kubectl create secret generic mysql-secrets --from-literal=openmetadata-mysql-password=openmetadata_password
kubectl create secret generic airflow-secrets --from-literal=openmetadata-airflow-password=admin

The above commands sets the passwords as an example. Change to any password of choice.

Next, we install Open Metadata dependencies.

Add openmetadata helm repo by running the following -

helm repo add open-metadata https://helm.open-metadata.org/

Run the command helm repo list to list the addition of openmetadata helm repo -

NAME        	URL                            
open-metadata	https://helm.open-metadata.org/

Assuming kubectl context points to the correct kubernetes cluster, first create kubernetes secrets that contain airflow mysql password as secrets.

kubectl create secret generic airflow-mysql-secrets --from-literal=airflow-mysql-password=airflow_pass

Deploy the dependencies by running

helm install openmetadata-dependencies open-metadata/openmetadata-dependencies

Note - The above command uses configurations defined here. You can modify any configuration and deploy by passing your own values.yaml

helm install openmetadata-dependencies open-metadata/openmetadata-dependencies --values <<path-to-values-file>>

Run kubectl get pods to check whether all the pods for the dependencies are running. You should get a result similar to below.

NAME                            READY   STATUS    RESTARTS   AGE
elasticsearch-0                 1/1     Running   0          3m56s
mysql-0                         1/1     Running   0          3m56s

Next, deploy the openmetadata by running the following

helm install openmetadata open-metadata/openmetadata

Values in values.yaml are preset to match with dependencies deployed using openmetadata-dependencies with release name "openmetadata-dependencies". If you deployed helm chart using different release name, make sure to update values.yaml accordingly before installing.

Run kubectl get pods command to check the statuses of pods running you should get a result similar to below.

NAME                            READY   STATUS    RESTARTS   AGE
elasticsearch-0                 1/1     Running   0          5m34s
mysql-0                         1/1     Running   0          5m34s
openmetadata-5566f4d8b9-544gb   1/1     Running   0          98s

To expose the Openmetadata UI locally, run the below command -

kubectl port-forward deployment/openmetadata 8585:8585

Setting Up Chart Testing Lint with Pre-commit Hook

Why Chart Testing Lint?

When working with Helm charts, it's important to ensure that they meet best practices, are free from errors, and follow the defined guidelines. Chart Testing (ct) Lint is a tool designed to automate this process by linting your Helm charts before committing them to the repository. It helps to:

  • Catch errors early.
  • Enforce best practices in chart development.
  • Automatically validate changes to Helm charts during pull requests or commits.

This guide will show you how to integrate chart-testing linting into your pre-commit hooks to automatically lint charts before committing them. It also allows you to manually trigger linting when needed.

Prerequisites

Before setting up the pre-commit hook, make sure you have the following dependencies installed:

1. Install chart-testing

chart-testing is a command-line tool used to lint and validate Helm charts. It can be installed using Homebrew on macOS.

To install chart-testing, run the following command:

brew install chart-testing
2. Install pre-commit

To install the pre-commit tool, run:

pip install pre-commit

Setting Up Pre-commit Hook for Chart Testing Lint

1. Install the Pre-commit Hook

Once the dependencies are installed, navigate to your repository and run the following command to install the pre-commit hook:

pre-commit install

This will set up the pre-commit hook in the .git/hooks directory of your repository.

2. Manually Trigger the Linting Process

If you need to manually trigger the linting of charts at any time, navigate to the root of your repository and run:

ct lint --all --check-version-increment=false --use-helmignore

Documentation and Support

Check out OpenMetadata documentation for a complete description of OpenMetadata's features.

Join our Slack Community if you get stuck, want to chat, or are thinking of a new feature.

Or join the group at https://groups.google.com/g/openmetadata-users

We're here to help - and make OpenMetadata even better!

Contributors

We ❤️ all contributions, big and small!

Read Build Code and Run Tests for how to setup your local development environment. Get started with our Good first issues.

If you want to, you can reach out via Slack or email and we'll set up a pair programming session to get you started.

License

OpenMetadata is released under Apache License, Version 2.0

About

No description, website, or topics provided.

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Smarty 100.0%