Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mbailleu/avocado
https://github.com/mbailleu/avocado
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/mbailleu/avocado
- Owner: mbailleu
- License: mit
- Created: 2021-05-03T16:28:45.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-09-20T14:20:04.000Z (over 3 years ago)
- Last Synced: 2024-08-03T01:24:36.361Z (6 months ago)
- Language: C++
- Size: 65.4 KB
- Stars: 15
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- Awesome-SGX-Open-Source - https://github.com/mbailleu/avocado
README
# Avocado
Avocado is secure distributed in-memory key-value store. It leverages SGX to provide trust in an untrusted setting. You can find more details in our USENIX ATC'21 [paper](https://www.usenix.org/conference/atc21/presentation/bailleu).
## Getting started
### Dependencies
* [cmake](https://cmake.org/)
* [fmt](https://fmt.dev/latest/index.html)
* [glog](https://github.com/google/glog)
* [folly](https://github.com/facebook/folly)
* [openssl](https://www.openssl.org/)
* [jemalloc](https://github.com/jemalloc/jemalloc)
* [double-conversion](https://github.com/google/double-conversion)
* [numactl](https://github.com/numactl/numactl)
* [libevent](https://libevent.org/)
* [gflags](https://github.com/gflags/gflags)
* [docopt.cpp](https://github.com/docopt/docopt.cpp)
* [scone](https://sconedocs.github.io/)### Building
You can build the non-secure version by doing the following
```[bash]
git submodule update --init --recursive
mkdir build
cd build
cmake ..
cmake --build . --parallel
```You can build the secure version with the scone images. However, you might be required to patch the folly library with the provided [patch](folly-scone.patch). You should also set the SCONE flag in cmake
```[bash]
cmake .. -DSCONE=ON
```#### Notes
We used a internal development version of scone to run Avocado. We have not tested it with the publicly available version.### Running
The build process will generate a benchmark application ```build/src/server``` which you can use to run the benchmark, see the ```--help``` flag for information.