mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-11-04 04:29:13 +00:00 
			
		
		
		
	
		
			
	
	
		
			225 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
		
		
			
		
	
	
			225 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| 
								 | 
							
								#!/bin/bash
							 | 
						||
| 
								 | 
							
								#  Copyright 2021 Collate
							 | 
						||
| 
								 | 
							
								#  Licensed under the Apache License, Version 2.0 (the "License");
							 | 
						||
| 
								 | 
							
								#  you may not use this file except in compliance with the License.
							 | 
						||
| 
								 | 
							
								#  You may obtain a copy of the License at
							 | 
						||
| 
								 | 
							
								#  http://www.apache.org/licenses/LICENSE-2.0
							 | 
						||
| 
								 | 
							
								#  Unless required by applicable law or agreed to in writing, software
							 | 
						||
| 
								 | 
							
								#  distributed under the License is distributed on an "AS IS" BASIS,
							 | 
						||
| 
								 | 
							
								#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
							 | 
						||
| 
								 | 
							
								#  See the License for the specific language governing permissions and
							 | 
						||
| 
								 | 
							
								#  limitations under the License.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								cd "$(dirname "${BASH_SOURCE[0]}")" || exit
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								helpFunction()
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								   echo ""
							 | 
						||
| 
								 | 
							
								   echo "Usage: $0 -m mode -d database"
							 | 
						||
| 
								 | 
							
								   echo "\t-m Running mode: [ui, no-ui]. Default [ui]"
							 | 
						||
| 
								 | 
							
								   echo "\t-d Database: [mysql, postgresql]. Default [mysql]"
							 | 
						||
| 
								 | 
							
								   echo "\t-s Skip maven build: [true, false]. Default [false]"
							 | 
						||
| 
								 | 
							
								   echo "\t-x Open JVM debug port on 5005: [true, false]. Default [false]"
							 | 
						||
| 
								 | 
							
								   echo "\t-h For usage help"
							 | 
						||
| 
								 | 
							
								   echo "\t-r For Cleaning DB Volumes. [true, false]. Default [true]"
							 | 
						||
| 
								 | 
							
								   echo "\t-f Start Fuseki for RDF support: [true, false]. Default [true]"
							 | 
						||
| 
								 | 
							
								   exit 1 # Exit script after printing help
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								while getopts "m:d:s:x:r:f:h" opt
							 | 
						||
| 
								 | 
							
								do
							 | 
						||
| 
								 | 
							
								   case "$opt" in
							 | 
						||
| 
								 | 
							
								      m ) mode="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      d ) database="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      s ) skipMaven="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      x ) debugOM="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      r ) cleanDbVolumes="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      f ) startFuseki="$OPTARG" ;;
							 | 
						||
| 
								 | 
							
								      h ) helpFunction ;;
							 | 
						||
| 
								 | 
							
								      ? ) helpFunction ;;
							 | 
						||
| 
								 | 
							
								   esac
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								mode="${mode:=ui}"
							 | 
						||
| 
								 | 
							
								database="${database:=mysql}"
							 | 
						||
| 
								 | 
							
								skipMaven="${skipMaven:=false}"
							 | 
						||
| 
								 | 
							
								debugOM="${debugOM:=false}"
							 | 
						||
| 
								 | 
							
								authorizationToken="eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg"
							 | 
						||
| 
								 | 
							
								cleanDbVolumes="${cleanDbVolumes:=true}"
							 | 
						||
| 
								 | 
							
								startFuseki="${startFuseki:=true}"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								echo "Running local docker using mode [$mode] database [$database] and skipping maven build [$skipMaven] with cleanDB as [$cleanDbVolumes] and Fuseki [$startFuseki]"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								cd ../
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								echo "Stopping any previous Local Docker Containers"
							 | 
						||
| 
								 | 
							
								docker compose -f docker/development/docker-compose-postgres.yml down --remove-orphans
							 | 
						||
| 
								 | 
							
								docker compose -f docker/development/docker-compose.yml down --remove-orphans
							 | 
						||
| 
								 | 
							
								docker compose -f docker/development/docker-compose-fuseki.yml down --remove-orphans
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if [[ $skipMaven == "false" ]]; then
							 | 
						||
| 
								 | 
							
								    if [[ $mode == "no-ui" ]]; then
							 | 
						||
| 
								 | 
							
								        echo "Maven Build - Skipping Tests and UI"
							 | 
						||
| 
								 | 
							
								        mvn -DskipTests -DonlyBackend clean package -pl !openmetadata-ui
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								        echo "Maven Build - Skipping Tests"
							 | 
						||
| 
								 | 
							
								        mvn -DskipTests clean package
							 | 
						||
