em-rack-mongrel2

This is a Mongrel2 Rack handler that supports EventMachine and async response.

I folked this from darkhelmet's rack-mongrel2 so that I can rack up async_sinatra apps. Tested on async_sinatra but will be able to run any Rack apps that requires an async web server such as Thin.

This is my very first contribution to Ruby ecosystem. Let me know if I've done wrong. Pull requests and feature requests are very welcome!

How to run examples

Clone the repository.

git clone https://github.com/ichiban/em-rack-mongrel2.git

Download all dependencies.

cd em-rack-mongrel2
bundle install

Run Mongrel2.

cd example
mkdir -p tmp/pids logs run
m2sh load
sudo m2sh start -name main

Run a simple sinatra example,

cd sinatra
rackup -s Mongrel2 \
       -O uuid=9539ED88-1B33-4D19-A9F9-283E5BF11AC7 \
       -O send=tcp://127.0.0.1:9996 \
       -O recv=tcp://127.0.0.1:9997

an async sinatra example or

cd async_sinatra
rackup -s Mongrel2 \
       -O uuid=AEE66029-E420-42E7-A7C8-6C37BBFC7B9F \
       -O send=tcp://127.0.0.1:9998 \
       -O recv=tcp://127.0.0.1:9999

a big-upload example.

cd upload
rackup -s Mongrel2 \
       -O uuid=51226E47-AE49-4BC8-A9C6-BD7F6827E8A4 \
       -O send=tcp://127.0.0.1:10000 \
       -O recv=tcp://127.0.0.1:10001 \
       -O chroot=..

How to use in your projects

  1. Get mongrel2 installed (http://mongrel2.org/wiki/quick_start.html)
  2. Get your config for mongrel2 setup (see example directory)
  3. Add it to your Gemfile (gem 'em-rack-mongrel2')
  4. You also need some sort of JSON parsing library installed, like Yajl or JSON (gem i yajl-ruby or gem i json). json-jruby will work too
  5. Run Mongrel2
  6. Run your rack application

Note on Patches/Pull Requests

  • Fork the project.
  • Make your feature addition or bug fix.
  • Add tests for it. This is important so I don't break it in a future version unintentionally.
  • Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)
  • Send me a pull request. Bonus points for topic branches.
  • Original project Copyright (c) 2010, 2011 Daniel Huckstep. See LICENSE for details.
  • This derivative project Copyright (c) 2011 ICHIBANGASE, Yutaka.