バリケンのRuby日記 RSSフィード

2009-08-22

[][] Ramaze on GAE/J  Ramaze on GAE/J - バリケンのRuby日記 を含むブックマーク はてなブックマーク -  Ramaze on GAE/J - バリケンのRuby日記  Ramaze on GAE/J - バリケンのRuby日記 のブックマークコメント

Rubyで書かれた軽量Webアプリケーション開発フレームワーク「Ramaze」をGoogle App Engine for Java上でJRubyを使って動かすための、自分用のメモだよ。ここでの手順はWindowsで行うことを想定しているよ。

Java SDKのダウンロードとインストール

まだJava SDKをインストールしていない人は、ダウンロードしてインストールしてね。

Java SDKをインストールするには、Java SDKのダウンロードサイトにアクセスして、下のほうにある「JDK 6 Update 16」の右側の「Download」をクリックしてね。Platformは「Windows」を選択してね。

ダウンロードしたインストーラ「jdk-6u16-windows-i586.exe」をダブルクリックすると、インストールが始まるよ。

Google App Engine for Java SDKのダウンロードと展開

まだGoogle App Engine for Java SDKを入手していない人は、ダウンロードしてね。

Google App Engine for Java SDKを入手するには、Google App Engineのダウンロードサイトにアクセスして、「appengine-java-sdk-1.2.2.zip」をクリックしてダウンロードしてね。ダウンロードした「appengine-java-sdk-1.2.2.zip」ファイルは圧縮されているから、Cドライブ直下に展開してね。

ramaze_on_gaeディレクトリの作成

コマンドプロンプトを起動して、次のようにコマンドを入力してね

空白を含むパス上だとうまく動かないみたいなので、ここではCドライブ直下に作成しているよ

> cd \
> mkdir ramaze_on_gae
> cd \ramaze_on_gae

jruby-complete-1.3.1.jarのダウンロードと設置

まだ「jruby-complete-1.3.1.jar」を入手していない人は、ダウンロードしてね。入手先はJRubyのダウンロードサイトだよ。

jruby-complete-1.3.1.jar」をクリックしてダウンロードしたら、先ほど作ったC:\ramaze_on_gaeフォルダに配置してね。

WEB-INFフォルダの作成

先ほど作った「\ramaze_on_gae」ディレクトリの中に、次のように3つのディレクトリを作成するよ。

> mkdir WEB-INF
> mkdir WEB-INF\gems
> mkdir WEB-INF\lib

Ramazeのインストール

JRubygemコマンドを使って、必要となるライブラリを入手するよ。

> set JAVA_HOME=C:\PROGRA~1\Java\jdk1.6.0_16
> set PATH=%JAVA_HOME%\bin;C:\appengine-java-sdk-1.2.2\bin;%PATH%
> java -jar jruby-complete-1.3.1.jar -S gem install -i WEB-INF\gems ramaze --no-ri --no-rdoc
> del /q WEB-INF\gems\cache\*

jruby-core.jarruby-stdlib.jarlibフォルダに作成

次のようにコマンドを入力して、「jruby-complete-1.3.1.jar」から「jruby-core.jar」と「ruby-stdlib.jar」を作成するよ。ここでは元となる「jruby-complete-1.3.1.jar」は削除しているけど、削除したくない人は他のフォルダにコピーしておいてね。

> mkdir tmp_unpack
> cd tmp_unpack
> jar xf ../jruby-complete-1.3.1.jar
> cd ..
> mkdir jruby-core
> move tmp_unpack\org jruby-core
> move tmp_unpack\com jruby-core
> move tmp_unpack\jline jruby-core
> move tmp_unpack\jay jruby-core
> move tmp_unpack\jruby jruby-core
> cd jruby-core
> jar cf ../jruby-core.jar .
> cd ..\tmp_unpack
> jar cf ../ruby-stdlib.jar .
> cd ..
> rmdir /s /q jruby-core
> rmdir /s /q tmp_unpack
> move jruby-core.jar WEB-INF\lib
> move ruby-stdlib.jar WEB-INF\lib
> del jruby-complete-1.3.1.jar

