Skip to main content

Software Heritage object storage

Project description

Content-addressable object storage for the Software Heritage project.

Quick start

The easiest way to try the swh-objstorage object storage is to install it in a virtualenv. Here, we will be using virtualenvwrapper but any virtual env tool should work the same.

In the example below we will create a new objstorage using the pathslicer backend.

~/swh$ mkvirtualenv -p /usr/bin/python3 swh-objstorage
[...]
(swh-objstorage) ~/swh$ pip install swh.objstorage
[...]
(swh-objstorage) ~/swh$ cat >local.yml <<EOF
objstorage:
  cls: pathslicing
  root: /tmp/objstorage
  slicing: 0:2/2:4/4:6
EOF
(swh-objstorage) ~/swh$ mkdir /tmp/objstorage
(swh-objstorage) ~/swh$ swh objstorage -C local.yml rpc-serve -p 15003
INFO:swh.core.config:Loading config file local.yml
======== Running on http://0.0.0.0:15003 ========
(Press CTRL+C to quit)

Now we have an API listening on http://0.0.0.0:15003 we can use to store and retrieve objects from. In an other terminal, you can import all the files from a local directory in this objstorage:

~/swh$ workon swh-objstorage
(swh-objstorage) ~/swh$ cat >remote.yml <<EOF
objstorage:
  cls: remote
  url: http://127.0.0.1:15003
EOF
(swh-objstorage) ~/swh$ swh objstorage -C remote.yml import .
INFO:swh.core.config:Loading config file remote.yml
Imported 1369 files for a volume of 722837 bytes in 2 seconds

Test dependencies

Some tests do require non-python dependencies to be installed on the machine:

  • Ceph: the ceph executable can be used to run winery tests. When the ceph binary is available, the winery tests will try to create a real ceph Rados Block Device (rbd) pool to run.

  • Azurite: the azurite tool is needed for Azure backend tests. Since it’s a npm package, you can install it using:

    ~/swh$ npm install -g azurite

    Note: you may want to configure your npm setup so it uses ~/.local as prefix for global installations:

    ~/swh$ npm config set prefix '~/.local/'

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

swh_objstorage-5.1.0.tar.gz (120.7 kB view details)

Uploaded Source

Built Distribution

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

swh_objstorage-5.1.0-py3-none-any.whl (118.3 kB view details)

Uploaded Python 3

File details

Details for the file swh_objstorage-5.1.0.tar.gz.

File metadata

  • Download URL: swh_objstorage-5.1.0.tar.gz
  • Upload date:
  • Size: 120.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.12

File hashes

Hashes for swh_objstorage-5.1.0.tar.gz
Algorithm Hash digest
SHA256 90e085a0ff3725f9e31b17071eb6254a4b35c8ef5410272eb938e3334aaf985f
MD5 05414a452813bb340b6c32538ccc4314
BLAKE2b-256 5dd317164e5248d8222b592f4bfe37537b8116bad9767668a58166b8aa4e3151

See more details on using hashes here.

File details

Details for the file swh_objstorage-5.1.0-py3-none-any.whl.

File metadata

  • Download URL: swh_objstorage-5.1.0-py3-none-any.whl
  • Upload date:
  • Size: 118.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.12

File hashes

Hashes for swh_objstorage-5.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d1f08ab2c4015ae34be6e80f3bdbf0fa36329213d2b4e68585478b9732854802
MD5 772f27820a8ab8f9c439f2611e7a2b81
BLAKE2b-256 565f72fe0ad2e5bad8d44a7cfe2ef6732c810c809042a048675c1530ebcb5884

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