Open Data Mesh Platform is a platform that manages the full lifecycle of a data product from deployment to retirement. It uses the Data Product Descriptor Specification to create, deploy and operate data product containers in a mesh architecture.
The project requires the following dependencies:
- Java 11
- Maven 3.8.6
Clone the repository and move to the project root folder
git clone [email protected]:opendatamesh-initiative/odm-platform.git
cd odm-platform
First, in order to correctly download external Maven dependencies from GitHub Packages, you need to configure the Maven settings.xml
file with your GitHub credentials. The GITHUB TOKEN must have read:packages
permissions.
<settings>
<servers>
<server>
<id>github</id>
<username>GITHUB USERNAME</username>
<password>GITHUB TOKEN</password>
</server>
</servers>
</settings>
The settings.xml
file is in the ~/.m2
directory.
For additional information, see "How to install an Apache Maven package from GitHub Packages".
Then run:
mvn clean install -DskipTests
Run the application:
java -jar registry-server/target/odm-platform-pp-registry-server-1.0.0.jar
*version could be greater than 1.0.0, check on parent POM
To stop the application type CTRL+C or just close the shell. To start it again re-execute the following command:
java -jar registry-server/target/odm-platform-pp-registry-server-1.0.0.jar
Note: The application run in this way uses an in-memory instance of the H2 database. For this reason, the data is lost every time the application is terminated. On the next restart, the database is recreated from scratch.
Clone the repository and move it to the project root folder
git clone [email protected]:opendatamesh-initiative/odm-platform.git
cd odm-platform
Here you can find the Dockerfile which creates an image containing the application by directly copying it from the build executed locally (i.e. from target
folder).
First, in order to correctly download external Maven dependencies from GitHub Packages, you need to configure the Maven settings.xml
file with your GitHub credentials. The GITHUB TOKEN must have read:packages
permissions.
<settings>
<servers>
<server>
<id>github</id>
<username>GITHUB USERNAME</username>
<password>GITHUB TOKEN</password>
</server>
</servers>
</settings>
The settings.xml
file is in the ~/.m2
directory.
For additional information, see "How to install an Apache Maven package from GitHub Packages".
Then you need to first execute the build locally by running the following command:
mvn clean install -DskipTests
The image generated from Dockerfile contains only the application. It requires a database to run properly. The supported databases are MySql and Postgres. If you do not already have a database available, you can create one by running the following commands:
MySql
docker run --name odmp-mysql-db -d -p 3306:3306 \
-e MYSQL_DATABASE=ODMREGISTRY \
-e MYSQL_ROOT_PASSWORD=root \
mysql:8
Postgres
docker run --name odmp-postgres-db -d -p 5432:5432 \
-e POSTGRES_DB=odmpdb \
-e POSTGRES_USER=postgres \
-e POSTGRES_PASSWORD=postgres \
postgres:11-alpine
Check that the database has started correctly:
MySql
docker logs odmp-mysql-db
Postgres
docker logs odmp-postgres-db
Build the Docker image of the application and run it.
*Before executing the following commands change properly the value of arguments DATABASE_USERNAME
, DATABASE_PASSWORD
and DATABASE_URL
. Reported commands already contains right argument values if you have created the database using the commands above.
MySql
docker build -t odmp-mysql-app . -f Dockerfile \
--build-arg DATABASE_URL=jdbc:mysql://localhost:3306/ODMREGISTRY \
--build-arg DATABASE_USERNAME=root \
--build-arg DATABASE_PASSWORD=root \
--build-arg FLYWAY_SCRIPTS_DIR=mysql
Postgres
docker build -t odmp-postgres-app . -f Dockerfile \
--build-arg DATABASE_URL=jdbc:postgresql://localhost:5432/odmpdb \
--build-arg DATABASE_USERNAME=postgres \
--build-arg DATABASE_PASSWORD=postgres \
--build-arg FLYWAY_SCRIPTS_DIR=postgresql
Run the Docker image.
Note: Before executing the following commands remove the argument --net host
if the database is not running on localhost
MySql
docker run --name odmp-mysql-app -p 8001:8001 --net host odmp-mysql-app
Postgres
docker run --name odmp-postgres-app -p 8001:8001 --net host odmp-postgres-app
*Before executing the following commands:
- change the DB name to
odmp-postgres-db
if you are using postgres and not mysql - change the instance name to
odmp-postgres-app
if you are using postgres and not mysql
docker stop odmp-mysql-app
docker stop odmp-mysql-db
To restart a stopped application execute the following commands:
docker start odmp-mysql-db
docker start odmp-mysql-app
To remove a stopped application to rebuild it from scratch execute the following commands :
docker rm odmp-mysql-app
docker rm odmp-mysql-db
Clone the repository and move it to the project root folder
git clone [email protected]:opendatamesh-initiative/odm-platform.git
cd odm-platform
Build the docker-compose images of the application and a default PostgreSQL DB (v11.0).
Before building it, create a .env
file in the root directory of the project similar to the following one:
DATABASE_NAME=odmpdb
DATABASE_PASSWORD=pwd
DATABASE_USERNAME=usr
DATABASE_PORT=5432
SPRING_PORT=8001
Then, build the docker-compose file:
docker-compose build
Run the docker-compose images.
docker-compose up
Stop the docker-compose images
docker-compose down
To restart a stopped application execute the following commands:
docker-compose up
To rebuild it from scratch execute the following commands :
docker-compose build --no-cache
You can invoke REST endpoints through OpenAPI UI available at the following url:
*for a static version of the API documentation, check the APIdoc.md
file
If the application is running using an in memory instance of H2 database you can check the database content through H2 Web Console available at the following url:
In all cases you can also use your favourite sql client providing the proper connection parameters