Thursday, April 9, 2009

Deploying ColdFusion 8 on JRun 4

8 on JRun 4

From : http://bhlms.fltr.ucl.ac.be

When you deploy ColdFusion on an existing version of JRun 4, you must expand the EAR file or WAR files manually before deployment.

If you are updating an existing deployment of ColdFusion MX, ColdFusion MX 6.1, or ColdFusion MX 7 for J2EE, you must undeploy ColdFusion MX, ColdFusion MX 6.1, or ColdFusion MX 7 for J2EE before you deploy ColdFusion 8, as described in Updating from an earlier version for J2EE.

Expand the EAR file

  1. Expand the EAR file by performing the following steps:
    1. Open a console window, navigate to the directory that contains the EAR file, and make a new directory named cfusion-ear:
2.                 md cfusion-ear (mkdir cfusion-ear on UNIX)
3.                  
    1. Change to the cfusion-ear directory and expand the cfusion.ear file with the jar command:
5.                 cd cfusion-ear
6.                 java_home/bin/jar -xvf ../cfusion.ear
7.                  

This expands the cfusion.ear file into cfusion.war and rds.war (rds.war is not included if you specified a context root of / when you ran the installation wizard).

    1. In cfusion-ear, make a new directory named cfusion-war.
9.                 md cfusion-war (mkdir cfusion-war on UNIX)
10.              
    1. Change to the cfusion-war directory and expand the cfusion.war file with the jar command:
12.             cd cfusion-war
13.             java_root/bin/jar -xvf ../cfusion.war
14.              

This expands the cfusion.war file.

    1. (If rds.war exists) Go up one level to cfusion-ear, make a new directory named rds-war.
16.             cd ..
17.             md rds-war (mkdir rds-war on UNIX)
18.              
    1. (If rds.war exists) Change to the rds-war directory and expand rds.war with the jar command:
20.             cd rds-war
21.             java_root/bin/jar -xvf ../rds.war
22.              

This expands rds.war.

    1. Go up one level to the cfusion-ear file, and delete the cfusion.war and rds.war files:
24.             cd ..
25.             del cfusion.war (rm cfusion.war on UNIX)
26.             del rds.war (rm rds.war on UNIX)
27.              
    1. Open the cfusion-ear/META-INF/application.xml file in a text editor.
    2. Change the web-uri element from cfusion.war to cfusion-war (or the name of the directory that contains the expanded cfusion.war file). Change the web-uri element for rds.war to rds-war. A directory name in the web-uri element cannot contain a dot.
    3. Save the application.xml file.
  1. Deploy ColdFusion 8 by copying the cfusion-ear directory structure to the jrun_root/servers/servername directory. If auto deploy is enabled, JRun 4 either deploys the application immediately (if the JRun server is running), or when you start the JRun server.
  2. Review the server log (jrun_root/logs/servername-event.log) to ensure that ColdFusion 8 deployed successfully.

When using WAR deployment, JRun uses the directory name of the expanded cfusion.war file as the context root. You can optionally modify the context root. By setting the context root to slash (/), you do not have to include the context root in the URL when accessing CFM pages.

Set the context root to /

  1. Stop the JRun server that is running ColdFusion.
  2. Delete the jrun_root/servers/servername/default-ear directory and all subdirectories.
  3. Start the JRun server that is running ColdFusion.
  4. Ensure that the admin JRun server is running.
  5. Start the JRun server instance "admin" and browse to http://localhost:8000 from a browser on the computer where JRun is installed to access the JRun Management Console (JMC).
  6. Click the server in the left pane.
  7. Click the cfusion Web Application.
  8. Change the context path to / (instead of /cfusion).
  9. Click Apply.
  10. Restart the JRun server that is running ColdFusion.

You must deploy the rds.war file to a context root of /CFIDE (all uppercase). When deploying on JRun, this means that you should expand the rds.war file into a directory named CFIDE.

Deploy ColdFusion 8 on JRun 4 as a WAR file

  1. Create a directory named cfusion.

