Основная проблема заключается в следующем: долгое время MRI была единственной выполнимой реализацией Ruby. У MRI есть ряд проблем, которые затрудняют встраивание его в другое приложение (что в основном делает mod_ruby : он встраивает MRI в Apache), особенно многопоточное (которым является Apache). Он не особо ориентирован на многопоточность и имеет глобальное состояние.
Это глобальное состояние означает, например, что если одно приложение Rails изменяет некоторый класс, то все другие приложения Rails, работающие на том же сервере Apache, также увидят этот измененный класс.
Другая проблема заключается в том, что исходный код МРТ нелегко взломать. МРТ уже более 15 лет, и она начинает показывать.
В результате этих проблем mod_ruby никогда действительно не работал должным образом, и в какой-то момент сопровождающие просто сдались.
Интерпретатор PHP на основе C, с другой стороны, был разработан с самого первого дня для запуска в Apache как mod_php. Действительно, для первых двух версий не было даже версии интерпретатора для командной строки, mod_php был only способ запуска PHP.
Phusion Passenger (он же mod_rack, он же mod_rails) решает эту проблему, по сути отказываясь от этой проблемы: они просто запускают отдельную копию MRI в отдельном процессе для каждого приложения. Это прекрасно работает, и не только для Ruby. Он поддерживает WSGI (стандартный интерфейс для Python Web Frameworks), Rack (стандартный интерфейс для Ruby Web Framework) и прямую поддержку Ruby on Rails.
Я надеюсь на mod_rubinius , который, к сожалению, еще не существует. Rubinius изначально разрабатывался как поточно-ориентированный, встраиваемый, без глобального состояния, без использования стека C и т. Д. Он был разработан, чтобы иметь возможность запускать несколько виртуальных машин Rubinius в одном процессе Rubinius. Это делает mod_rubinius бесконечно проще в реализации и обслуживании, чем mod_ruby. К сожалению, конечно, Rubinius еще не выпущен, и настоящая работа над mod_rubinius не может даже начаться, пока не будет выпущен Rubinius. Хорошая новость заключается в том, что у mod_rubinius уже есть больше рабочей силы, чем у mod_ruby, потому что он заплатил разработчикам, работающим над ним с хостинговой компанией Rails, которая отчаянно хочет использовать ее самостоятельно.