Mojoを使って自作ウェブアプリをよりポータブルに!
第1回 はじめてのMojo
2009年12月8日:サンプルコードを現在のバージョンで動作するよう修正しました。
mod_perlの教訓
一昔前まで,Perlである程度大規模なウェブアプリケーションを書くときはmod_perlと呼ばれるApacheモジュールを利用するのが一般的でした。
ところが,Apache,mod_perlともに大規模な改修が行われ,後方互換性が失われた結果,古いmod_perlのアプリケーションを抱えている企業は,リスクや不便を覚悟で古いApacheを使い続けるか,Apache,mod_perlともに新しい環境に移行するか,あるいはまったく異なる第三の道を模索するかの選択を迫られることになりました。
同じようなことは,もっと小規模なアプリケーションでも起こりえます。たとえば,昔ながらのCGI環境で実行していたものをもっと高速な環境に移行したくなったとき。たしかにmod_perlにはApache::PerlRunと呼ばれる互換モードもありますが,これまではアプリケーションそのものを書き直すのが常でした。
サーバをとるか,フレームワークをとるか
もちろんよくできたフレームワークを使えば,このような差違は吸収できます。
たとえば海外でよく利用されているHTML::Masonは,1998年の登場時点ですでにmod_perlとCGI環境の双方に対応していましたし,mod_perlの書き直しが始まった2002年にはCVS上の開発版を利用して将来の変化に備えていました。
ただし,これはあくまでもHTML::Mason内部での対応にすぎません。HTML::MasonはPHPなどと同じくテンプレート内部にコードを埋め込むタイプのテンプレートエンジンを採用していますから,異なるテンプレートエンジンを利用していた企業にとっては,サーバ環境の移行に引けをとらないコストがかかってしまいます。「Apache2やめますか,Template-Toolkitやめますか」という選択は健全とはいえません。
Mojoはサーバとフレームワークをつなぐミドルウェア
Mojoは,そのような問題を解決するために生まれました。その歴史については連載の第4回でまたあらためて説明しますが,ここでは自社のアプリケーションないしフレームワークをMojoの規約に対応させれば,CGIやFastCGI,mod_perlといった環境にシームレスに対応できるようになる――だけでなく,開発用のスタンドアロンサーバなどもついてくる――ということを覚えておいていただければ結構です。
「規約に対応させる」というと,なにか大変な作業が必要になるような印象を受けるかもしれませんが,Mojoが取り扱うのはあくまでアプリケーション本体とサーバをつなぐ部分のみ。だから,基本的には,サーバから送られてくるクエリストリングやフォームデータの解析とヘッダやボディをサーバに送り返す処理を,アプリケーションの内部ではなく,Mojoにさせるように書き換えるだけのことです。
と,いくら言葉で説明してもわかりづらいと思いますので,まずは実際にMojoをインストールして,簡単なアプリケーションを作成してみましょう。
インストールはとても簡単
Perlのモジュールというと,インストールが大変という印象があるかもしれません。
言葉で書けばシェルから「cpan <モジュール名>」するだけなのですが,なかには芋づる式に何十個ものモジュールがインストールされたり,C言語の開発環境が必須というものがあったりで,最近の有名で高性能なモジュールになればなるほど,ある程度融通が利く環境にしか入れられないようになっています。
でも,アプリケーションをサーバ環境の制約から解放するのが目的のミドルウェアとしては,そのような取り扱いのむずかしさは害でしかありません。
だから,Mojoは,その思想的な祖先であるWSGI(Web Server Gateway Interface)(※1)の理念にしたがって,不要な依存関係はいっさい省き,なるべく簡単にインストールできるようにつくられています。
2009年1月の時点では,テストにしか使わないものを含めてちょうど20個の依存モジュールが列挙されていますが,そのすべてがPerl 5.8.8(2006年1月リリース)以降標準添付されているもの。本体だけであれば2002年7月リリースのPerl 5.8.0でも問題なく動作します。
githubからのインストール
いつものようにCPANからインストールしてもそれほどの手間にはならないのですが,ここでは将来的にアプリケーションを別の環境に移動するときの便を考えて,githubから開発版をダウンロードしてくることにしましょう。
Mojoの最新版は常に下記のサイトにあります。
手元にgitの環境がある方はgit cloneするのが楽ですが,[download]ボタンをクリックすると圧縮ファイルをダウンロードできますので,ない方はそちらを利用して適当なディレクトリに解凍しておいてください。安定版を使いたい方はgithubのかわりにsearch.cpan.orgから圧縮ファイルを落としてくるとよいでしょう。
Mojoを使って自作ウェブアプリをよりポータブルに!
- 第4回 Mojoの歴史と展望
- 第3回 サンプルフレームワーク:Mojolicious
- 第2回 Mojoを使えばテストも簡単!
- 第1回 はじめてのMojo


