Oracle Workflow Guide
Release 2.6.2
Part Number A95265-03 |
|
Step 13 Setting Up the Java Function Activity Agent
To execute external Java function activities, you must set up the Java Function Activity Agent. This functionality is currently only available for the standalone version of Oracle Workflow. The Java Function Activity Agent dequeues the messages related to external Java activities from the 'Outbound' queue for external function processing, calls the appropriate Java functions, and places the results on the 'Inbound' queue for external function processing.
Note: These 'Outbound' and 'Inbound' queues are separate from the queues used for the Business Event System. See: Workflow Queue APIs.
After a Java function completes, you must run a background engine to process the 'Inbound' queue and complete the function activity. See: Setting Up Background Engines.
Some standard Workflow activities are external Java function activities and require the Java Function Activity Agent. You can also define your own external Java function activities. See: Standard Activities, To Create a Function Activity, and Standard API for Java Procedures Called by Function Activities.
To run the Java Function Activity Agent, you must have Java Runtime Environment (JRE) Version 1.1.8, or a higher 1.1.x version, installed.
Note: The Java Runtime Environment is available for download from http://www.javasoft.com.
Context: You need to perform this step only once.
Starting the Java Function Activity Agent
If you are using the standalone version of Oracle Workflow, you can run scripts provided by Oracle Workflow to start the Java Function Activity agent. You can also start the agent manually.
When you start the Java Function Activity Agent, you must specify the database connection details. You can also optionally specify the character set and the JDBC driver type that you want to use.
You use different commands to start the agent depending on whether you are running it from a script or manually, which platform you are running it on, and which options you want to specify.
Starting the Java Function Activity Agent From a Script
If you are using the standalone version of Oracle Workflow, you can run scripts called wfjvlsnr.csh or wfjvlsnr.bat to start the Java Function Activity Agent on UNIX or on Windows NT, respectively. These scripts are located on your server in the Oracle Workflow admin
subdirectory.
If you define your own external Java function activities, you must edit the scripts to include the path to the JAR files containing your custom Java classes. The custom class files should reside on the same platform where the Java Function Activity Agent is run. The Java Function Activity Agent does not need to reside on the same tier as the database, however.
You can use commands with different syntax to run the scripts, depending on your platform and the options you want to specify.
Running the wfjvlsnr.csh Script on UNIX
For example, you can use the following command to run the wfjvlsnr.csh script on UNIX, if you want to use the default JDBC OCI8 driver:
wfjvlsnr.csh <user_name>/<password>@<connect_string> [<character_set>]
Replace the parameters in the command as follows:
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. Since this command uses the default JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry.
- <character_set>--The character set to use for the database session. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
You can also use the following command to run the wfjvlsnr.csh script on UNIX, if you want to specify the JDBC driver type to use:
wfjvlsnr.csh "<user_name> <password> <connect_string> [<JDBC_driver>]" [<character_set>]
Replace the parameters in the command as follows:
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. The format of the connect string depends on the JDBC driver type.
- For a JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry, in the following format: <database_name>
- For a JDBC THIN driver, you can use two different types of connect string. For the first type, the connect string should include the host name, port number, and database system identifier (SID) in the following format: <host_name>:<port_number>:<database_SID>
- For the second type, the connect string should include an Oracle Net name-value pair with the host name, protocol, port number, and SID in the following format: (description=(address=(host=<host_name>)(protocol= <protocol>)(port=<port_number>))(connect_data=(sid= <database_SID>)))
- <JDBC_driver>--The JDBC driver type you want to use to connect to the database. The JDBC driver type can be either oci8 or thin. If you do not specify a character set, Oracle Workflow uses the JDBC OCI8 driver by default.
Note: The connection details, including the user name, password, connect string, and JDBC driver type, must be enclosed in double quotes to separate them from the character set parameter.
- <character_set>--The character set to use for the database session. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Running the wfjvlsnr.bat Script on Windows NT
On Windows NT, you can use the following command to run the wfjvlsnr.bat script, if you want to use the default JDBC OCI8 driver:
wfjvlsnr.bat <user_name>/<password>@<connect_string> [<character_set>]
Replace the parameters in the command as follows:
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. Since this command uses the default JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry.
- <character_set>--The character set to use for the database session. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
You can also use the following command to run the wfjvlsnr.bat script on Windows NT, if you want to specify the JDBC driver type to use:
wfjvlsnr.bat "<user_name> <password> <connect_string> [<JDBC_driver>]" [<character_set>]
Replace the parameters in the command as follows:
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. The format of the connect string depends on the JDBC driver type.
- For a JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry, in the following format: <database_name>
- For a JDBC THIN driver, you can use two different types of connect string. For the first type, the connect string should include the host name, port number, and database system identifier (SID) in the following format: <host_name>:<port_number>:<database_SID>
- For the second type, the connect string should include an Oracle Net name-value pair with the host name, protocol, port number, and SID in the following format: (description=(address=(host=<host_name>)(protocol= <protocol>)(port=<port_number>))(connect_data=(sid= <database_SID>)))
- <JDBC_driver>--The JDBC driver type you want to use to connect to the database. The JDBC driver type can be either oci8 or thin. If you do not specify a character set, Oracle Workflow uses the JDBC OCI8 driver by default.
Note: The connection details, including the user name, password, connect string, and JDBC driver type, must be enclosed in double quotes to separate them from the character set parameter.
- <character_set>--The character set to use for the database session. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Starting the Java Function Activity Agent Manually
To start the Java Function Activity Agent manually, run JRE against oracle.apps.fnd.wf.WFFALsnr, specifying your CLASSPATH, the user name and password of your Oracle Workflow database account, and the database connect string. You can also optionally specify the character set and the JDBC driver type that you want to use.
The CLASSPATH must point to the Java Runtime Environment, the directory containing the Workflow JAR files, the Oracle XML parser, the Oracle JDBC implementation, and the following Workflow JAR files:
- wfjava.jar--The Java Function Activity Agent.
- wfapi.jar--Workflow Java APIs.
- The Share JAR file--Utilities referenced by the Workflow Java APIs. In the standalone version of Oracle Workflow with Oracle9i, this file is named share-<version>.jar, such as share-1_1_9.jar, or whichever version is current. In the version of Oracle Workflow embedded in Oracle Applications, this file is named fndbalishare.jar.
- The Ewt JAR file--Utilities referenced by the Workflow Java APIs. In the standalone version of Oracle Workflow with Oracle9i, this file is named ewt-<version>.jar, such as ewt-3_3_18.jar, or whichever version is current. In the version of Oracle Workflow embedded in Oracle Applications, this file is named fndewt.jar.
- The Swing JAR file--Optional additional utilities. In the standalone version of Oracle Workflow with Oracle9i, this file is named swingall-<version>.jar, such as swingall-1_1_1.jar, or whichever version is current. In the version of Oracle Workflow embedded in Oracle Applications, this file is named fndswing.jar.
Note: In the standalone version of Oracle Workflow with Oracle9i, the Workflow JAR files are located in the <ORACLE_HOME>/jlib directory. In the version of Oracle Workflow embedded in Oracle Applications, the Workflow JAR files are located in the <ORACLE_HOME>/wf/java/oracle/apps/fnd/wf/jar/ directory.
If you define your own external Java function activities, you must also include the JAR files containing your custom Java classes in the CLASSPATH. The custom class files should reside on the same platform where the Java Function Activity Agent is run. The Java Function Activity Agent does not need to reside on the same tier as the database, however.
You can use commands with different syntax to start the Java Function Activity Agent manually, depending on your platform and the options you want to specify.
Starting the Java Function Activity Agent on UNIX
For example, you can use the following command to start the Java Function Activity Agent on UNIX, if you want to use the default JDBC OCI8 driver:
jre -classpath "$<JREPATH>/rt.jar:$<Workflow_JAR_file_directory>:
$<Workflow_JAR_file_directory>/wfjava.jar:$<ORACLE_HOME>/wf/
xml/java/lib/xmlparserv2.jar:$<Workflow_JAR_file_directory>/wfapi.jar:$<ORACLE_HOME>/jdbc/lib/classes111.zip:
$<Workflow_JAR_file_directory>/<Share_JAR_file>:
$<Workflow_JAR_file_directory>/<Ewt_JAR_file>:
$<Workflow_JAR_file_directory>/<Swing_JAR_file>:" [-DCHARSET=<character_set>] oracle.apps.fnd.wf.WFFALsnr <user_name>/<password>@<connect_string>
In this command, you can optionally use the -DCHARSET option to specify the character set that you want to use. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Replace the parameters in the command as follows:
- <character_set>--The character set to use for the database session.
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. Since this command uses the default JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry.
You can also use the following command to start the Java Function Activity Agent on UNIX, if you want to specify the JDBC driver type to use:
jre -classpath "$<JREPATH>/rt.jar:$<Workflow_JAR_file_directory>:
$<Workflow_JAR_file_directory>/wfjava.jar:$<ORACLE_HOME>/wf/
xml/java/lib/xmlparserv2.jar:$<Workflow_JAR_file_directory>/wfapi.jar:$<ORACLE_HOME>/jdbc/lib/classes111.zip:
$<Workflow_JAR_file_directory>/<Share_JAR_file>:
$<Workflow_JAR_file_directory>/<Ewt_JAR_file>:
$<Workflow_JAR_file_directory>/<Swing_JAR_file>:" [-DCHARSET=<character_set>] oracle.apps.fnd.wf.WFFALsnr <user_name> <password> <connect_string> [<JDBC_driver>]
In this command, you can optionally use the -DCHARSET option to specify the character set that you want to use. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Replace the parameters in the command as follows:
- <character_set>--The character set to use for the database session.
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. The format of the connect string depends on the JDBC driver type.
- For a JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry, in the following format: <database_name>
- For a JDBC THIN driver, you can use two different types of connect string. For the first type, the connect string should include the host name, port number, and database system identifier (SID) in the following format: <host_name>:<port_number>:<database_SID>
- For the second type, the connect string should include an Oracle Net name-value pair with the host name, protocol, port number, and SID in the following format: (description=(address=(host=<host_name>)(protocol= <protocol>)(port=<port_number>))(connect_data=(sid= <database_SID>)))
- <JDBC_driver>--The JDBC driver type you want to use to connect to the database. The JDBC driver type can be either oci8 or thin. If you do not specify a character set, Oracle Workflow uses the JDBC OCI8 driver by default.
Starting the Java Function Activity Agent on Windows NT
On Windows NT, you can use the following command to start the Java Function Activity Agent, if you want to use the default JDBC OCI8 driver:
jre -classpath ";<JREPATH>\rt.jar;<Workflow_JAR_file_directory>;
<Workflow_JAR_file_directory>\wfjava.jar;<ORACLE_HOME>\wf\
xml\java\lib\xmlparserv2.jar;<Workflow_JAR_file_directory>\
wfapi.jar;<ORACLE_HOME>\jdbc\lib\classes111.zip;
<Workflow_JAR_file_directory>\<Share_JAR_file>;
<Workflow_JAR_file_directory>\<Ewt_JAR_file>;
<Workflow_JAR_file_directory>\<Swing_JAR_file>;"
-nojit [-DCHARSET=<character_set>]
oracle.apps.fnd.wf.WFFALsnr <user_name>/<password>@<connect_string>
In this command, you can optionally use the -DCHARSET option to specify the character set that you want to use. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Replace the parameters in the command as follows:
- <character_set>--The character set to use for the database session.
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. Since this command uses the default JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry.
You can also use the following command to start the Java Function Activity Agent on Windows NT, if you want to specify the JDBC driver type to use:
jre -classpath ";<JREPATH>\rt.jar;<Workflow_JAR_file_directory>;
<Workflow_JAR_file_directory>\wfjava.jar;<ORACLE_HOME>\wf\
xml\java\lib\xmlparserv2.jar;<Workflow_JAR_file_directory>\
wfapi.jar;<ORACLE_HOME>\jdbc\lib\classes111.zip;
<Workflow_JAR_file_directory>\<Share_JAR_file>;
<Workflow_JAR_file_directory>\<Ewt_JAR_file>;
<Workflow_JAR_file_directory>\<Swing_JAR_file>;"
-nojit [-DCHARSET=<character_set>]
oracle.apps.fnd.wf.WFFALsnr <user_name> <password>
<connect_string> [<JDBC_driver>]
In this command, you can optionally use the -DCHARSET option to specify the character set that you want to use. If you do not specify a character set, Oracle Workflow uses UTF8 by default.
Replace the parameters in the command as follows:
- <character_set>--The character set to use for the database session.
- <user_name>--The user name of your Oracle Workflow database account.
- <password>--The password for your Oracle Workflow database account.
- <connect_string>--The connect string for the database. The format of the connect string depends on the JDBC driver type.
- For a JDBC OCI8 driver, the connect string should be the database name as specified in its TNSNAMES entry, in the following format: <database_name>
- For a JDBC THIN driver, you can use two different types of connect string. For the first type, the connect string should include the host name, port number, and database system identifier (SID) in the following format: <host_name>:<port_number>:<database_SID>
- For the second type, the connect string should include an Oracle Net name-value pair with the host name, protocol, port number, and SID in the following format: (description=(address=(host=<host_name>)(protocol= <protocol>)(port=<port_number>))(connect_data=(sid= <database_SID>)))
- <JDBC_driver>--The JDBC driver type you want to use to connect to the database. The JDBC driver type can be either oci8 or thin. If you do not specify a character set, Oracle Workflow uses the JDBC OCI8 driver by default.
Stopping the Java Function Activity Agent
Normally, the Java Function Activity Agent runs as a perpetual job. However, you can stop the agent by running a script called wfjvstop.sql, located in the admin/sql
subdirectory on your Oracle Workflow server. This script places a stop message on the 'Outbound' queue. See: wfjvstop.sql.
Note: If you are running more than one Java Function Activity Agent simultaneously, you must run the wfjvstop.sql script once for each Java Function Activity Agent.
|
Copyright © 1996, 2002 Oracle Corporation.
All Rights Reserved.