|             | 
 
This chapter includes the following tips to increase developer productivity:
See Team Plug-ins.
Based on the test described in the next paragraph with a basic portal application, the JRockit JVM is faster than the Hotspot JVM for iterative development.
Using a scenario that is based on a typical developer’s tasks—starting a server, deploying an application, then redeploying the application ten times—JRockit saves several minutes of wait time on a reasonably fast Linux machine. You’ll save even more time on a slower computer.
For more information using JRockit, see:
Running the Debug Server slows down both JRockit and the Sun JVM. In the developer’s scenario described in the previous section, running debug add several minutes of wait time.
 
Obviously, using debugging will save you much more time in productivity when you need it compared to sprinkling your code with printlns. However, if you are not going to use debug, start the server without it.
For additional information, see:
As your portal gets larger, you may need to increase the heap (-Xmx) and initial heap sizes (-Xms). It is generally best to make the initial and maximum heap sizes equal.
Because of the size of a portal EAR, redeployment of a portal application can be slow—several minutes, depending on the machine. However, you can organize your work to spend less time waiting and avoid slow redeployment in the following ways:
 
JSPs, .portal files, and similar objects do not need to redeploy. For example, if you change a JSP and then republish in WorkSpace Studio, basically nothing happens. Use coding in a JSP for light investigation or testing.
For information about using WorkSpace Studio for JSP development, see BEA Workshop for JSP in BEA Workshop Product Family 10.2.
The redeployment of a web application, including a portal web application, is significantly faster than deploying the entire EAR.
 
If your only change a web application, WorkSpace Studio republishes only that web application. Therefore, it is faster to code in a web application as classes in the web project’s Java Resources/src folder. They deploy in the web application’s WEB-INF/classes, and WorkSpace Studio directs the server redeploy only the WAR (unless you change something that requires the application to redeploy).
For additional information, see Streamlining Deployment/Testing in BEA Workshop Product Family 10.2.
Because the majority of application redeployment time is spent processing resources like portal EJBs, you can save time by avoiding redeployment of these resources. For instance, if you have code that is application-scoped, such as EJBs, you may be able to deploy the code in a submodule. However, use of this method is limited, due to the ClassLoader arrangement that it requires. This technique will not work if the application calls code in the EJB project, such as implementing a content management SPI or registering P13n EventListeners and UUP.
 
To make an EJB project a submodule of the EAR, add a classloader-structure stanza to your EAR’s weblogic-application.xml file. This allows the EJB and WAR projects to redeploy without redeploying the EAR.
 
To add a classloader-structure stanza to your EAR’s weblogic-application.xml file:
module-uri names to those of your project:<wls:classloader-structure>
<wls:classloader-structure>
<wls:module-ref>
<wls:module-uri>projectXejb.jar</wls:module-uri>
</wls:module-ref>
<wls:classloader-structure>
<wls:module-ref>
<wls:module-uri>projectX.war</wls:module-uri>
</wls:module-ref>
</wls:classloader-structure>
</wls:classloader-structure>
</wls:classloader-structure>
 
Because this stanza makes your EJB project (projectXejb) a submodule of the EAR, it allows WebLogic Server to redeploy the EJB JAR without requiring the entire EAR to redeploy. Notice that the WAR project (projectX) is made a child of the EJB, which allows the code in the WAR to access the code in the EJB project.
|       |