| 
								 | 
							
								    fi
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								    echo "Skipping Maven Build"
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								RESULT=$?
							 | 
						||
| 
								 | 
							
								if [ $RESULT -ne 0 ]; then
							 | 
						||
| 
								 | 
							
								  echo "Failed to run Maven build!"
							 | 
						||
| 
								 | 
							
								  exit 1
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if [[ $debugOM == "true" ]]; then
							 | 
						||
| 
								 | 
							
								 export OPENMETADATA_DEBUG=true
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if [[ $cleanDbVolumes == "true" ]]
							 | 
						||
| 
								 | 
							
								then
							 | 
						||
| 
								 | 
							
								  if [[ -d "$PWD/docker/development/docker-volume/" ]]
							 | 
						||
| 
								 | 
							
								  then
							 | 
						||
| 
								 | 
							
								      rm -rf $PWD/docker/development/docker-volume
							 | 
						||
| 
								 | 
							
								    fi
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if [[ $VIRTUAL_ENV == "" ]];
							 | 
						||
| 
								 | 
							
								then
							 | 
						||
| 
								 | 
							
								  echo "Please Use Virtual Environment and make sure to generate Pydantic Models";
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								  echo "Generating Pydantic Models";
							 | 
						||
| 
								 | 
							
								  make install_dev generate
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Start Fuseki if requested
							 | 
						||
| 
								 | 
							
								if [[ $startFuseki == "true" ]]; then
							 | 
						||
| 
								 | 
							
								    echo "Starting Apache Jena Fuseki for RDF support"
							 | 
						||
| 
								 | 
							
								    docker compose -f docker/development/docker-compose-fuseki.yml up -d
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    # Wait for Fuseki to be ready
							 | 
						||
| 
								 | 
							
								    until curl -s -f "http://localhost:3030/$/ping" > /dev/null 2>&1; do
							 | 
						||
| 
								 | 
							
								      echo 'Waiting for Fuseki to start...'
							 | 
						||
| 
								 | 
							
								      sleep 5
							 | 
						||
| 
								 | 
							
								    done
							 | 
						||
| 
								 | 
							
								    echo "✔ Fuseki is ready"
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    # Set RDF environment variables
							 | 
						||
| 
								 | 
							
								    export RDF_ENABLED=true
							 | 
						||
| 
								 | 
							
								    export RDF_STORAGE_TYPE=FUSEKI
							 | 
						||
| 
								 | 
							
								    export RDF_BASE_URI="https://open-metadata.org/"
							 | 
						||
| 
								 | 
							
								    export RDF_ENDPOINT="http://localhost:3030/openmetadata"
							 | 
						||
| 
								 | 
							
								    export RDF_REMOTE_USERNAME="admin"
							 | 
						||
| 
								 | 
							
								    export RDF_REMOTE_PASSWORD="admin"
							 | 
						||
| 
								 | 
							
								    export RDF_DATASET="openmetadata"
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								echo "Starting Local Docker Containers"
							 | 
						||
| 
								 | 
							
								echo "Using ingestion dependency: ${INGESTION_DEPENDENCY:-all}"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if [[ $database == "postgresql" ]]; then
							 | 
						||
| 
								 | 
							
								    docker compose -f docker/development/docker-compose-postgres.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose-postgres.yml up -d
							 | 
						||
| 
								 | 
							
								elif [[ $database == "mysql" ]]; then
							 | 
						||
| 
								 | 
							
								    docker compose -f docker/development/docker-compose.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose.yml up -d
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								    echo "Invalid database type: $database"
							 | 
						||
| 
								 | 
							
								    exit 1
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								RESULT=$?
							 | 
						||
| 
								 | 
							
								if [ $RESULT -ne 0 ]; then
							 | 
						||
| 
								 | 
							
								  echo "Failed to start Docker instances!"
							 | 
						||
| 
								 | 
							
								  exit 1
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								until curl -s -f "http://localhost:9200/_cat/indices/openmetadata_team_search_index"; do
							 | 
						||
| 
								 | 
							
								  echo 'Checking if Elastic Search instance is up...'
							 | 
						||
| 
								 | 
							
								  sleep 5
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								until curl -s -f --header 'Authorization: Basic YWRtaW46YWRtaW4=' "http://localhost:8080/api/v1/dags/sample_data"; do
							 | 
						||
| 
								 | 
							
								  echo 'Checking if Sample Data DAG is reachable...'
							 | 
						||
| 
								 | 
							
								  sleep 5
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								until curl -s -f --header "Authorization: Bearer $authorizationToken" "http://localhost:8585/api/v1/tables"; do
							 | 
						||
