| Oracle® BPEL Process Manager Quick Start Guide 10g (10.1.3.1.0) Part Number B28983-01 | 
 | 
| 
 | View PDF | 
This chapter provides an overview of how the business process execution language (BPEL) and Oracle BPEL Process Manager enable you to design service-oriented architecture (SOA)-based applications by developing synchronous and asynchronous services into end-to-end BPEL process flows. This chapter also describes how to install and start the Oracle BPEL Process Manager, Oracle BPEL Server, and other key components.
This chapter contains the following topics:
Installing Oracle Application Server SOA Suite and Oracle JDeveloper
Starting and Stopping Oracle BPEL Process Manager Components
Many companies are looking at Web services and SOA as a method for addressing the integration requirements involved in building connected applications. While SOA has existed for over a decade, there was confusion about which interfaces to adopt. BPEL and Web service standards solve this dilemma by addressing common application requirements in an open, portable, and standard way. SOA optimizes business performance by using existing resources and minimizing the cost of deploying new applications. Enterprises adopting these standards and architectural approaches achieve a significant return on investment (ROI) from using the same standards-based approach to building connected applications that they used for building Web applications with Java/Java 2 Platform, Enterprise Edition (J2EE).
Making Web services work is a two-step process:
Publish the services.
Publishing a service involves taking a function within an existing application or system and making it available in a standard way.
Compose, or orchestrate, the services into business flows.
Orchestration involves composing multiple services into an end-to-end business process.
Web services standards, including web services description language (WSDL), extensible markup language (XML), and simple object access protocol (SOAP), have emerged as an effective and highly interoperable platform for publishing services. In addition, high performance binding frameworks enable enterprises to access legacy systems and native Java code without having to wrap them in a SOAP interface.
BPEL is emerging as the clear standard for composing multiple synchronous and asynchronous services into collaborative and transactional process flows. BPEL benefits from over 15 years of research that improves upon its predecessor languages of XLANG and WSFL. BPEL provides the following features:
Web services/WSDL as component model
XML as data model (data loose-coupling)
Synchronous and asynchronous message exchange patterns
Deterministic and nondeterministic flow coordination
Hierarchical exception management
Long-running unit of work/compensation
Since the BPEL specification was submitted to the Organization for the Advancement of Structured Information Standards (OASIS) in March 2003, it has gained the support of nearly every major industry vendor. This provides a great benefit to enterprises that can now implement their business processes in a standard and portable way, avoiding vendor-specific rules to a degree not previously possible.
This section contains these topics:
Oracle BPEL Process Manager provides a user-friendly and reliable solution for designing, deploying, and managing BPEL business processes. Oracle BPEL Process Manager consists of the key components shown in Figure 1-1.
Oracle BPEL Process Manager is loaded into Oracle JDeveloper. This extends the functionality of Oracle JDeveloper to enable you to model, edit, and design business processes using BPEL. Oracle JDeveloper provides a graphical and user-friendly way to build BPEL processes. What is unique about Oracle JDeveloper is that it uses BPEL as its native format. This means that processes built with Oracle JDeveloper are 100% portable. Oracle JDeveloper also enables you to view and modify the BPEL source without decreasing the usefulness of the tool. The core BPEL engine provides the most mature, scalable, and robust implementation of a BPEL server available today. Oracle BPEL Process Manager executes standard BPEL processes. Oracle BPEL Process Manager also provides a dehydration capability that enables the states of long-running flows to be automatically maintained in a database, thus enabling clustering for both fail over and scalability. Oracle BPEL Server uses an underlying J2EE application server, with support for most major commercial application servers and a bundled version available.The built-in integration services enable you to use advanced connectivity and transformation capabilities of standard BPEL processes. These capabilities include support for XSLT and XQuery transformation, and bindings to hundreds of legacy systems through Java connector architecture (JCA) adapters and native protocols. A human task service is provided as a built-in BPEL service to enable the integration of people and manual tasks into BPEL flows.The extensible WSDL binding framework enables connectivity to protocols and message formats other than SOAP. Bindings are available for JMS, e-mail, JCA, HTTP GET, HTTP POST, and many other protocols enabling simple connectivity to hundreds of back-end systems.
Oracle Enterprise Manager 10g BPEL Control provides a mature Web-based interface for management, administration, and debugging of processes deployed to Oracle BPEL Server. Audit trails and process history and reporting information are automatically maintained and available through both Oracle Enterprise Manager 10g BPEL Control and a Java API.
Oracle BPEL Process Manager provides the following key differences:
The power of an open standard
By capturing your business processes in BPEL, you protect your intellectual property and investments while avoiding vendor lock-in. BPEL is to business process management what SQL is to data management.
Unparalleled visibility and administration
Oracle Enterprise Manager 10g BPEL Control reduces the cost and complexity of deploying and managing your business processes. Visually monitor the execution of each BPEL process, drill down into the audit trail and view the details of each conversation, or debug a running flow against its BPEL implementation.
Open and flexible binding framework
You can orchestrate XML Web services, and also Java/J2EE components, portals, JCA interfaces, and Java message service (JMS) destinations. You can tie into back-end systems. You can use your Java skills and application server investments.
Oracle BPEL Process Manager includes the following features:
Oracle JDeveloper
Native BPEL support
Drag-and-drop process modeler
Universal description, discover, and integration (UDDI) and Web services inspection language (WSIL) service browser
Visual XPath editor
One-click build and deploy
Oracle Enterprise Manager 10g BPEL Control
Visual monitoring
Auditing
BPEL debugging
Process versioning
In-flight administration
Process performance monitoring statistics
Partitioning/domains
Built-in integration services
Java embedding
E-mail and JMS messaging services
Extensible style sheet language transformation (XSLT) and XQuery transformation services
Workflow tasks and portal integration
Extensible WSIF binding framework
Comprehensive BPEL version 1.1
Synchronous and asynchronous messaging
Context dehydration
Advanced exception management
Side-by-side versioning
Large XML documents
This section describes how to install Oracle Application Server SOA Suite and Oracle JDeveloper and configure Oracle BPEL Process Manager to work with Oracle JDeveloper.
This section contains the following topics:
Note:
If you install the Oracle BPEL Process Manager for Developers installation type and attempt to use this tutorial, note that the ports (9700), Oracle BPEL Server startup commands, and Oracle Enterprise Manager 10g BPEL Control user name (bpeladmin) may be different from those listed in this tutorial.See the Oracle Application Server Installation Guide 10g Release 3 (10.1.3.1) for your operating system for instructions on installing Oracle Application Server SOA Suite.
Select Basic Install on the Oracle Application Server SOA Suite 10.1.3.1.0 Installation window.
Note:
If you want to use Oracle BPEL Process Manager samples, enter welcome1 in the AS Administrator Password field of the Oracle Application Server SOA Suite 10.1.3.1.0 Installation window for the oc4jadmin user. If you enter a different password, some samples require modification in order to work.Click Install.
Click Exit when installation completes.
Identify several port numbers that were automatically configured during installation. You use these port numbers when creating application server and integration server connections to Oracle BPEL Server.
Use a text editor to open the SOA_Oracle_Home\bpel\utilities\ant-orabpel.properties file.
Make note of the ports being used by the following properties:
http.port
opmn.requestport
These port values are required later when you create connections in "Creating Oracle Application Server and Integration Server Connections".
You must separately install Oracle JDeveloper 10.1.3.1 Studio.
Unzip Oracle JDeveloper into a location on your host.
Start Oracle JDeveloper by clicking JDev_Oracle_Home\JDev\bin\jdev.exe or creating a shortcut.
Note:
Do not install Oracle JDeveloper into a directory path that includes a space (for example,C:\Program Files\JDev). If you do, you receive an error when you compile BPEL processes.Select Connection Navigator from the View main menu in Oracle JDeveloper.
Right-click Application Server.
Select New Application Server Connection.
Click Next on the Welcome page.
Provide a meaningful name for connecting to the application server. Remember this name, as you select it when creating an integration server connection in Step 19.
Select Oracle Application Server 10g 10.1.3 from the Connection Type list.
Click Next.
Enter the following details:
| Field | Value | 
|---|---|
| Username | oc4jadmin | 
| Password | Enter the same administrator password you entered in "Installing Oracle Application Server SOA Suite". | 
| Deploy Password | Select this check box; otherwise, you must authenticate each time you deploy a process. | 
Click Next.
Enter the following details:
| Field | Value | 
|---|---|
| Host Name | localhost | 
| OPMN Port | Enter the same port value used by the opmn.requestportproperty that you identified in Step 2 of "Identifying Ports". This is likely port number6003. | 
| Group/OC4J Instance Name | home | 
| Single Instance | Select this radio button. | 
| Group | Leave this radio button unselected. | 
Click Next.
Test the connection by clicking Test Connection. If the connection is successful, the following message appears:
Success!
Click Finish.
Right-click Integration Server in the Connection Navigator.
Select New Integration Server Connection.
You use this integration server connection to deploy all your BPEL processes.
Click Next on the Welcome page.
Provide a meaningful name for connecting to the server.
Click Next.
Select the application server connection name you specified in Step 5 from the Application Server list.
Enter the following details:
| Field | Value | 
|---|---|
| Host Name | localhost | 
| Port | Enter the same port value used by the http.portproperty that you identified in Step 2 of "Identifying Ports". This is likely port number8888. | 
| Add host name to the list of proxy exceptions | Select this check box to automatically add this host to the list of proxy exceptions shown in the Exceptions field under Tools > Preferences > Web Browser and Proxy. The first time it is started, Oracle JDeveloper by default picks up these proxy exceptions that are set for your browser. | 
Click Next.
Test the connection by clicking Test Connection. If the connection is successful, the following message appears:
Application Server: OK BPEL Process Manager Server: OK ESB Server: OK
Click Finish.
Follow the instructions in Table 1-1 to start and stop Oracle BPEL Process Manager components.
Table 1-1 Starting and Stopping Oracle BPEL Process Manager Components
| To Access The... | On Windows... | On UNIX... | 
|---|---|---|
| Oracle BPEL Server | Select Start > All Programs > Oracle - Oracle_Home > Start SOA suite | To start Oracle BPEL Server: From  
 To stop Oracle BPEL Server: From  
 | 
