Posted by
arungupta on April 7, 2008 at 11:49 AM PDT
Part
1 of this tri-series blog explained how a Java EE
Servlet and Rails application can be packaged together as WAR file
using
Goldspike
plugin and deployed on
GlassFish
v2 UR1. There are few issues with Goldspike as explained
here.
A better and recommended option is to use
Warbler
for packaging which provides a minimal, flexible and Ruby-like way to
create WAR. Warbler really cleans up the packagingof WAR, for example
excluding .svn directories, tests and migrations - really nice. For
now, it uses RailsServlet for dispatching but even that is pluggable.
This blog, Part 2, will explain how to generate a WAR file using
Warbler.
Rails
powered by GlassFish provides all the details on why
GlassFish provides an industry-grade and functionally-rich Application
Server.
Now detailed steps:
- In an existing JRuby
1.1 installation (enabled with Rails), install Warbler gem:
~/testbed/jruby-1.1
>bin/jruby -S gem
install warbler
JRuby limited openssl loaded. gem install jruby-openssl for full
support.
http://wiki.jruby.org/wiki/JRuby_Builtin_OpenSSL
Updating metadata for 35 gems from http://gems.rubyforge.org
...................................
complete
Successfully installed warbler-0.9.4
1 gem installed
Installing ri documentation for warbler-0.9.4...
Installing RDoc documentation for warbler-0.9.4... |
- Create a Rails app "railsee2" as:
~/testbed/jruby-1.1/samples/rails >../../bin/jruby -S rails
railsee2
create
create
app/controllers
create
app/helpers
create
app/models
. . .
create
log/production.log
create
log/development.log
create
log/test.log |
In order to keep it simple, this application will not be using any
database so uncomment the following line from
"config/environment.rb"(by removing "#" from beginning of the line):
| config.frameworks
-= [ :active_record, :active_resource, :action_mailer ] |
- Create a new file "web.xml" in "config" directory and use
the following contents:
<!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>
<servlet>
<servlet-name>HelloServlet</servlet-name>
<servlet-class>server.HelloServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloServlet</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>
</web-app> |
This "web.xml" is used by Warbler when packaging the WAR file.
- Create and Copy Servlet
- Create a Java library with Servlet code as explained in bullet
#4 here.
- Copy "HelloServlet.jar" from "dist" directory of NetBeans
project to "lib" directory of Rails application.
- Create and deploy the WAR
- Create a WAR file as:
- Deploy the WAR to GlassFish
v2 UR1 as:
~/testbed/jruby-1.1/samples/rails/railsee2
>~/testbed/glassfish/v2ur1/glassfish/bin/asadmin
deploy railsee2.war
Command deploy executed successfully. |
- The bundled Servlet is now accessible at
"http://localhost:8080/railsee2/hello". The default browser output
looks like:

And passing a parameter to the URL as
"http://localhost:8080/railsee2/hello?name=Arun" shows the output as:

With this, your Java EE Servlet is now bundled with your Rails
application deployed on GlassFish v2 UR1.
Now, lets add Controller and View to Rails application and invoke this
servlet from there to show complete integration with Rails.
- Create a new Controller and View as
~/testbed/jruby-1.1/samples/rails/railsee2
>../../../bin/jruby
script/generate controller home index
JRuby limited openssl loaded. gem install jruby-openssl for full
support.
http://wiki.jruby.org/wiki/JRuby_Builtin_OpenSSL
exists
app/controllers/
exists
app/helpers/
create
app/views/home
exists
test/functional/
create
app/controllers/home_controller.rb
create
test/functional/home_controller_test.rb
create
app/helpers/home_helper.rb
create
app/views/home/index.html.erb |
- Change the generated controller in
"app/controllers/home_controller.rb" to:
class
HomeController < ApplicationController
include Java
def index
url = java.net.URL.new("http://localhost:8080/railsee2/hello");
conn = url.open_connection;
reader =
java.io.BufferedReader.new(java.io.InputStreamReader.new(conn.get_input_stream));
@servlet_output = "";
input_line = reader.read_line;
while input_line != nil
@servlet_output << input_line;
input_line = reader.read_line;
end
reader.close;
end
end |
- Change the generated view in
"app/views/home/index.rhtml.erb" to:
<h1>Home#index</h1>
<p>Find me in
app/views/home/index.html.erb</p>
<%= @servlet_output %> |
- Re-create the WAR as describd in bullet # 5 above. And now
"http://localhost:8080/railsee2/home/index" shows the output as shown:

This blog explained how a Java EE 5 Servlet and Rails application can
be packaged Warbler and deployed on GlassFish.
Warbler
docs provide detail about usage, configuration, web.xml and
other details.
The next blog in this tri-series blog will explain how such an
application can be deployed on GlassFish v3. And the cool thing there
is that you don't need Goldspike, Warbler or any other additional
plugins - total native deployment, stay tuned!
Technorati: rubyonrails
netbeans
glassfish
v3 javaee5
servlets
jruby
ruby warbler