Skip to content
/ limbo Public
forked from tursodatabase/limbo

Limbo is a work-in-progress, in-process OLTP database management system, compatible with SQLite.

License

Notifications You must be signed in to change notification settings

pereman2/limbo

This branch is 103 commits ahead of, 3639 commits behind tursodatabase/limbo:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ab99596 · Jun 8, 2024
Mar 3, 2024
Mar 28, 2024
Mar 3, 2024
Jun 8, 2024
Jan 26, 2024
Jun 8, 2024
Sep 10, 2023
Aug 27, 2023
May 8, 2024
May 8, 2024
May 7, 2024
Sep 30, 2023
May 7, 2024
Mar 3, 2024

Repository files navigation

Limbo

Limbo

Build badge

Limbo is a work-in-progress, in-process OLTP database management system, compatible with SQLite.

Features

  • In-process OLTP database engine library
  • Asynchronous I/O support with io_uring
  • SQLite compatibility
    • SQL dialect support (wip)
    • File format support (read-only)
    • SQLite C API (wip)
  • JavaScript/WebAssembly bindings (wip)

Getting Started

Limbo is currently read-only. You can either use the sqlite3 program to create a database:

$ sqlite3 database.db
SQLite version 3.42.0 2023-05-16 12:36:15
Enter ".help" for usage hints.
sqlite> CREATE TABLE users (id INT PRIMARY KEY, username TEXT);
sqlite> INSERT INTO users VALUES (1, 'alice');
sqlite> INSERT INTO users VALUES (2, 'bob');

or use the testing script to generate one for you:

./testing/gen-database.py

You can then start the Limbo shell with:

$ cargo run database.db
Welcome to Limbo SQL shell!
> SELECT * FROM users LIMIT 1;
|1|Cody|Miller|mhurst@example.org|525.595.7319x21268|33667 Shaw Extension Suite 104|West Robert|VA|45161|`

Developing

Run tests:

cargo test

Test coverage report:

cargo tarpaulin -o html

Run benchmarks:

cargo bench

Run benchmarks and generate flamegraphs:

echo -1 | sudo tee /proc/sys/kernel/perf_event_paranoid
cargo bench --bench benchmark -- --profile-time=5

Publications

  • Pekka Enberg, Sasu Tarkoma, Jon Crowcroft Ashwin Rao (2024). Serverless Runtime / Database Co-Design With Asynchronous I/O. In EdgeSys ‘24. [PDF]
  • Pekka Enberg, Sasu Tarkoma, and Ashwin Rao (2023). Towards Database and Serverless Runtime Co-Design. In CoNEXT-SW ’23. [PDF] [Slides]

License

This project is licensed under the MIT license.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Limbo by you, shall be licensed as MIT, without any additional terms or conditions.

About

Limbo is a work-in-progress, in-process OLTP database management system, compatible with SQLite.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 95.0%
  • C 3.1%
  • Python 1.1%
  • Other 0.8%