The directory can have any name, but these instructions assume a directory name of cfusion under your JRun server instance. This directory becomes the context root into which ColdFusion is deployed. For example, if you are installing ColdFusion in the default JRun server, the directory is /opt/jrun4/servers/default/cfusion.

  1. Create a directory named CFIDE.

This directory is the context root into which the remote development service (RDS) application is deployed, for example, /opt/jrun4/servers/default/CFIDE.

  1. Stop the JRun server to which you want to deploy ColdFusion by using the JRun Launcher (jrun_root/bin/jrun) or type jrun_root/bin/jrun stop server_name in a console window.
  2. If you haven't done so already, open a console window, navigate to the cfusion directory, and use the jar utility to uncompress the cfusion.war file, by using the following commands:
5.           cd jrun_root/jrun4/servers/servername/cfusion 
6.           java_home/bin/jar -xvf cfmx_install_directory/cfusion.war

The directory jrun_root refers to the directory in which you installed JRun 4, for example, C:\JRun 4 or /opt/jrun4. Replace servername with the name of the server to which you are deploying ColdFusion. For example, if you installed ColdFusion in the default JRun server, replace servername with default.

  1. Navigate to the CFIDE directory and use the jar utility to uncompress the rds.war file, using the following commands:
8.           cd jrun_root/jrun4/servers/servername/CFIDE (or cd ../CFIDE)
9.           java_home/bin/jar -xvf cfmx_install_directory/rds.war

  1. Configure JVM settings through the Settings panel of the JRun Management Console (JMC) or by using a text editor to modify the jrun_root/bin/jvm.config file.
  2. To enable COM support (Windows only), add the following jIntegra binary directories to the JVM's native library path (java.library.path):
12.       WEB-INF/cfusion/jintegra/bin
13.       WEB-INF/cfusion/jintegra/bin/international

  1. (optional) To enable CORBA support, copy the vbjorb.jar file to the WEB-INF/cfusion/lib directory and define the following argument:

-Xbootclasspath/a:"cf_webapp_root/WEB-INF/cfusion/lib/vbjorb.jar"

  1. To enable charting (UNIX only), define the following argument:

-Djava.awt.graphicsenv=com.gp.java2d.ExGraphicsEnvironment"

and specify

com.gp.java2d.ExHeadlessGraphicsEnvironment

instead of

com.gp.java2d.ExGraphicsEnvironment.

  1. In addition to enabling sandbox security in the ColdFusion Administrator, the application server must be running a security manager (java.lang.SecurityManager) and you must define the following JVM arguments:
17.       -Djava.security.manager 
18.       -Djava.security.policy="cf_webapp_root/WEB-INF/cfusion/lib/coldfusion.policy" 
19.       -Djava.security.auth.policy="cf_webapp_root/WEB-INF/cfusion/lib/neo_jaas.policy"

  1. To use cfregistry in Windows, to use the cfreport tag for Crystal Reports, and to use any C++ CFX custom tags, you must add cfusion/lib to the Java library path. Add the following directory to the JVM's native library path (java.library.path):

WEB-INF/cfusion/lib

  1. If you are running Solaris without X Windows, to use the cfdocument tag, you must set the headless switch to true in the jvm.config file, as follows:

java.awt.headless=true

  1. Start the JRun server the way you stopped it in step 3, either by using the JRun Launcher or by typing jrun_root/bin/jrun start server_name in a command window. If autodeploy is enabled, JRun 4 deploys the application automatically when you start the JRun server.
  2. Review the server log (jrun_root/logs/servername-event.log) to ensure that ColdFusion deployed successfully.
  3. Start the ColdFusion Administrator to run the Configuration Wizard.

1 comment:

  1. You mentioned that to deploy ColdFusion on an existing version of JRun 4, you must expand the EAR file or WAR files manually before deployment. Why this need to be done manually.Is there no way to automate the process as this will help improving speed while testing

    ReplyDelete