| Oracle JDeveloper | See Step 2 of "Installing Oracle JDeveloper" | 
 | 
| Oracle Enterprise Manager 10g BPEL Control | You must first start Oracle BPEL Server. To start Oracle Enterprise Manager 10g BPEL Control: 
 You can also start Oracle Enterprise Manager 10g BPEL Control using the URL for your installation, which can found in  | First start Oracle BPEL Server. To start Oracle Enterprise Manager 10g BPEL Control: 
 | 
| Developer Prompt | Select Start > All Programs > Oracle - Oracle_Home > Oracle BPEL Process Manager > Developer Prompt to open up a command prompt at the  | Setting Developer Prompt in Bourne shell: 
 
 
 
 | 
| Oracle BPEL Process Manager Samples and Tutorials | For details about BPEL samples and additional tutorials available for use: Select Start > All Programs > Oracle - Oracle_Home > Oracle BPEL Process Manager > Getting Started with Samples | Log into the following URL: 
 | 
| Sample Worklist Application | To access the login window for Oracle BPEL Worklist Application: Select Start > All Programs > Oracle - Oracle_Home > Oracle BPEL Process Manager > Sample Worklist Application You may also start Oracle BPEL Worklist Application using the URL for your installation, which is found in  | First start Oracle BPEL Server. To start Oracle BPEL Worklist Application: 
 | 
