Skip to main content

h5py compatible client lib for HDF REST API

Project description

https://travis-ci.org/HDFGroup/h5pyd.svg?branch=master

Python client library for HDF5 REST interface

Introduction

This repository contains library, test, and examples of h5pyd - a Python package for the HDF REST interface.

The library is provides a high-level interface to the REST specification that is generally easier to use than invoking http calls directly.

The package is based on the popular h5py package and aims to be source compatible with the h5py high level interface.

Websites

Installing

Via pip:

pip install h5pyd

From a release tarball or Git checkout:

python setup.py install

By default the examples look for a local instance of HSDS. See the https://github.com/HDFGroup/hsds for instructions on installing and running HSDS.

These tests are also to designed to work with HSDS (see https://github.com/HDFGroup/hsds). Install HSDS locally, or set environment variables (see next section) to point to an existing HSDS instance.

h5pyd can all be run in serverless mode with either AWS Lambda or direct mode (storage system accessed directly).

To use with AWS Lambda, set the HS_ENDPOINT to: “http+lambda://hslambda” where “hslambda” is the name of the lambda function. When using AWS Lambda some additional environment variables need to be set:

  • AWS_LAMBDA_GATEWAY - AWS Lambda endpoint, e.g.: https://lambda.us-west-2.amazonaws.com

  • AWS_REGION - Region where the Lambda function is installed, e.g.: us-west-2

  • AWS_SECRET_ACCESS_KEY - Your AWS secret access AWS_SECRET_ACCESS_KEY

  • AWS_ACCESS_KEY_ID - Your AWS access key ID

To use in direct mode, set the HS_ENDPOINT to “local”. For direct mode, some additional environment variables are needed to be defined:

  • BUCKET_NAME - name of the S3 Bucket, Azure Container, or Posix top level folder

To use “local” mode with S3, define these variables:

  • AWS_S3_GATEWAY - AWS S3 endpoint, e.g.: https://s3.us-west-2.amazonaws.com

  • AWS_REGION - Region where the Lambda function is installed, e.g.: us-west-2

  • AWS_SECRET_ACCESS_KEY - Your AWS secret access AWS_SECRET_ACCESS_KEY

  • AWS_ACCESS_KEY_ID - Your AWS access key ID

To use “local” mode with Azure, defined these variables:

  • AZURE_CONNECTION_STRING - The connection string for your Azure storage account

To use “local” with Posix storage, define these variables:

  • ROOT_DIR - The top level directory used for storage (i.e. the parent directory of “buckets”)

H5PYD Command Line Apps

Serveral utility applications are included with this package:

  • hsconfigure - save endpoint, username, and password in config files

  • hsacl - read/update ACL (access control list) for a given folder or domain

  • hscopy - copy a domain

  • hsrm - delete a domain or folder

  • hsdiff - compare HDF5 file with HSDS domain

  • hsget - create an HDF5 file from HSDS domain

  • hsinfo - get server status or domain details

  • hsload - upload an HDF5 file to an HSDS domain

  • hsls - list contents of domain or folder

  • hsmv - change the naame of a domain

  • hstouch - create new domain or folder

Use the --help option to get usage information for each command.

Testing

Setup the following environment variables that inform h5pyd which endpoint and username to use:

  • HS_ENDPOINT - “http://127.0.0.1:5000” for HSDS installed locally or appropriate remote endpoint

  • HS_USERNAME - “test_user1” or your preferred username

  • HS_PASSWORD - password for above username - “test” for test_user1 with local HSDS install

  • TEST2_USERNAME - “test_user2” or your preffered username

  • TEST2_PASSWORD - password for above username - “test” for test_user2 with local HSDS install

  • H5PYD_TEST_FOLDER - server folder that will be used for generated files. Example: “/home/test_user1/h5pyd_test/”. Use hstouch command to create the folder before running the test, e.g.: $ hstouch /home/test_user1/h5pyd_test/

Run: $python testall.py to execute the test suite.

Uninstalling

Just remove the install directory and all contents to uninstall.

Reporting bugs (and general feedback)

Create new issues at http://github.com/HDFGroup/h5pyd/issues for any problems you find.

For general questions/feedback, please use the HSDS forum (https://forum.hdfgroup.org/c/hsds).

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

h5pyd-0.18.0.tar.gz (139.8 kB view details)

Uploaded Source

File details

Details for the file h5pyd-0.18.0.tar.gz.

File metadata

  • Download URL: h5pyd-0.18.0.tar.gz
  • Upload date:
  • Size: 139.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for h5pyd-0.18.0.tar.gz
Algorithm Hash digest
SHA256 53cee21d7f2d8c25671e4a9d615b1833a495bc198bc44fe14d841298ae0684be
MD5 f7d1888fec7d54058aa874d0952e02bb
BLAKE2b-256 8d9ef7caf7486a22c3f8dde60228a9905c73dd676cdcacbdaa4390acfc9ae959

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