Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/faasm/faasm
High-performance stateful serverless runtime based on WebAssembly
https://github.com/faasm/faasm
cpp faas kubernetes mpi openmp serverless wasi wasm webassembly
Last synced: about 1 month ago
JSON representation
High-performance stateful serverless runtime based on WebAssembly
- Host: GitHub
- URL: https://github.com/faasm/faasm
- Owner: faasm
- License: apache-2.0
- Created: 2018-10-02T14:49:29.000Z (about 6 years ago)
- Default Branch: main
- Last Pushed: 2024-04-12T16:23:02.000Z (8 months ago)
- Last Synced: 2024-04-12T22:17:14.144Z (8 months ago)
- Topics: cpp, faas, kubernetes, mpi, openmp, serverless, wasi, wasm, webassembly
- Language: C++
- Homepage: https://faasm.readthedocs.io
- Size: 115 MB
- Stars: 834
- Watchers: 11
- Forks: 69
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-repositories - faasm/faasm - High-performance stateful serverless runtime based on WebAssembly (C++)
- awesome-list - faasm - performance stateful serverless runtime based on WebAssembly | faasm | 491 | (C++)
README
# Faasm [![Tests](https://github.com/faasm/faasm/workflows/Tests/badge.svg?branch=main)](https://github.com/faasm/faasm/actions) [![License](https://img.shields.io/github/license/faasm/faasm.svg)](https://github.com/faasm/faasm/blob/main/LICENSE.md) [![Release](https://img.shields.io/github/release/faasm/faasm.svg)](https://github.com/faasm/faasm/releases/) [![Contributors](https://img.shields.io/github/contributors/faasm/faasm.svg)](https://github.com/faasm/faasm/graphs/contributors/) [![codecov](https://codecov.io/gh/faasm/faasm/branch/main/graph/badge.svg?token=F7HBQ84OSD)](https://codecov.io/gh/faasm/faasm)
Faasm is a high-performance stateful serverless runtime.
Faasm provides multi-tenant isolation, yet allows functions to share regions of
memory. These shared memory regions give low-latency concurrent access to data,
and are synchronised globally to support large-scale parallelism across multiple
hosts.Faasm combines software fault isolation from WebAssembly with standard Linux
tooling, to provide security and resource isolation at low cost. Faasm runs
functions side-by-side as threads of a single runtime process, with low
overheads and fast boot times.Faasm defines a custom host interface that extends [WASI](https://wasi.dev/) to
include function inputs and outputs, chaining functions, managing state,
accessing the distributed filesystem, dynamic linking, pthreads, OpenMP and MPI.Our paper from Usenix ATC '20 on Faasm can be found
[here](https://www.usenix.org/conference/atc20/presentation/shillaker).Please see the [full documentation](https://faasm.readthedocs.io/en/latest/) for
more details on the code and architecture.## Quick start
Update submodules and activate the virtual environment:
```bash
git submodule update --init --recursive
source ./bin/workon.sh
```Start a Faasm cluster locally using `docker compose`:
```bash
faasmctl deploy.compose
```To compile, upload and invoke a C++ function using this local cluster you can
use the [faasm/cpp](https://github.com/faasm/cpp) container:```bash
faasmctl cli.cpp# Compile the demo function
inv func demo hello# Upload the demo "hello" function
inv func.upload demo hello# Invoke the function
inv func.invoke demo hello
```For more information on next steps you can look at the [getting started
docs](https://faasm.readthedocs.io/en/latest/source/getting_started.html)## Acknowledgements
This project has received funding from the European Union's Horizon 2020
research and innovation programme under grant agreement No 825184 (CloudButton),
the UK Engineering and Physical Sciences Research Council (EPSRC) award 1973141,
and a gift from Intel Corporation under the TFaaS project.