• Stars
    star
    362
  • Rank 117,671 (Top 3 %)
  • Language
    Rust
  • License
    MIT License
  • Created over 9 years ago
  • Updated about 8 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

The mio-based framework for rust for doing I/O in simple and composable way (ABANDONED)

Rotor

Status: Alpha
Examples:TCP echo server, TCP client (telnet)
Ecosystem:libraries and apps using rotor
Documentation:http://tailhook.github.com/rotor/

The mio-based framework for rust for doing I/O in simple and composable way.

The rotor core (this crate) basically consists of:

  • An event loop handler (in terms of mio) which turns mio event into event to specific state machine
  • A Future type which allows communication between state machines in safe and efficient way
  • A simple way to combine multiple libraries (e.g. multiple protocol handlers) into single mio event loop

At the end of the day, rotor is the minimalistic core for making composable libraries on top. It's less than 0.5KLoC.

You are expected to use some higher level abstraction most of the time. For example, you should use stream abstraction (yet to be implemented) for making TCP protocol parser.

Resources

Both are rather historical at the moment

Benchmarks

These benchmarks are based on old version of this example. Hopefully we will get updated benchmarks soon.

Just few micro-benchmarks to show that framework has a decent peformance.

The performance on the few years old laptop (i7-3517U CPU @ 1.90GHz):

> wrk -t2 -c 400 http://localhost:8888/
Running 10s test @ http://localhost:8888/
  2 threads and 400 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency    11.19ms   18.03ms 627.44ms   99.54%
    Req/Sec    19.66k     1.76k   21.93k    81.00%
  391170 requests in 10.01s, 32.83MB read
Requests/sec:  39071.42
Transfer/sec:      3.28MB

Performance on newer desktop class CPU (i7-4790K CPU @ 4.00GHz):

> ./wrk -t 2 -c 400 http://127.0.0.1:8888
Running 10s test @ http://127.0.0.1:8888
  2 threads and 400 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency     2.24ms    1.56ms 126.94ms   99.91%
    Req/Sec    91.35k     2.27k   93.76k    98.00%
  1818133 requests in 10.00s, 152.58MB read
Requests/sec: 181781.96
Transfer/sec:     15.26MB

Note: both benchmarks are run on single threaded server.

The benchmarks are too early (not a full implementation of HTTP), so no comparison bencmarks listed here.

More Repositories

1

vagga

Vagga is a containerization tool without daemons
Rust
1,842
star
2

quick-error

A rust-macro which makes errors easy to write
Rust
313
star
3

humantime

A parser and formatter for std::time::{SystemTime, Duration}
Rust
285
star
4

zerogw

A fast HTTP/WebSocket to zeromq gateway (UNMAINTAINED, take a look at swindon web server instead)
C
252
star
5

rust-argparse

The command-line argument parser library for rust
Rust
227
star
6

unshare

The low-level linux containers creation library for rust
Rust
115
star
7

rotor-http

The mio/rotor based http server library for rust (UNMAINTAINED, use tk-http)
Rust
110
star
8

lithos

Process supervisor that supports linux containers
Rust
107
star
9

dns-parser

The parser of DNS protocol packets in rust
Rust
82
star
10

knuffel

Rust KDL parser and derive implementation
Rust
81
star
11

ciruela

A peer-to-peer synchronization software for servers in datacenters.
Rust
66
star
12

serde-regex

A serde wrapper that allows to (de)serialize regular expressions
Rust
62
star
13

tilenol

Yet another tiling window manager
Python
61
star
14

probor

A protocol on top of CBOR that provides protobuf-like functionality
Rust
48
star
15

cantal

Heartbeating and monitoring solution
Rust
45
star
16

zorro

Network communication library based on greenlets, with zeromq and redis support
Python
44
star
17

trafaret-config

A small wrapper around trafaret and yaml that does nice error reporting (python)
Python
41
star
18

libwebsite

An HTTP and websocket protocol implementation for libev event loop (UNMAINTAINED, use rust and tk-http crate)
C
39
star
19

injections

Simple dependency injection library for python2 and python3
Python
39
star
20

verwalter

A tool which manages cluster of services
Rust
34
star
21

nginx-config

An (unofficial) nginx configuration parser
Rust
33
star
22

libmount

A type-safe wrapper around mount() system call for rust with good error reporting
Rust
32
star
23

tk-listen

A library that allows to listen network sockets with proper resource limits and error handling
Rust
30
star
24

tk-sendfile

A thread pool for rust/tokio that can process file requests and send data to the socket with zero copy (using sendfile)
Rust
26
star
25

resolv-conf

The /etc/resolv.conf file parser in rust
Rust
25
star
26

cpu-time

CPU time measurement library for rust
Rust
23
star
27

tk-pool

A connection pool implementation for tokio
Rust
22
star
28

openat

A wrapper around openat, symlinkat, and similar system calls
Rust
21
star
29

signal

Signal handling for rust
Rust
21
star
30

khufu

A template language for incremental-dom or DSL for javascript views
JavaScript
19
star
31

rotor-stream

The stream abstraction on top of rotor (UNMAINTAINED, use tokio)
Rust
19
star
32

abstract-ns

Abstract name service traits for rust
Rust
18
star
33

async-listen

A rust crate with various helpers for writing production-ready servers in rust using async-std
Rust
18
star
34

paperjam

Devices and commandline tools for zeromq and crossroads io
C
16
star
35

self-meter

A tiny library to measure resource usage of the process it's used in
Rust
15
star
36

netbuf

Network buffers for rust
Rust
15
star
37

rust-quire

A YAML-based configuration library for Rust
Rust
14
star
38

tokio-tutorial

