Skip to content
This repository has been archived by the owner on Feb 17, 2019. It is now read-only.

pviotti/hybris

Repository files navigation

Hybris Build Status

Hybris is a key-value hybrid cloud storage system that robustly replicates data over untrusted public clouds while keeping metadata on trusted private premises.
Thanks to this design, Hybris provides strong consistency guarantees (i.e., linearizability) and affordable Byzantine fault tolerance (i.e., withstanding f faulty clouds with as few as 2f+1 replicas).
Hybris is also very efficient: in the common case it writes to f+1 clouds and it reads from one single cloud.

Hybris architecture

For more information and detailed benchmarks read our SoCC14 paper.
A version of the personal cloud application StackSync featuring Hybris as storage backend is available here.

Code base overview

The code base of Hybris is composed by two main modules: MdsManager and KvsManager; the first is a thin wrapper layer of the metadata distributed storage service (i.e. ZooKeeper or Consul), while KvsManager implements the storage primitives towards the APIs of the main public cloud storage services - currently, it supports Amazon S3, Google Cloud Storage, Rackspace Cloud Files and Windows Azure Blob.

Maven is used to compile the code and manage the dependencies.

Read the wiki for more information on development setup.

Authors and license

Hybris has been developed at EURECOM as part of the CloudSpaces European research project. Its code is released under the terms of Apache 2.0 license.

Erasure coding support is provided by the Jerasure library through its JNI bindings.

Releases

No releases published

Packages

No packages published