Web applications
Installing war support
The following steps will install the "war" feature (support for deploying WAR files with Servlet and JSPs into a Jetty server) into your Karaf instance.
List the available features -
karaf@root> features:list State Name . . . [uninstalled] [2.2.0] obr karaf-2.2.0 [uninstalled] [2.2.0] config karaf-2.2.0 [uninstalled] [2.2.0] http karaf-2.2.0 [uninstalled] [2.2.0] war karaf-2.2.0 [uninstalled] [2.2.0] webconsole karaf-2.2.0 [installed ] [2.2.0] ssh karaf-2.2.0 . . .
Install the war feature (and the sub-features it requires) -
karaf@root> features:install war
Note: you can use the -v or --verbose to see exactly what Karaf does
karaf@root> features:install -v war Installing feature war 2.1.99-SNAPSHOT Installing feature http 2.1.99-SNAPSHOT Installing feature jetty 7.1.6.v20100715 Installing bundle mvn:org.apache.geronimo.specs/geronimo-servlet_2.5_spec/1.1.2 Found installed bundle: org.apache.servicemix.bundles.asm [10] Installing bundle mvn:org.eclipse.jetty/jetty-util/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-io/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-http/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-continuation/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-server/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-security/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-servlet/7.1.6.v20100715 Installing bundle mvn:org.eclipse.jetty/jetty-xml/7.1.6.v20100715 Checking configuration file mvn:org.apache.karaf/apache-karaf/2.1.99-SNAPSHOT/xml/jettyconfig Installing bundle mvn:org.ops4j.pax.web/pax-web-api/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-spi/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-runtime/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-jetty/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-jsp/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-extender-war/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-extender-whiteboard/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.web/pax-web-deployer/0.8.2-SNAPSHOT Installing bundle mvn:org.ops4j.pax.url/pax-url-war/1.2.4
Verify the features were installed
servicemix> features/list State Name . . . [installed ] [2.2.0] http karaf-2.2.0 [installed ] [2.2.0] war karaf-2.2.0 . . .
Verify the installed bundles were started
karaf@root> osgi:list START LEVEL 100 ID State Level Name . . . [ 32] [Active ] [ ] [ 60] geronimo-servlet_2.5_spec (1.1.2) [ 33] [Active ] [ ] [ 60] Apache ServiceMix :: Bundles :: jetty (6.1.22.2) [ 34] [Active ] [ ] [ 60] OPS4J Pax Web - API (1.0.0) [ 35] [Active ] [ ] [ 60] OPS4J Pax Web - Service SPI (1.0.0) [ 36] [Active ] [ ] [ 60] OPS4J Pax Web - Runtime (1.0.0) [ 37] [Active ] [ ] [ 60] OPS4J Pax Web - Jetty (1.0.0) [ 38] [Active ] [ ] [ 60] OPS4J Pax Web - Jsp Support (1.0.0) [ 39] [Active ] [ ] [ 60] OPS4J Pax Web - Extender - WAR (1.0.0) [ 40] [Active ] [ ] [ 60] OPS4J Pax Web - Extender - Whiteboard (1.0.0) [ 42] [Active ] [ ] [ 60] OPS4J Pax Web - FileInstall Deployer (1.0.0) [ 41] [Active ] [ ] [ 60] OPS4J Pax Url - war:, war-i: (1.2.4) . . .
The Jetty server should now be listening on http://localhost:8181/, but with no published applications available.
HTTP ERROR: 404 NOT_FOUND RequestURI=/ Powered by jetty://
Deploying a WAR to the installed web feature
The following steps will describe how to install a simple WAR file (with JSPs or Servlets) to the just installed web feature.
To deploy a WAR (JSP or Servlet) to Jetty, update its MANIFEST.MF to include the required OSGi headers as described here -
http://team.ops4j.org/wiki/display/ops4j/Pax+Web+Extender+-+War+-+OSGi-fyCopy the updated WAR (archive or extracted files) to the deploy directory.
If you want to deploy a sample web application into Karaf, you could use the following command:
karaf@root> osgi:install -s webbundle:http://tomcat.apache.org/tomcat-5.5-doc/appdev/sample/sample.war?Bundle-SymbolicName=tomcat-sample&Webapp-Context=/sample
Then open your web browser and point to http://localhost:8181/sample/index.html.