My futures/tokio tutorial for Rust Belt Rust (OUT OF DATE)
Rust
13
star
39

aio-s3

The asyncio client for Amazon S3
Python
12
star
40

rust-gron

A rust reimplementation of a gron utility which makes JSON greppable (https://github.com/tomnomnom/gron)
Rust
12
star
41

trimmer

A whitespace and memory friendly template engine
Rust
12
star
42

coyaml

Configuration file parser generator, that uses YAML for configuration files. Currently generates only C code
C
12
star
43

ssh-keys

Parser of ssh public and private keys
Rust
12
star
44

sortedsets

Sorted sets implementation in pure python
Python
11
star
45

stator

A wrapper around rotor library for rust which provides C API and scripting language bindings
Rust
11
star
46

marafet

Compiler for Jade-like template language to cito.js-based virtual dom
Rust
11
star
47

quire

A YAMLy configuration parser-generator for C
C
10
star
48

httpbin-rs

A httpbin reimplementation in rust
HTML
10
star
49

vagga-docker

This is a prototype which brings vagga as the first-class tool to OS X and (possibly) windows through docker's layer of compatibility
Dockerfile
10
star
50

pyarchive

Cython-based python bindings for libarchive
C
10
star
51

procboss

Process supervisor
C
9
star
52

tk-easyloop

Thread-local loop and other simplifications for tokio loop
Rust
9
star
53

bulk

A tool that builds packages, updates package repos, and bumps versions
Rust
9
star
54

serde-str

A serde wrapper, that can be used to serialize data types using Display and FromStr
Rust
9
star
55

graphql-cli

A command-line tool for working with graphql written in rust
Rust
9
star
56

vagga-box

A virtualbox wrapper around vagga
Python
9
star
57

url-tail

A clone of unix "tail" utility which uses HTTP Range requests to watch remote files
Rust
8
star
58

flake8-import-graph

A flake8 lint to enforce that some modules can't be imported from other modules
Python
8
star
59

capturing-glob

A glob (file matching utility) with capture groups (similar to regex)
Rust
7
star
60

ns-router

An abstraction around domain name system that allows to resolve different names by different means
Rust
7
star
61

serde-millis

A serde wrapper that stores integer millisecond value for timestamps and durations (used similarly to serde_bytes)
Rust
7
star
62

battleship

Battle ship implementation in Nim language (hackaton project)
Nim
7
star
63

mglawica

A simple PaaS inspired by dokku but built with vagga, cantal, lithos, verwalter, ciruela and possibly swindon
Lua
6
star
64

pyzza

A compiler of a python-like programming language, targeting the Flash platform
Python
6
star
65

reqtxt2nix

Generator of nix expressions from pythonic requirements.txt
Python
5
star
66

aio-routes

URL routing library for asyncio
Python
5
star
67

aio-beanstalk

The asyncio client for beanstalkd work queue
Python
5
star
68

string-intern

Another implementation of string interning in rust
Rust
4
star
69

jarred

a web interface for viewing collectd statistics
JavaScript
4
star
70

tk-carbon

Carbon client for tokio
Rust
4
star
71

dir-signature

A library to create a signature (or index) of the directory suitable for using by file synchronization utilities
Rust
4
star
72

rotor-carbon

(ABANDONED. Use `tk-carbon` instead) The asynchronous rust + rotor bindings for carbon (graphite)
Python
4
star
73

objpath

A library that allows to traverse data structures by path
C
4
star
74

vagga2lithos

A tool which helps to generate lithos config from a vagga config
Python
4
star
75

tk-cantal

The cantal client library (on top of tokio main loop)
Rust
3
star
76

rotor-redis

Redis implementation for rotor library (using mio in Rust language)
Rust
3
star
77

amfy

AMF serializer/deserializer for python3
Python
3
star
78

scan_dir

A easier read_dir for rust, useful for reading directory of config files
Rust
3
star
79

magickpy

ImageMagick bindings for python3
Python
3
star
80

nginx-config-mod

A command-line utility and a rust library to validate and make certain tweaks/rewrites of nginx configs
Rust
3
star
81

tk-bufstream

A buffered stream backed by contiguous buffers for tokio (rust)
Rust
2
star
82

humannum

A human friendly format parser for numeric types
Rust
2
star
83

cantal-go

Go bindings to cantal
Go
2
star
84

mesos-tests

Few semi-automated tests of mesos in various network failure conditions
Python
2
star
85

cantal-py

Python library for cantal
Python
2
star
86

xsnano

C
2
star
87

async-presentation

Talk about asynchronous IO. WARNING: Presentation contains both good and bad examples without any markup. Use your own judgement.
CSS
2
star
88

vagga-presentation

Presentation for vagga
JavaScript
2
star
89

digest-writer

Adds an `io::Write` interface on top of `digest::Digest`
Rust
2
star
90

zerogw.com

zerogw.com website
CSS
1
star
91

containers_presentation

Linux Containers Ecosystem presentation for PyCon Ukraine 2014
CSS
1
star
92

self-meter-http

A HTTP renderer for self-meter data
Rust
1
star
93

ns-env-config

An env_logger-inspired one-stop configuration for name resolution based on abstract-ns.
Rust
1
star
94

fedor

Federated organizer (basically todo list on steroids with multiple servers support to be implemented)
JavaScript
1
star
95

debian-libwebsite

Debian packaging for libwebsite
C
1
star
96

dotns

And experimental name service for nanomsg
Python
1
star
97

clojureday-presentation

CSS
1
star
98

trimmer-derive

A derive implementation for `trimmer::Variable` trait
Rust
1
star
99

debian-coyaml

Debian packaging for coyaml
C
1
star
100

rotor-dns

A DNS resolver for rotor
Rust
1
star