Skip to main content

RESTful web service which makes any storage system X available as an S3-compatible REST API

Project description

x2s3

Python CI

RESTful web service which makes any storage system X available as an S3-compatible REST API, hence the name "X to S3". It was initially built to support cloud-compatible microscopy image viewers such as N5 Viewer (BigDataViewer) and Neuroglancer.

At Janelia, we use x2s3 to make private buckets on Seagate Lyve appear public, and to proxy internal resources (e.g. VAST S3). It can also be used as a pop-up file service for quickly viewing local images in BigDataViewer or Neuroglancer.

Features

  • Extensible support for backend storage systems
  • Optional web-based bucket explorer
  • Hidden buckets
  • Partial buckets (chroot-like prefixes)
  • Non-blocking object streaming

Inspired by S3 proxies such as oxyno-zeta/s3-proxy and pottava/aws-s3-proxy, this service goes a step further to implement enough of the AWS S3 API to be useable by AWS clients, such as BigDataViewer. The S3 proxy implements which do this well (e.g. gaul/s3proxy) only proxy a single bucket at a time.

S3 endpoints implemented:

S3 features omitted:

  • Permissions
  • Encryption
  • Versioning
  • RequestPayer
  • etc.

Running

Create a config.yaml file that contains all of the buckets you want to serve. You can get started quickly by using the provided example template:

cp config.template.yaml config.yaml

See the documentation for more information about the configuration file.

The simplest way to run the service is to use Docker:

docker run -it -p 8000:8000 -v ./config.yaml:/app/x2s3/config.yaml ghcr.io/janeliascicomp/x2s3:latest

You can also run the service with Python/Uvicorn directly. See the development documentation for more information on setting that up.

Production Deployment

For production deployments, we recommend using an orchestrator (like Docker Compose) to run the prebuilt Docker container along with an Nginx reverse proxy which provides caching and TLS termination.

Create a ./docker/.env file that looks like this:

CONFIG_FILE=/path/to/config.yaml
VAR_DIR=/path/to/var/dir
CERT_DIR=/path/to/certs
NGINX_CACHE_DIR=/path/to/cache

These properties configure the service as follows:

  • CONFIG_FILE: path to the config.yaml settings file
  • VAR_DIR: optional path to the var directory containing access keys referenced by config.yaml
  • CERT_FILE: optional path to the SSL cert file
  • KEY_FILE: optional path to the SSL key file
  • NGINX_CACHE_DIR: path for Nginx response caching (you can disable caching by editing nginx.conf)

Now you can bring up the container:

cd docker/
docker compose up -d

Additional Documentation

  • Configuation - how to use config.yaml to configure the service
  • Development - notes on developing the service codebase

Attributions

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

x2s3-0.8.2.tar.gz (22.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

x2s3-0.8.2-py3-none-any.whl (20.5 kB view details)

Uploaded Python 3

File details

Details for the file x2s3-0.8.2.tar.gz.

File metadata

  • Download URL: x2s3-0.8.2.tar.gz
  • Upload date:
  • Size: 22.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for x2s3-0.8.2.tar.gz
Algorithm Hash digest
SHA256 2fa7c291792b5eb60f59ba6b5e9f61d200564dda5d71f3b211e663807fabb597
MD5 d4f27078c4028106e946b00030c859ac
BLAKE2b-256 315336a5fb84c8e54047c000fc8ec5affb9dfc81c751070312db3e83f8d8e7d7

See more details on using hashes here.

File details

Details for the file x2s3-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: x2s3-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 20.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for x2s3-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6a90c5680c34d6da0c3a91e06abe4b88e4020943e8198b6268bac3d3f5d68326
MD5 f2a15401c50739983a955118fa7fd67d
BLAKE2b-256 92b9582c780e2be58791b79464b3f9a18002692e6a0f2769025d3283f34d87aa

See more details on using hashes here.

Supported by

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