Note:
Always use the Developer Prompt to open an operating system command prompt in this guide. This sets all required paths. Opening an operating system command prompt in any other way is not supported.The hostname of your computer was automatically added to the Oracle JDeveloper preference settings during installation. If the hostname does not appear in the preference settings, you can receive parsing errors when selecting a WSDL file on the Service Explorer window while creating a partner link.
Select Preferences from the Tools main menu.
Click Web Browser and Proxy.
Verify that your hostname is in the Exceptions field. For example, if your hostname is myhost-pc:
us.acme.com|*.us.acme.com|127.0.0.1|myhost-pc|localhost
Ensure also that localhost appears in the Exceptions field.
Click OK.
You are now ready to design your BPEL process.
As you use Oracle JDeveloper, namespace values such as ns1:, ns2:, or client: can display in an Expression field or Variables navigation tree when creating copy operations in Assign activities, or in fields of other activities.
Oracle BPEL Process Manager attempts to reduce your interaction with namespaces. When a namespace appears in an Expression field or Variables navigation tree, accept the namespace prefixes that display when filling in the parts of your query or expression.
XML namespaces provide a method for distinguishing between duplicate element type and attribute names. Such duplication can occur, for example, in an XSLT style sheet or document that contains element types and attributes from two different DTDs. A <refuse> element means something entirely different for a sanitation agency than a <refuse> element for a loan processing agency. For this reason, they are distinguished by different namespace prefixes, such as ns1:, ns2:, or client:.The URIs provide a system for creating unique identifiers.