0.01
No commit activity in last 3 years
No release in over 3 years
A Rack handler for the Mongrel2 web server with EventMachine support
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 0.0.3
~> 2.3.0
~> 0.6.4

Runtime

~> 0.2.2
~> 1.0.0
~> 1.0.3
~> 0.3.4
 Project Readme

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.

Copyright

  • Original project Copyright (c) 2010, 2011 Daniel Huckstep. See LICENSE for details.
  • This derivative project Copyright (c) 2011 ICHIBANGASE, Yutaka.