From f5017905cee21b92bf582acec051244088126ded Mon Sep 17 00:00:00 2001 From: Franck Michel Date: Wed, 23 Aug 2023 15:42:47 +0200 Subject: [PATCH] Bug fixes in Docker deployment + rel 1.3.2 --- CHANGELOG.md | 6 +++++- codemeta.json | 10 +++++----- docker/README.md | 15 +++++++-------- docker/docker-compose.yml | 2 +- docker/mongo_tools/import-file.sh | 2 +- docker/mongo_tools/import-tools.sh | 2 +- docker/run.sh | 5 +---- docker/xr2rml_config/run_xr2rml.sh | 2 +- docker/xr2rml_docker.zip | Bin 10065 -> 11706 bytes 9 files changed, 22 insertions(+), 22 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f3b25de3..9c590c39 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,10 @@ # Changelog -## [CURRENT 1.3.2 SNAPSHOT] 2022-01-12 +## [CURRENT 1.3.2] 2023-08-23 + +Add Docker deplyment. + +## [1.3.2 SNAPSHOT] 2022-01-12 - fix bug in sha1() mixed path - document the sha1() mixed path - (partially) fix bug in pushDown: for any field that is an ObjectID with $oid field (such as "_id"), the value of the $oid is pushed instead of the serialization f the field itself diff --git a/codemeta.json b/codemeta.json index 96e96ade..0a2d4b17 100644 --- a/codemeta.json +++ b/codemeta.json @@ -4,14 +4,14 @@ "license": "https://spdx.org/licenses/Apache-2.0", "codeRepository": "https://github.com/frmichel/morph-xr2rml", "datePublished": "2015-04-02", - "dateModified": "2021-07-30", + "dateModified": "2023-08-23", "downloadUrl": "https://www.dropbox.com/sh/djnztipsclvcskw/AABT1JagzD4K4aCALDNVj-yra?dl=0", "issueTracker": "https://github.com/frmichel/morph-xr2rml/issues", - "name": "Morph-xR2RML", - "version": "1.3.1", + "name": "Morph-xR2RML: MongoDB-to-RDF translation", + "version": "1.3.2", "identifier": "10.5281/zenodo.5148233", - "description": "Morph-xR2RML is an implementation of the xR2RML mapping language that enables the description of mappings from relational or non relational databases to RDF. It comes with connectors for relational databases (MySQL, PostgreSQL, MonetDB) and the MongoDB NoSQL database.", - "developmentStatus": "active", + "description": "Morph-xR2RML is an implementation of the xR2RML mapping language (https://www.i3s.unice.fr/~fmichel/xr2rml_specification_v5.1.html) that enables the description of mappings from relational or non relational databases to RDF. It comes with connectors for relational databases (MySQL, PostgreSQL, MonetDB) and the MongoDB NoSQL database.", + "developmentStatus": "inactive", "referencePublication": [ "https://hal.science/hal-01207828", "https://hal.science/hal-01280951", diff --git a/docker/README.md b/docker/README.md index f28cada2..fd81e4f5 100644 --- a/docker/README.md +++ b/docker/README.md @@ -30,32 +30,31 @@ docker-compose up -d Now, both containers are started and ready to process data. -Script `run.sh` provides an example of how to (1) import data located in `mongo_import` into MongoDB, and (2) run Morph-xR2RML to translate the data to RDF and store the result in `xr2rml_output`. +Script `run.sh` provides an example of how to run the different steps manually: (1) import data located in `mongo_import` into MongoDB, and (2) run Morph-xR2RML to translate the data to RDF and store the result in `xr2rml_output`. ### Description of each folder -- `mongo_db`: will contain the actual Mongo database, so that you don't need to re-import files everytime you rerun it. +- `mongo_db`: will contain the actual Mongo database, so that you don't need to re-import files everytime you rerun Morph-xR2RML. - `mongo_tools`: set of handy bash scripts to import json/csv/tsv data into MongoDB. -- `mongo_import`: copy your files to import in this folder, it is mouned in the MongoDB container. -- `xr2rml_config`: mapping files, morph.properties, log configuration file, and bash scripts to run Morph-xR2RML. This folder is mouned in the Morph-xR2RML container. +- `mongo_import`: copy your files to import in this folder, it is moutned in the MongoDB container. +- `xr2rml_config`: mapping files (morph.properties, log configuration file) and bash scripts to run Morph-xR2RML. This folder is mounted in the Morph-xR2RML container. - `xr2rml_config`: where the RDF files will be written. -- `run.sh`: example script showing how to import data into MongoDB and run Morph-xR2RML to translate the data to RDF. +- `run.sh`: example script showing how to use evrything from your machine, i.e. to import data into MongoDB and run Morph-xR2RML to translate the data to RDF. ### Accessing Logs The `docker-compose.yml` mounts the Morph-xR2RML log directory to the Docker host in directory `log`. - Check it if an error occurs or if your mapping does not generate the expected triples. ### Changing Morph-xR2RML configuration and mappings -Put your mapping files in folder `xr2rml_config`. Script `run_xr2rml.sh` will be used to run the transltation from within the container. +Put your mapping files in folder `xr2rml_config`. Script `xr2rml_config/run_xr2rml.sh` will be used to run the transltation from within the container. -Mapping files can also be templates, with 2 predefined placeholders: `{{collection}}` and `{{dataset}}`. Script `run_xr2rml_template.sh` wil replace them before running the translation. Check the example mapping `xr2rml_config/mapping_movies.ttl` and how it is used by script `run.sh`. +Mapping files can also be templates, with 2 predefined placeholders: `{{collection}}` and `{{dataset}}`. Script `xr2rml_config/run_xr2rml_template.sh` will replace them before running the translation. Check the example mapping `xr2rml_config/mapping_movies.ttl` and how it is used by script `run.sh`. The main Morph-xR2RML configuration file is editable at ```xr2rml_config/morph.properties```. In particular that's where you would change the name of the MongoDB database. diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml index 4def05e5..ba887c97 100644 --- a/docker/docker-compose.yml +++ b/docker/docker-compose.yml @@ -2,7 +2,7 @@ version: '3.2' services: morph-xr2rml: - image: frmichel/morph-xr2rml + image: frmichel/morph-xr2rml:1.3.2 container_name: morph-xr2rml networks: - xr2rml-net diff --git a/docker/mongo_tools/import-file.sh b/docker/mongo_tools/import-file.sh index f72865fb..74205ade 100644 --- a/docker/mongo_tools/import-file.sh +++ b/docker/mongo_tools/import-file.sh @@ -38,7 +38,7 @@ index_col=$5 if [[ -z "$index_col" ]] ; then help; fi # Optional -extra_script=$5 +extra_script=$6 # Functions definitions diff --git a/docker/mongo_tools/import-tools.sh b/docker/mongo_tools/import-tools.sh index e98f54b8..4a666455 100644 --- a/docker/mongo_tools/import-tools.sh +++ b/docker/mongo_tools/import-tools.sh @@ -187,7 +187,7 @@ mongo_drop_import_file_index() { _collection_c=$4 _index_col_c=$5 - mongoimport --drop --type=_type --headerline --ignoreBlanks -d $_database_c -c $_collection_c $_file_c + mongoimport --drop --type=$_type --headerline --ignoreBlanks -d $_database_c -c $_collection_c $_file_c mongo --eval "db.${_collection_c}.createIndex({${_index_col_c}: 1})" localhost/$_database_c --quiet mongo --eval "db.${_collection_c}.count()" localhost/$_database_c --quiet } diff --git a/docker/run.sh b/docker/run.sh index f9c89b5c..b73d2351 100644 --- a/docker/run.sh +++ b/docker/run.sh @@ -16,9 +16,6 @@ docker exec -w /mongo_tools $MONGO_CONTAINER \ /bin/bash import-json-files.sh $DB $COLLECTION id # --- Run the translation to RDF -# Note that at start-up Morph-xR2RML shows these warning messages, just ignore them: -# SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". -# SLF4J: Defaulting to no-operation (NOP) logger implementation -# SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details. +# Note that at start-up Morph-xR2RML shows 3 SLF4J warning messages, just ignore them. docker exec -w /xr2rml_config $XR2RML_CONTAINER \ /bin/bash run_xr2rml_template.sh mapping_movies.ttl movies.ttl dataset1.0 $COLLECTION diff --git a/docker/xr2rml_config/run_xr2rml.sh b/docker/xr2rml_config/run_xr2rml.sh index b313f271..a9453b25 100644 --- a/docker/xr2rml_config/run_xr2rml.sh +++ b/docker/xr2rml_config/run_xr2rml.sh @@ -48,7 +48,7 @@ java -Xmx4g \ -jar "$JAR" \ --configDir $CONFIG_DIR \ --configFile xr2rml.properties \ - --mappingFile $CONFIG/$mappingFile \ + --mappingFile $CONFIG_DIR/$mappingFile \ --output $OUTPUT_DIR/$output \ >> $log date >> $log diff --git a/docker/xr2rml_docker.zip b/docker/xr2rml_docker.zip index e5dcb208f180b0d9ad4547fbc42143272796c1b8..2fdda4b9da79c3f413b8c9b1ff8b039b2cef82e4 100644 GIT binary patch delta 4853 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 Z_BP%@OH=mEViv^DdU{x2uA4ak{TCY3B;5c2