| 
								 | 
							
								  echo 'Checking if OM Server is reachable...'
							 | 
						||
| 
								 | 
							
								  sleep 5
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_data' \
							 | 
						||
| 
								 | 
							
								  --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
							 | 
						||
| 
								 | 
							
								  --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								  --data-raw '{
							 | 
						||
| 
								 | 
							
								        "is_paused": false
							 | 
						||
| 
								 | 
							
								      }'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								curl --location --request PATCH 'localhost:8080/api/v1/dags/extended_sample_data' \
							 | 
						||
| 
								 | 
							
								  --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
							 | 
						||
| 
								 | 
							
								  --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								  --data-raw '{
							 | 
						||
| 
								 | 
							
								        "is_paused": false
							 | 
						||
| 
								 | 
							
								      }'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								echo 'Validate sample data DAG...'
							 | 
						||
| 
								 | 
							
								sleep 5
							 | 
						||
| 
								 | 
							
								# This validates the sample data DAG flow
							 | 
						||
| 
								 | 
							
								make install
							 | 
						||
| 
								 | 
							
								python docker/validate_compose.py
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								sleep 5
							 | 
						||
| 
								 | 
							
								curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_usage' \
							 | 
						||
| 
								 | 
							
								  --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
							 | 
						||
| 
								 | 
							
								  --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								  --data-raw '{
							 | 
						||
| 
								 | 
							
								      "is_paused": false
							 | 
						||
| 
								 | 
							
								      }'
							 | 
						||
| 
								 | 
							
								sleep 5
							 | 
						||
| 
								 | 
							
								curl --location --request PATCH 'localhost:8080/api/v1/dags/index_metadata' \
							 | 
						||
| 
								 | 
							
								  --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
							 | 
						||
| 
								 | 
							
								  --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								  --data-raw '{
							 | 
						||
| 
								 | 
							
								      "is_paused": false
							 | 
						||
| 
								 | 
							
								      }'
							 | 
						||
| 
								 | 
							
								sleep 2
							 | 
						||
| 
								 | 
							
								curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_lineage' \
							 | 
						||
| 
								 | 
							
								  --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
							 | 
						||
| 
								 | 
							
								  --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								  --data-raw '{
							 | 
						||
| 
								 | 
							
								      "is_paused": false
							 | 
						||
| 
								 | 
							
								      }'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								echo "✔running reindexing"
							 | 
						||
| 
								 | 
							
								# Trigger ElasticSearch ReIndexing from UI
							 | 
						||
| 
								 | 
							
								curl --location --request POST 'http://localhost:8585/api/v1/apps/trigger/SearchIndexingApplication' \
							 | 
						||
| 
								 | 
							
								--header 'Authorization: Bearer eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								sleep 60 # Sleep for 60 seconds to make sure the elasticsearch reindexing from UI finishes
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# If RDF is enabled, trigger RDF indexing
							 | 
						||
| 
								 | 
							
								if [[ $startFuseki == "true" ]]; then
							 | 
						||
| 
								 | 
							
								    echo "✔running RDF reindexing"
							 | 
						||
| 
								 | 
							
								    # Trigger RDF ReIndexing from UI  
							 | 
						||
| 
								 | 
							
								    curl --location --request POST 'http://localhost:8585/api/v1/apps/trigger/RdfIndexApp' \
							 | 
						||
| 
								 | 
							
								    --header 'Authorization: Bearer eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg' \
							 | 
						||
| 
								 | 
							
								    --header 'Content-Type: application/json' \
							 | 
						||
| 
								 | 
							
								    --data-raw '{
							 | 
						||
| 
								 | 
							
								        "entities": ["all"],
							 | 
						||
| 
								 | 
							
								        "recreateIndex": true,
							 | 
						||
| 
								 | 
							
								        "batchSize": 100
							 | 
						||
| 
								 | 
							
								    }'
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    sleep 30 # Wait for RDF indexing to complete
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								tput setaf 2
							 | 
						||
| 
								 | 
							
								echo "✔ OpenMetadata is up and running"
							 | 
						||
| 
								 | 
							
								if [[ $startFuseki == "true" ]]; then
							 | 
						||
| 
								 | 
							
								    echo "✔ RDF/Knowledge Graph support is enabled"
							 | 
						||
| 
								 | 
							
								    echo "  - Fuseki UI: http://localhost:3030"
							 | 
						||
| 
								 | 
							
								    echo "  - SPARQL endpoint: http://localhost:3030/openmetadata/sparql"
							 | 
						||
| 
								 | 
							
								fi
							 | 
						||
| 
								 | 
							
								echo ""
							 |