CARVIEW |
Select Language
HTTP/2 302
server: nginx
date: Sun, 17 Aug 2025 00:05:36 GMT
content-type: text/plain; charset=utf-8
content-length: 0
x-archive-redirect-reason: found capture at 20090510031239
location: https://web.archive.org/web/20090510031239/https://github.com/nicksieger/jruby-rack/tree/0.9.1
server-timing: captures_list;dur=0.870863, exclusion.robots;dur=0.033807, exclusion.robots.policy;dur=0.019635, esindex;dur=0.013551, cdx.remote;dur=28.099597, LoadShardBlock;dur=214.838973, PetaboxLoader3.datanode;dur=81.714335, PetaboxLoader3.resolve;dur=82.305025
x-app-server: wwwb-app201
x-ts: 302
x-tr: 295
server-timing: TR;dur=0,Tw;dur=0,Tc;dur=1
set-cookie: wb-p-SERVER=wwwb-app201; path=/
x-location: All
x-rl: 0
x-na: 0
x-page-cache: MISS
server-timing: MISS
x-nid: DigitalOcean
referrer-policy: no-referrer-when-downgrade
permissions-policy: interest-cohort=()
HTTP/2 200
server: nginx
date: Sun, 17 Aug 2025 00:05:37 GMT
content-type: text/html; charset=utf-8
x-archive-orig-server: nginx/0.6.26
x-archive-orig-date: Sun, 10 May 2009 03:12:39 GMT
x-archive-orig-connection: close
x-archive-orig-set-cookie: _github_ses=BAh7BzoOcmV0dXJuX3RvIiEvamV0dmlwZXIyMS9uaW1ibGUvd2lraXMvbmV3IgpmbGFzaElDOidBY3Rpb25Db250cm9sbGVyOjpGbGFzaDo6Rmxhc2hIYXNoewAGOgpAdXNlZHsA--e418ae6e15b6b6a5afb43eb8509bcb404091524c; path=/; expires=Wed, 01 Jan 2020 08:00:00 GMT; HttpOnly
x-archive-orig-status: 200 OK
x-archive-orig-x-runtime: 399ms
x-archive-orig-etag: "514208c65a9085ae4d888480f6ddd85b"
x-archive-orig-cache-control: private, max-age=0, must-revalidate
x-archive-orig-content-length: 27105
x-archive-guessed-content-type: text/html
x-archive-guessed-charset: utf-8
memento-datetime: Sun, 10 May 2009 03:12:39 GMT
link: ; rel="original", ; rel="timemap"; type="application/link-format", ; rel="timegate", ; rel="first memento"; datetime="Sun, 07 Dec 2008 21:58:56 GMT", ; rel="prev memento"; datetime="Tue, 10 Mar 2009 04:01:36 GMT", ; rel="memento"; datetime="Sun, 10 May 2009 03:12:39 GMT", ; rel="next memento"; datetime="Wed, 29 Jul 2009 09:22:39 GMT", ; rel="last memento"; datetime="Wed, 29 Jul 2009 09:22:39 GMT"
content-security-policy: default-src 'self' 'unsafe-eval' 'unsafe-inline' data: blob: archive.org web.archive.org web-static.archive.org wayback-api.archive.org athena.archive.org analytics.archive.org pragma.archivelab.org wwwb-events.archive.org
x-archive-src: 52_9_20090509235040_crawl100-c/52_9_20090510031221_crawl101.arc.gz
server-timing: captures_list;dur=0.704527, exclusion.robots;dur=0.033051, exclusion.robots.policy;dur=0.019232, esindex;dur=0.014643, cdx.remote;dur=16.959327, LoadShardBlock;dur=193.782652, PetaboxLoader3.datanode;dur=162.123221, PetaboxLoader3.resolve;dur=395.335681, load_resource;dur=410.604455
x-app-server: wwwb-app201
x-ts: 200
x-tr: 693
server-timing: TR;dur=0,Tw;dur=0,Tc;dur=0
x-location: All
x-rl: 0
x-na: 0
x-page-cache: MISS
server-timing: MISS
x-nid: DigitalOcean
referrer-policy: no-referrer-when-downgrade
permissions-policy: interest-cohort=()
content-encoding: gzip
nicksieger's jruby-rack at 0.9.1 - GitHub
This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (

This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (

Description: | Rack for JRuby and Java appservers |
Homepage: | <span><a href="https://jruby-rack.kenai.com/pages/Home">https://jruby-rack.kenai.com/pages/Home</a></span> |
Clone URL: |
git://github.com/nicksieger/jruby-rack.git
Give this clone URL to anyone.
git clone git://github.com/nicksieger/jruby-rack.git
|

nsieger (author)
Fri Jul 25 13:34:02 -0700 2008
name | age | message | |
---|---|---|---|
![]() |
.gitignore | Fri Jul 25 11:26:10 -0700 2008 | Get sinatra example working by artificially set... [nsieger] |
![]() |
History.txt | Sat May 03 13:23:49 -0700 2008 | Update README, add history file and remove no-l... [nsieger] |
![]() |
LICENSE.txt | Tue Apr 15 11:22:21 -0700 2008 | Change license to MIT git-svn-id: https://svn... [nsieger] |
![]() |
README.txt | Fri May 16 20:56:32 -0700 2008 | Updated README with a few extras from the wiki ... [nsieger] |
![]() |
TODO | Loading commit data... ![]() |
|
![]() |
build.xml | Tue Dec 11 08:08:08 -0800 2007 | Add NetBeans project and build file git-svn-i... [nsieger] |
![]() |
buildfile | Fri Jul 25 13:34:02 -0700 2008 | Update version to 0.9.1 git-svn-id: https://sv... [nsieger] |
![]() |
examples/ | ||
![]() |
nbproject/ | Tue May 20 11:34:41 -0700 2008 | Gah. NB goo changes every time I reshuffle the ... [nsieger] |
![]() |
src/ |
JRuby-Rack is a lightweight adapter for the Java servlet environment that allows any Rack-based application to run unmodified in a Java servlet container. JRuby-Rack supports Rails, Merb, as well as any Rack-compatible Ruby web framework. For more information on Rack, visit https://rack.rubyforge.org. = Features == Servlet Filter JRuby-Rack's main mode of operation is as a servlet filter. This allows requests for static content to pass through and be served by the application server. Dynamic requests only happen for URLs that don't have a corresponding file, much like many Ruby applications expect. == Goldspike-compatible Servlet JRuby-Rack includes a stub RailsServlet and recognizes many of Goldspike's context parameters (e.g., pool size configuration), making it interchangeable with Goldspike, for convenience of migration. One caveat is that static content is served by Rack, which requires acquisition of a JRuby runtime. Your throughput with static files will be much lower than when JRuby-Rack is configured as a servlet filter. You have been warned! == Servlet environment integration - Servlet context is accessible to any application both through the global variable $servlet_context and the Rack environment variable java.servlet_context. - Servlet request object is available in the Rack environment via the key java.servlet_request. - Servlet request attributes are passed through to the Rack environment. - Rack environment variables and headers can be overridden by servlet request attributes. - Java servlet sessions are used as the default session store for both Rails and Merb. Session attributes with String keys and String, numeric, boolean, or java object values are automatically copied to the servlet session for you. == Rails Several aspects of Rails are automatically set up for you. - The Rails controller setting ActionController::Base.relative_url_root is set for you automatically according to the context root where your webapp is deployed. - Rails logging output is redirected to the application server log. - Page caching and asset directories are configured appropriately. == Merb == JRuby Runtime Management JRuby runtime management and pooling is done automatically by the framework. In the case of Rails, runtimes are pooled. For Merb and other Rack applications, a single runtime is created and shared for every request. = Building Ensure you have JRuby with the buildr and rack gems installed. jruby -S gem install buildr rack Checkout the JRuby Rack code and cd to that directory svn co https://svn.codehaus.org/jruby-contrib/trunk/rack cd rack Resolve dependencies, compile the code, and build the jar file. jruby -S buildr package The generated jar should be located here: target/jruby-rack-*.jar. == Rails Step-by-step This example shows how to create and deploy a simple Rails app using the embedded Java database H2 to a WAR using Warble and JRuby Rack. JRuby Rack is now included in the latest release of Warbler (0.9.9), but you can build your own jar from source and substitute it if you like. Install Rails and the driver and ActiveRecord adapters for the H2 database: jruby -S gem install rails activerecord-jdbch2-adapter Install Warbler: jruby -S gem install warbler Make the "Blog" application jruby -S rails blog cd blog Copy this configuration into config/database.yml: development: adapter: jdbch2 database: db/development_h2_database test: adapter: jdbch2 database: db/test_h2_database production: adapter: jdbch2 database: db/production_h2_database Generate a scaffold for a simple model of blog comments. jruby script/generate scaffold comment name:string body:text Run the database migration that was just created as part of the scaffold. jruby -S rake db:migrate Start your application on the Rails default port 3000 using Mongrel/ and make sure it works: jruby script/server Generate a custom Warbler WAR configuration for the blog application jruby -S warble config Generate a production version of the H2 database for the blog application: RAILS_ENV=production jruby -S rake db:migrate Edit this file: config/warble.rb and add the following line after these comments: # Additional files/directories to include, above those in config.dirs # config.includes = FileList["db"] config.includes = FileList["db/production_h2*"] This will tell Warble to include the just initialized production H2 database in the WAR. Continue editing config/warble.rb and add the following line after these comments: # Gems to be packaged in the webapp. Note that Rails gems are added to this # list if vendor/rails is not present, so be sure to include rails if you # overwrite the value # config.gems = ["activerecord-jdbc-adapter", "jruby-openssl"] # config.gems << "tzinfo" # config.gems["rails"] = "1.2.3" config.gems << "activerecord-jdbch2-adapter" This will tell Warble to add the JDBC driver for H2 as well as the ActiveRecord JDBC and JDBC-H2 adapter Gems. Now generate the WAR file: jruby -S warble war This task generates the file: blog.war at the top level of the application as well as an exploded version of the war located here: tmp/war. The war should be ready to deploy to your Java application server. = Thanks - Dudley Flanders, for the Merb support - Robert Egglestone, for the original JRuby servlet integration project, Goldspike - Chris Neukirchen, for Rack - Sun Microsystems, Nick's employer, for project support - Last, but not least, Flannery, Nick's wife, for patience and understanding
This feature is coming soon. Sit tight!