appengine-api-1.0-sdk-1.2.2.jarのコピー

次のコマンドを入力して、「appengine-api-1.0-sdk-1.2.2.jar」ファイルをコピーするよ。

> copy C:\appengine-java-sdk-1.2.2\lib\user\appengine-api-1.0-sdk-1.2.2.jar WEB-INF\lib

jruby-rack-0.9.5-SNAPSHOT.jarのダウンロードと配置

こちらのサイトから「jruby-rack-0.9.5-SNAPSHOT.jar」をダウンロードして、C:\ramaze_on_gae\WEB-INF\libに配置してね。ダウンロードは右下のほうの「raw」というリンクをクリックしてね。

WEB-INF/hello.rbの作成

テキストエディタで次の内容を入力して、WEB-INFフォルダの中にhello.rbという名前で保存してね。単に「Hello, World!!」と表示させるだけのアプリケーションだよ。

require 'rubygems'
require 'ramaze'

class MainController < Ramaze::Controller
  def index
    "Hello, World!"
  end
end

WEB-INF/appengine-web.xmlの作成

テキストエディタで次の内容を入力して、WEB-INFフォルダの中にappengine-web.xmlという名前で保存してね。

<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
    <application>ramaze_on_gae</application>
    <version>1</version>
    <static-files />
    <resource-files />
    <sessions-enabled>false</sessions-enabled>
    <system-properties>
      <property name="jruby.management.enabled" value="false" />
      <property name="os.arch" value="" />
      <property name="jruby.compile.mode" value="JIT"/> <!-- JIT|FORCE|OFF -->
      <property name="jruby.compile.fastest" value="true"/>
      <property name="jruby.compile.frameless" value="true"/>
      <property name="jruby.compile.positionless" value="true"/>
      <property name="jruby.compile.threadless" value="false"/>
      <property name="jruby.compile.fastops" value="false"/>
      <property name="jruby.compile.fastcase" value="false"/>
      <property name="jruby.compile.chainsize" value="500"/>
      <property name="jruby.compile.lazyHandles" value="false"/>
      <property name="jruby.compile.peephole" value="true"/>
   </system-properties>
</appengine-web-app>

WEB-INF/web.xmlの作成

テキストエディタで次の内容を入力して、WEB-INFフォルダの中にweb.xmlという名前で保存してね。

<!DOCTYPE web-app PUBLIC
  "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
  "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
 
  <context-param>
    <param-name>public.root</param-name>
    <param-value>/</param-value>
  </context-param>
 
  <context-param>
    <param-name>rackup</param-name>
    <param-value>require 'rubygems'

class Thread
  def Thread.exclusive
    _old = Thread.critical
    begin
      Thread.critical = true
      return yield
    ensure
      Thread.critical = _old
    end
  end
end

require 'ramaze'

require 'hello'

Ramaze.start(:root => __DIR__, :started => true)
run Ramaze
</param-value>
  </context-param>
 
  <context-param>
    <param-name>jruby.min.runtimes</param-name>
    <param-value>1</param-value>
  </context-param>
 
  <context-param>
    <param-name>jruby.max.runtimes</param-name>
    <param-value>1</param-value>
  </context-param>
 
  <context-param>
    <param-name>jruby.init.serial</param-name>
    <param-value>true</param-value>
  </context-param>
 
  <filter>
    <filter-name>RackFilter</filter-name>
    <filter-class>org.jruby.rack.RackFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>RackFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
 
  <listener>
    <listener-class>org.jruby.rack.RackServletContextListener</listener-class>
  </listener>
 
</web-app>

開発用サーバの起動

次のコマンドを入力して、開発用サーバを起動してね。

> dev_appserver.cmd .

Webブラウザで開発用サーバにアクセス

http://localhost:8080/にアクセスして、動作確認してね。

Google App Engineにデプロイ

「appengine-web.xml」の「application」と「version」を適切に設定して、次のコマンドを実行してね。

> appcfg.cmd update .
トラックバック - http://rubyist.g.hatena.ne.jp/muscovyduck/20090822