Skip to content

donovan68/seastar

This branch is 5 commits ahead of, 4999 commits behind scylladb/seastar:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

4cd43f7 · Dec 21, 2018
Sep 11, 2018
Feb 1, 2017
May 5, 2018
Apr 27, 2018
Apr 24, 2018
Oct 7, 2018
Nov 27, 2016
Oct 5, 2018
Jan 15, 2018
Jun 24, 2017
Aug 12, 2018
Aug 17, 2018
May 27, 2017
Sep 20, 2015
Oct 5, 2018
Apr 24, 2018
Oct 5, 2018
Sep 19, 2018
Oct 7, 2018
Sep 10, 2018
Nov 3, 2015
Jul 7, 2018
Feb 1, 2017
May 12, 2015
Oct 8, 2018
Aug 12, 2018
Aug 9, 2017
Oct 8, 2018
Apr 15, 2018
Apr 15, 2018
Feb 19, 2015
Jun 24, 2015
Jul 28, 2015
Apr 27, 2018
Aug 19, 2018
Dec 5, 2018
Dec 21, 2018
Jul 31, 2017
Aug 29, 2018
May 23, 2018
May 8, 2018
Aug 29, 2018

Repository files navigation

Seastar

Travis Build Status Version License: Apache2 n00b issues

Introduction

SeaStar is an event-driven framework allowing you to write non-blocking, asynchronous code in a relatively straightforward manner (once understood). It is based on futures.

Building Seastar

See instructions for Fedora, CentOS and Ubuntu.

There are also instructions for building on any host that supports Docker.

Use of the DPDK is optional.

Using C++17

Seastar can be built with the C++17 dialect by supporting compilers, conditional on the --c++-dialect option being set to gnu++17.

However, by default Seastar uses C++14-compatible types such as std::experimental::optional<> or boost::variant, both internally and in its public API, thus forcing them on C++17 projects. To fix this, Seastar provides the --use-std-optional-variant-stringview 0|1 option, which changes those types to their stdlib incarnation, and allows seemless use of C++17. Usage of this option requires an updated compiler, such as GCC 8.1.1-5 on Fedora.

Getting started

There is a mini tutorial and a more comprehensive one.

The documentation is available on the web.

Resources

Ask questions and post patches on the development mailing list. Subscription information and archives are available here, or just send an email to [email protected].

Information can be found on the main project website.

File bug reports on the project issue tracker.

The Native TCP/IP Stack

Seastar comes with its own userspace TCP/IP stack for better performance.

Recommended hardware configuration for SeaStar

  • CPUs - As much as you need. SeaStar is highly friendly for multi-core and NUMA
  • NICs - As fast as possible, we recommend 10G or 40G cards. It's possible to use 1G too but you may be limited by their capacity. In addition, the more hardware queue per cpu the better for SeaStar. Otherwise we have to emulate that in software.
  • Disks - Fast SSDs with high number of IOPS.
  • Client machines - Usually a single client machine can't load our servers. Both memaslap (memcached) and WRK (httpd) cannot over load their matching server counter parts. We recommend running the client on different machine than the servers and use several of them.

About

High performance server-side application framework

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 90.9%
  • Python 6.5%
  • CMake 1.8%
  • Other 0.8%