Edge-triggered epoll concurrency model using sleepy_penguin for epoll.
Unlike more portable options like Coolio
and EventMachine
, this is Linux-only, but uses edge-triggering instead of level-triggering, so it may perform better in some cases. Coolio
and EventMachine
have better library support and may be widely-used, however.
Consider using XEpoll
instead of this if you are using Ruby 1.9, it will avoid accept()-scalability issues with many worker processes.
When serving static files, this is extremely unfair and optimized for throughput at the expense of fairness. This is not an issue if you're not serving static files, or if your working set is small enough to always be in your kernel page cache. This concurrency model may starve clients if you have slow disks and large static files.
Do not use this if you have slow external dependencies.
raindrops 0.6.0 or later
sleepy_penguin 3.0.1 or later
sendfile 1.1.0 or later
mail archives: https://yhbt.net/rainbows-public/ http://ou63pmih66umazou.onion/rainbows-public/ nntp://news.public-inbox.org/inbox.comp.lang.ruby.rainbows nntp://ou63pmih66umazou.onion/inbox.comp.lang.ruby.rainbows nntp://news.gmane.io/gmane.comp.lang.ruby.rainbows.general public: rainbows-public@yhbt.net source code: git clone https://yhbt.net/rainbows.git torsocks git clone http://ou63pmih66umazou.onion/rainbows.git