blob: 265843caf5991a1cf7b4750c329f264629fc74c3 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML>
<HEAD>
<!-- $PAGETITLE -->
<TITLE>OpenEJB - HomeBaseDiscussion</TITLE>
<LINK href="http://openejb.apache.org/all.css" rel="stylesheet" type="text/css">
<!--[if IE]><link rel="stylesheet" type="text/css" media="screen, projection" href="openejb.apache.org/ie.css"><![endif]-->
<LINK rel="SHORTCUT ICON" href="http://openejb.apache.org/images/favicon.ico">
<META http-equiv="Content-Type" content="text/html;charset=UTF-8">
<SCRIPT language="javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.1/jquery.min.js" type="text/javascript"></SCRIPT>
<SCRIPT language="javascript" src="http://openejb.apache.org/tweet/jquery.tweet.js" type="text/javascript"></SCRIPT>
<SCRIPT type="text/javascript">
$(document).ready(function(){
$(".tweet").tweet({
avatar_size: 32,
count: 4,
fetch:25,
username: "openejb",
list: "contributors",
template:"{avatar}{text}",
filter: function(t){ return /openejb/i.test(t["tweet_raw_text"]); },
loading_text: "loading list..."
});
});
</SCRIPT>
</HEAD>
<BODY>
<!-- Delay the loading of the external javascript file needed for labels (as it takes too long to load and visibly holds loading of the page body) -->
<!-- To do this without javascript errors over undefined functions, we need to declare stubs here (that are overrided later by the proper implementations) -->
<SCRIPT language="JavaScript" type="text/javascript">
function doAddLabel(hideTextfieldAfterAddParam)
{
// stub
}
function onAddLabel()
{
// stub
}
function showLabelsInput()
{
// stub
}
</SCRIPT>
<A name="top"></A>
<TABLE class="frameTable" cellpadding="0" cellspacing="0" border="0">
<TR class="Row1">
<TD class="Col1"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col2"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col3"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col4"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col5"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
</TR>
<TR class="Row2">
<TD class="Col1"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col2">&nbsp;</TD>
<TD class="Col3" id="breadcrumbs">
<!-- $TOP_NAV_BAR -->
<A href="index.html" title="Index">Home</A> | <A href="news.html" title="News">News</A> | <A href="faq.html" title="FAQ">FAQ</A> | <A href="download.html" title="Download">Download</A> | <A href="mailing-lists.html" title="Mailing Lists">Lists</A> | <A href="http://issues.apache.org/jira/browse/OPENEJB" class="external-link" rel="nofollow">Issues</A>
</TD>
<TD class="Col4"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col5">&nbsp;</TD>
</TR>
<TR class="Row3">
<TD class="Col1"><IMG alt="" class="Row3Img" id="thinLine" src="http://openejb.apache.org/images/line_sm.gif"></TD>
<TD class="Col2"><IMG alt="" class="Row3Img" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col3"><IMG alt="" class="Row3Img" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col4"><IMG alt="" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col5"><IMG alt="" class="Row3Img" src="http://openejb.apache.org/images/dotTrans.gif"></TD>
</TR>
<TR class="Row4">
<TD class="Col1">
<SPAN id="Navigation">
<H3><A name="Navigation-Overview"></A>Overview</H3>
<UL class="alternate" type="square">
<LI><A href="index.html" title="Index">Home</A></LI>
<LI><A href="news.html" title="News">News</A></LI>
<LI><A href="faq.html" title="FAQ">FAQ</A></LI>
<LI><A href="download.html" title="Download">Download</A></LI>
<LI><A href="../OPENEJBx30/index.html" title="Index">Documentation</A></LI>
<LI><A href="examples.html" title="Examples">Examples</A></LI>
<LI><A href="http://cwiki.apache.org/confluence/display/OPENEJB/Lightening%20Demos" class="external-link" rel="nofollow">Lightning Demos</A></LI>
<LI><A href="mailing-lists.html" title="Mailing Lists">Mailing Lists</A></LI>
<LI><A href="source-code.html" title="Source Code">Source Code</A></LI>
<LI><A href="http://blogs.apache.org/openejb" class="external-link" rel="nofollow">Project Blog</A></LI>
</UL>
<H3><A name="Navigation-Servers"></A>Servers</H3>
<UL class="alternate" type="square">
<LI><A href="local-server.html" title="Local Server">Local</A></LI>
<LI><A href="remote-server.html" title="Remote Server">Remote</A></LI>
</UL>
<H3><A name="Navigation-Integrations"></A>Integrations</H3>
<UL class="alternate" type="square">
<LI><A href="../OPENEJBx30/tomcat.html" title="Tomcat">Tomcat</A></LI>
<LI><A href="geronimo.html" title="Geronimo">Geronimo</A></LI>
<LI><A href="webobjects.html" title="WebObjects">WebObjects</A></LI>
</UL>
<H3><A name="Navigation-Community"></A>Community</H3>
<UL class="alternate" type="square">
<LI><A href="team.html" title="Team">Team</A></LI>
<LI><A href="articles.html" title="Articles">Articles</A></LI>
<LI><A href="http://webchat.freenode.net/?channels=openejb" class="external-link" rel="nofollow">IRC</A></LI>
</UL>
<H3><A name="Navigation-RelatedProjects"></A>Related Projects</H3>
<UL class="alternate" type="square">
<LI><A href="http://activemq.apache.org/" class="external-link" rel="nofollow">ActiveMQ</A></LI>
<LI><A href="http://openjpa.apache.org/" class="external-link" rel="nofollow">OpenJPA</A></LI>
<LI><A href="http://cxf.apache.org/" class="external-link" rel="nofollow">CXF</A></LI>
</UL>
<H3><A name="Navigation-Index"></A>Index</H3>
<UL class="alternate" type="square">
<LI><A href="space-index.html" title="Space Index">Site Index</A></LI>
<LI><A href="../OPENEJBx30/space-index.html" title="Space Index">Doc Index</A></LI>
</UL>
<H3>
<A name="Navigation-Feeds"></A>
Feeds
</H3>
<UL class="feeds">
<LI>
<A href="http://cwiki.apache.org/confluence/spaces/rss.action?key=OPENEJB&newPages=false">
<IMG src="http://openejb.apache.org/images/rss.gif"></A>
<A class="feedsText" href="http://cwiki.apache.org/confluence/spaces/rss.action?key=OPENEJB&newPages=false">Site</A>
</LI>
<LI><A href="http://cwiki.apache.org/confluence/spaces/blogrss.action?key=OPENEJB">
<IMG src="http://openejb.apache.org/images/rss.gif"></A>
<A class="feedsText" href="http://cwiki.apache.org/confluence/spaces/blogrss.action?key=OPENEJB">News</A>
</LI>
</UL>
</SPAN>
</TD>
<TD class="Col2">&nbsp;</TD>
<TD class="Col3">
<TABLE id="PageHeader" border="0" width="100%">
<TR>
<TD>
<A href="http://openejb.org/">
<IMG hspace="0" src="http://openejb.apache.org/images/logo_openejb.gif" vspace="0">
</A>
</TD>
<TD align="right">
<A href="http://www.apache.org/">
<IMG src="http://www.apache.org/images/asf-logo.gif" width="258" height="66">
</A>
</TD>
</TR>
<TR>
<TD id="page_title">
<!-- $TITLE -->
HomeBaseDiscussion
</TD>
<TD align="right">
<BR><BR>
<!-- Google CSE Search Box Begins -->
<FORM id="searchbox_010475492895890475512:_t4iqjrgx90" action="http://www.google.com/cse">
<INPUT type="hidden" name="cx" value="010475492895890475512:_t4iqjrgx90">
<INPUT type="hidden" name="cof" value="FORID:0">
<INPUT name="q" type="text" size="25">
<INPUT type="submit" name="sa" value="Search">
</FORM>
<SCRIPT type="text/javascript" src="http://www.google.com/coop/cse/brand?form=searchbox_010475492895890475512:_t4iqjrgx90"></SCRIPT>
<!-- Google CSE Search Box Ends -->
</TD>
</TR>
</TABLE>
<P>
<!-- $BODY -->
<DIV id="PageContent">
<DIV class="panelMacro"><TABLE class="noteMacro"><COLGROUP><COL width="24"><COL></COLGROUP><TR><TD valign="top"><IMG src="https://cwiki.apache.org/confluence/images/icons/emoticons/warning.gif" width="16" height="16" align="absmiddle" alt="" border="0"></TD><TD><B>THIS PAGE IS ARCHIVED FOR THE MOMENT AND WILL BE REMOVED LATER.</B><BR><H1><A name="HomeBaseDiscussion-Lifein0.9.2"></A>Life in 0.9.2</H1>
<P>Some background on how a 0.9.2 installation behaves.</P>
<H2><A name="HomeBaseDiscussion-Basiclayout"></A>Basic layout</H2>
<P>Basically, openejb.base is the source for 100% of all configuration information and third party config files (log4j, castor, instantdb, whatever). This includes finding where the, possibly many, &lt;Deployment&gt; entries in the openejb.conf point. The openejb.home is where the code loading OpenEJB will look for all the OpenEJB libraries. Usually openejb.base is not explicitly set and defaults to the value of openejb.home, so many people are used to only dealing with openejb.home.</P>
<P>The point of having and openejb.base and openejb.home was basically to allow several independently configured instances of OpenEJB running on a system (perhaps embedded in Swing apps, in Tomcat, running as a standalone Server, or even in Groovy as Mr. Strachan did!) but without the need to copy all the OpenEJB system libraries everywhere.</P>
<P><B>openejb.home</B> </P>
<UL>
<LI>can be set explicitly via a system property.</LI>
<LI>if not set it default's to user.dir, which is the current working directory.<BR>
See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/util/FileUtils.java?%3D1.7.4.3#l58" class="external-link" rel="nofollow">source code</A></LI>
</UL>
<P><B>openejb.base</B></P>
<UL>
<LI>can be set explicitly via a system property.</LI>
<LI>If not set it default's to openejb.home.<BR>
See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/util/FileUtils.java?%3D1.7.4.3#l59" class="external-link" rel="nofollow">source code</A></LI>
</UL>
<P><B>openejb.configuration</B></P>
<UL>
<LI>can be set to explicitly point to the file containing your configuration.</LI>
<LI>If set to a relative path, we first look in user.dir/your-conf-file, then in openejb.base/your-conf-file</LI>
<LI>If not set we check in openejb.base/conf/openejb.conf</LI>
<LI>If no conf file is found, we create one in openejb.base/conf/openejb.conf<BR>
See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/facilities/org/openejb/alt/config/ConfigUtils.java?%3D1.21.2.1#l269" class="external-link" rel="nofollow">source code</A></LI>
</UL>
<P><B>relative paths in openejb.conf</B></P>
<UL>
<LI>Deployment entries are resolved relative to openejb.base. <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/facilities/org/openejb/alt/config/ConfigurationFactory.java?%3D1.22.2.1#l969" class="external-link" rel="nofollow">source code</A></LI>
<LI>Containers (such as the Castor CMP Container) use openejb.base to resolve their own config files. Kind of an [ugly hack|
<A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/facilities/org/openejb/alt/containers/castor_cmp11/CastorCMP11_EntityContainer.java?%3D1.16.2.6#l404" class="external-link" rel="nofollow">http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/facilities/org/openejb/alt/containers/castor_cmp11/CastorCMP11_EntityContainer.java?r=1.16.2.6#l404</A>] to get Castor JDO to load the database.xml and all other files from the right place, but it works.</LI>
<LI>Resource adapters that are embedded usually have config files of their own and are also loaded from the openeb.base. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/facilities/org/openejb/resource/jdbc/JdbcManagedConnectionFactory.java?%3D1.7#l71" class="external-link" rel="nofollow">code</A>. Again that could be done better.</LI>
</UL>
<P>Note: Both Containers and Resources are what OpenEJB thinks of as <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/spi/Service.java?%3D1.2#l47" class="external-link" rel="nofollow">Services</A> which have an init method. In hindsight, both hacks to the JDBC Resouces Adapter and Castor CMP Container could be removed if we simply guaranteed that a Service's init method is called &quot;relative&quot; to the openejb.base dir.</P>
<P><B>log files</B></P>
<UL>
<LI>The log4.configuration file is resolved relative to openejb.base. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/util/Logger.java?%3D1.11.4.3#l1601" class="external-link" rel="nofollow">code</A></LI>
<LI>The properties in the config file that point to files are also resolved relative to openejb.base. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/util/Logger.java?%3D1.11.4.3#l1632" class="external-link" rel="nofollow">code</A></LI>
</UL>
<P><B>OpenEJB libraries</B></P>
<UL>
<LI>The jars in the <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/server/org/openejb/server/Main.java?r=1.3" class="external-link" rel="nofollow">lib and dist</A> directories under openejb.home are <A href="http://cvs.openejb.org/viewrep/openejb/openejb-sfnet/src/main/org/openejb/util/ClasspathUtils.java?%3D1.5.2.1#l95" class="external-link" rel="nofollow">added to the classpath</A>.</LI>
</UL>
<H2><A name="HomeBaseDiscussion-Summary"></A>Summary</H2>
<P>A summary of the above in a different notation:</P>
<DIV class="preformatted panel" style="border-width: 1px;"><DIV class="preformattedContent panelContent">
<PRE>openejb.home = user.dir (can be set explicitly)
openejb.base = openejb.home (can be set explicitly)
openejb.conf = openejb.base/conf/openejb.conf (can be set explicitly)
logging.conf = openejb.base/conf/logging.conf (can be set explicitly)
deployments = paths listed in openejb.conf (relative paths resolved from openejb.base)
Classpath includes openejb.home/lib and openejb.home/dist
</PRE>
</DIV></DIV>
<H2><A name="HomeBaseDiscussion-Examplelayout"></A>Example layout</H2>
<P>In this one the openejb.home and openejb.base are set, everything else is defaulted. The openejb.conf file as been updated to point to the ejb jars by name (abc-ejbs.jar and xyz-ejbs.jar).</P>
<P>An example layout:</P>
<DIV class="preformatted panel" style="border-width: 1px;"><DIV class="preformattedContent panelContent">
<PRE>/usr/local/openejb (openejb.home)
/usr/local/openejb/lib (in classpath)
/usr/local/openejb/dist (in classpath)
/home/jsmith/foo_app (openejb.base)
/home/jsmith/foo_app/conf/openejb.conf
/home/jsmith/foo_app/conf/logging.conf
/home/jsmith/foo_app/abc-ejbs.jar (Deployment entry in openejb.conf)
/home/jsmith/foo_app/xyz-ejbs.jar (Deployment entry in openejb.conf)
/home/jsmith/foo_app/logs/
</PRE>
</DIV></DIV>
<H2><A name="HomeBaseDiscussion-AnotherExamplelayout"></A>Another Example layout</H2>
<P>In this example openejb.home and openejb.base are setup as well as the explicit paths for the openejb and log4j configuration files.</P>
<P>An example layout:</P>
<DIV class="preformatted panel" style="border-width: 1px;"><DIV class="preformattedContent panelContent">
<PRE>/usr/local/openejb (openejb.home)
/usr/local/openejb/lib (in classpath)
/usr/local/openejb/dist (in classpath)
/home/jsmith/foo_app (openejb.base)
/home/jsmith/foo_app/openejb.xml (openejb.configuration)
/home/jsmith/foo_app/abc-ejbs.jar (Deployment entry in openejb.xml)
/home/jsmith/foo_app/xyz-ejbs.jar (Deployment entry in openejb.xml)
/home/jsmith/foo_app/log4j.conf (log4j.configuration)
/home/jsmith/foo_app/mylogs/ (logging dir as defined in log4j.conf)
</PRE>
</DIV></DIV>
<H2><A name="HomeBaseDiscussion-PossibleandniceTomcatsetup."></A>Possible and nice Tomcat setup.</H2>
<P>Set openejb.base to be the same as catalina.home, then OpenEJB and Tomcat will share the same conf and logs directories.</P>
<H1><A name="HomeBaseDiscussion-CurrentOpenEJB1.0layout"></A>Current OpenEJB 1.0 layout</H1>
<P>In the current 1.0 code, user.dir and openejb.home and openejb.base are essentially aggregated together to create a larger layout for a single running OpenEJB instance. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb1/modules/core/src/java/org/openejb/util/FileUtils.java?%3D1.4#l267" class="external-link" rel="nofollow">code</A></P>
<P><B>openejb.home</B> </P>
<UL>
<LI>can be set explicitly via a system property.</LI>
<LI>if not set it default's to user.dir, which is the current working directory.<BR>
Same as 0.9.2</LI>
</UL>
<P><B>openejb.base</B></P>
<UL>
<LI>can be set explicitly via a system property.</LI>
<LI>If not set it default's to openejb.home.<BR>
Same as 0.9.2</LI>
</UL>
<P><B>openejb.configuration</B></P>
<UL>
<LI>can be set to explicitly point to the file containing your configuration.</LI>
<LI>If set to a relative path, we first look in user.dir/your-conf-file, then in openejb.base/your-conf-file, openejb.home/your-conf-file.</LI>
<LI>If not set we check in openejb.base/conf/openejb.conf, then openejb.home/conf/openejb.conf</LI>
<LI>If no conf file is found, we create one in openejb.base/conf/openejb.conf</LI>
</UL>
<P><B>relative paths in openejb.conf</B></P>
<UL>
<LI>Deployment entries are resolved relative to openejb.base, then openejb.home. <A href="http://cvs.openejb.org/viewrep/openejb/openejb1/modules/core/src/java/org/openejb/alt/config/ConfigurationFactory.java?%3D1.6#l1120" class="external-link" rel="nofollow">source code</A></LI>
<LI>Containers (such as the Castor CMP Container) use openejb.base to resolve their own config files. (Same as 0.9.2)</LI>
<LI>Resource adapters are loaded from the openeb.home, not openejb.base as in 0.9.2. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb1/modules/core/src/java/org/openejb/resource/jdbc/JdbcManagedConnectionFactory.java?%3D1.5#l147" class="external-link" rel="nofollow">code</A>.</LI>
</UL>
<P><B>log files</B></P>
<UL>
<LI>The log4.configuration file is resolved relative to openejb.base, then openejb.home.</LI>
<LI>Each property in the config file that point to files are also first resolved relative to openejb.base then openejb.home. See <A href="http://cvs.openejb.org/viewrep/openejb/openejb1/modules/core/src/java/org/openejb/util/Logger.java?r=1.6" class="external-link" rel="nofollow">code</A></LI>
</UL>
<P><B>OpenEJB libraries</B></P>
<UL>
<LI>The jars in the directories under openejb.home are added to the classloader.</LI>
</UL>
<H2><A name="HomeBaseDiscussion-Example"></A>Example</H2>
<P>An interesting note on this is that the openejb.home is only checked when the file or directory is not found in the openejb.base. So say you had the following entries in your openejb.conf.</P>
<DIV class="code panel" style="border-width: 1px;"><DIV class="codeContent panelContent">
<PRE class="code-xml">
<SPAN class="code-tag">&lt;Deployment dir=<SPAN class="code-quote">&quot;beans&quot;</SPAN> /&gt;</SPAN>
<SPAN class="code-tag">&lt;Deployment jar=<SPAN class="code-quote">&quot;foobar.jar&quot;</SPAN> /&gt;</SPAN>
</PRE>
</DIV></DIV>
<P>Then say you have an openejb.home with the following files and directories:</P>
<DIV class="preformatted panel" style="border-width: 1px;"><DIV class="preformattedContent panelContent">
<PRE>/usr/local/openejb (openejb.home)
/usr/local/openejb/dist/(multiple jars)
/usr/local/openejb/lib/(multiple jars)
/usr/local/openejb/conf/openejb.conf
/usr/local/openejb/beans/widget.jar
/usr/local/openejb/beans/dohickey.jar
/usr/local/openejb/beans/gizmo.jar
/usr/local/openejb/logs/ (default logging dir)
</PRE>
</DIV></DIV>
<P>And an openejb.base with the following files and directories:</P>
<DIV class="preformatted panel" style="border-width: 1px;"><DIV class="preformattedContent panelContent">
<PRE>/home/jsmith/foo_app (openejb.base)
/home/jsmith/foo_app/conf/openejb.conf (used for this app)
/home/jsmith/foo_app/foobar.jar
/home/jsmith/foo_app/log4j.conf (log4j.configuration)
/home/jsmith/foo_app/logs/ (logging dir as defined in log4j.conf)
</PRE>
</DIV></DIV>
<P>In this setup you will end up using your own conf file, your own logging file and logs directory. You will get the ejbs from foobar.jar located in your openejb.base and the ejbs from the widget.jar, dohickey.jar, and gizmo.jar files in openejb.home/beans.</P>
<P>Let's say that later on you decide you don't like having the foobar.jar listed in your conf file and decide to create a beans dir in your openejb.base and put it there. When you start up your openejb instance it will no longer contain the ejbs from the widget.jar, dohickey.jar, and gizmo.jar files. They are in the openejb.home and the openejb.home is only checked when the file or directory is not found in the openejb.base. By adding a beans directory to your openejb.base you also implicitly removed all the ejbs from openejb.home/beans.</P>
<P>By adding to your base you are potentially removing parts of your configuration at the same time.</P></TD></TR></TABLE></DIV>
</DIV>
</P>
</TD>
<TD class="Col4"><IMG src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col5">
</TD>
</TR>
<TR class="Row5">
<TD class="Col1">&nbsp;</TD>
<TD class="Col2">&nbsp;</TD>
<TD class="Col3">
<BR>
<BR>
<IMG width="100%" height="1" src="http://openejb.apache.org/images/line_light.gif">
<TABLE width="100%">
<TR>
<TD>
<SPAN class="bodyGrey">
<SMALL>
<NOTICE><!-- $FOOTER -->
Apache OpenEJB is an project of The Apache Software Foundation (ASF)
</NOTICE>
<BR>
Site Powered by
<A href="http://atlassian.com/">Atlassian</A>
<A href="http://atlassian.com/confluence/">Confluence</A>
.
</SMALL>
</SPAN>
</TD>
<TD align="right">
<A style="color:#999;font-size:small;font-weight:normal;" href="https://cwiki.apache.org/confluence/pages/editpage.action?spaceKey=OPENEJB&title=HomeBaseDiscussion">[ edit ]</A>
</TD>
</TR>
</TABLE>
<BR>
</TD>
<TD class="Col4"><IMG src="http://openejb.apache.org/images/dotTrans.gif"></TD>
<TD class="Col5">&nbsp;</TD>
</TR>
</TABLE>
<!-- Needed for composition plugin -->
<!-- delay the loading of large javascript files to the end so that they don't interfere with the loading of page content -->
<SPAN style="display: none">
<SCRIPT type="text/javascript" language="JavaScript" src="http://cwiki.apache.org/confluence/labels-javascript"></SCRIPT>
<SCRIPT src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</SCRIPT>
<SCRIPT type="text/javascript">
_uacct = "UA-2717626-1";
urchinTracker();
</SCRIPT>
</SPAN>
</BODY>
</HTML>