Skip to main content

a helper to ingest data in sdap

Project description

SDAP manager for ingestion of datasets

Prerequisites

python 3

Install anaconda for python 3. From the graphic install for example for macos:

https://www.anaconda.com/distribution/#macos

git lfs (for development)

Git lfs for the deployment from git, see https://git-lfs.github.com/

If not available you have to get netcdf files for test, if you do need the tests.

Deployed nexus on kubernetes cluster

See project https://github.com/apache/incubator-sdap-nexus

$ helm install nexus .  --namespace=sdap --dependency-update -f ~/overridden-nexus-values.yml 

Install, Configure and run

Install

Stay logged in as user

$ pip install sdap-ingest-manager

Configure the ingestion system

Catch the message at the end of the installation output

--------------------------------------------------------------
Now, create configuration files in
***/<some path>>/.sdap_ingest_manager***
 Use templates and examples provided there
--------------------------------------------------------------

If the path does not show in the installation stdout, you can find it with the command:

python -c "import sys; print(f'{sys.prefix}/.sdap_ingest_manager')"

Use the path shown in the message and create your own configuration files:

$ cd /<some path>>/.sdap_ingest_manager
$ cp sdap_ingest_manager.ini.default sdap_ingest_manager.ini

Edit and update the newly created files by following instructions in the comments.

Note that the .ini.default file will be used if no value is configured in the .ini file. So you can have a simplified .ini file with only your specific configuration. Don't put your specific configuration in the .ini.default file, it will be replaced when you upgrade the package.

Example of a simplified .ini file:

[COLLECTIONS_YAML_CONFIG]
yaml_file = collections.yml

[OPTIONS]
# set to False to actually call the ingestion command for each granule
dry_run = False
# set to True to automatically list the granules as seen on the nfs server when they are mounted on the local file system.
deconstruct_nfs = True
# number of parallel ingestion pods on kubernetes (1 per granule)
parallel_pods = 2

[INGEST]
# kubernetes namespace where the sdap cluster is deployed
kubernetes_namespace = nexus-dev

Configure the collections

You can configure it in a local yaml file referenced in the sdap_ingest_manager.ini file.

It can also be in a google spreadsheet.

If both are configured, the local yaml file will be used.

Run the ingestion

On the list of the configured collections:

$ run_collections

The number of parallel jobs can be updated during the process in the sdap_ingest_manager.ini file.

If interrupted (killed) the process will restart where it was.

For developers

deploy project

$ bash
$ git clone ...
$ cd sdap_ingest_manager
$ python -m venv venv
$ source ./venv/bin/activate
$ pip install .

Note the command pip install -e . does not work as it does not deploy the configuration files.

Update the project

Update the code and the test with your favorite IDE (e.g. pyCharm).

Test and create the package

A package based on the dev branch is automatically published at github release when a push is made.

Change version in file setup.py

$ python setup.py test
$ git tag <version>
$ git push origin <version>

The release will be automatically pushed to pypi though github action.

Containerization

Docker

(development version)

cd containers/docker
docker build --no-cache --tag tloubrieu/sdap-ingest-manager:latest .    
docker run -it --name sdap-ingest-manager -v sdap_ingest_config:/usr/local/.sdap_ingest_manager tloubrieu/sdap-ingest-manager:latest
docker volume inspect sdap_ingest_config

You can see the configuration files in the directory of the named volume (for example /var/lib/docker/volumes/sdap_ingest_config/_data).

Note on macos, to access this directory, you need to go inside the Virtual Machine which runs docker service. To update the configuration on macos:

docker run --rm -it -v /:/vm-root alpine:edge /bin/ash
cd /vm-root/var/lib/docker/volumes/sdap_ingest_config/_data
cp sdap_ingest_manager.ini.default sdap_ingest_manager.ini
vi sdap_ingest_manager.ini

To publish the docker image on dockerhub do (step necessary for kubernetes deployment):

docker login
docker push tloubrieu/sdap-ingest-manager:latest

Kubernetes

Create the configMap for your deployment

Prepare a configMap from existing native config files:

kubectl create configmap collection-ingester-config --from-file=venv/.sdap_ingest_manager -n sdap

Optionally you can update the configMap manually if the one you started from is not what you needed:

kubectl get configmap collection-ingester-config -o yaml -n sdap > containers/kubernetes/sdap_ingester_config.yml

Manually edit the yml file to only keep the configuration which is specific to the deployment (if different from the current one)

Replace the configmap:

kubectl delete configmap collection-ingester-config -n sdap
kubectl apply -f containers/kubernetes/sdap_ingester_config.yml -n sdap

Launch the service

kubectl apply -f containers/kubernetes/job.yml -n sdap

Delete the service:

kubectl delete jobs --all -n sdap

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sdap_ingest_manager-0.3.0rc2.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

sdap_ingest_manager-0.3.0rc2-py3-none-any.whl (3.9 MB view details)

Uploaded Python 3

File details

Details for the file sdap_ingest_manager-0.3.0rc2.tar.gz.

File metadata

  • Download URL: sdap_ingest_manager-0.3.0rc2.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.7

File hashes

Hashes for sdap_ingest_manager-0.3.0rc2.tar.gz
Algorithm Hash digest
SHA256 d3e67e4b798cb57b0fd8f108d5b92d52820575808742dbf25ad696f66a732cf3
MD5 b5a3ecb6a0d99a07d14ab97738155d24
BLAKE2b-256 914d8e626fdc83b802127a36e07ce70da38f2dc40facb4408edb7cf0b6ad191f

See more details on using hashes here.

File details

Details for the file sdap_ingest_manager-0.3.0rc2-py3-none-any.whl.

File metadata

  • Download URL: sdap_ingest_manager-0.3.0rc2-py3-none-any.whl
  • Upload date:
  • Size: 3.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.7

File hashes

Hashes for sdap_ingest_manager-0.3.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 abd3204a1b86c1de4de1c08845be70a1e1723ff7aeaf35d91f7f6d3bdc6183b6
MD5 c2b2ed51c64306ac04a5ac87e1b52a02
BLAKE2b-256 8b011c9ef0a63d57cc0b1474fa6d6a8c8a444690f0895a64eca0e6839133e93c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page