Dashboard Design and Deployment
------------------------------------------------
--------------------
-------------------------------------
---------------------------
-------------------------------------------------------
There are 4 ways to push data in Oracle BAM. Please note that we recommend that the DO should be updated via one common channel as this is the most efficient and optimized implementation for updating the DO. It is OK to update the DO from multiple projects as long as they are not writing to the same DO record concurrently. We strongly recommend against updating the same DO record via multiple sources (e.g. multiple EMS, or multiple BPEL projects etc.)
ii. BPEL 11g uses Oracle BAM Adapter to send data into Oracle BAM via the Oracle BAM sensor actions.
iii. This is not guaranteed messaging. All batches are stored in virtual memory. If there is a requirement for guaranteed messaging, please use JMS sensors in BPEL to send information to Oracle BAM via Enterprise Message Sources.
iv. Enable batching to keep the BPEL-Oracle BAM sensor action communication asynchronous. This also applies to the Oracle BAM Adapter use at the composite level. Oracle BAM 11g allows configuration of batch size, time-out, retry, etc.
v. Select the Monitor perspective in Oracle JDevelepor BPEL Designer (top right drop-down with BPEL as default) to create sensors /monitors to allow process monitoring.
2. Web services – Each data object is exposed as a Web service in Oracle BAM.
i. BPEL 10.1.3.x uses the Web services route for sending data into Oracle BAM using Oracle BAM sensor actions.
ii. This is not guaranteed messaging. All messages are stored in virtual memory. Enable batching in BPEL – Oracle BAM sensor communication to maintain asynchronous communication between the two applications.
iii. The Oracle BAM ICommand utility is available as a Web service.
3. JMS – Oracle BAM 11g has native JMS connectivity. It has the ability to listen to any JMS (1.1 or above) queue or topic. This also allows durable subscription. This is a recommended mode of communication for high volume messaging scenarios.
(5) Use Oracle BAM ICommand command line tool for exporting and importing Oracle BAM artifacts.
(6) Ensure that the Data Object field size is suitable to the payload size. Recommend field sizes less than 1000 characters, if possible
(7) If there are multiple BPEL processes /composite writing to Oracle BAM, it is a good practice to have all the various processes raise EDN events (or write to a JMS topic) and then have one single composite with BPEL process write to BAM.
Oracle BAM Data Control
------------------------------------
------------------------------------------------
- Ensure that a Dashboard is designed for a specific user group. Do not try to create an “all-purpose” dashboard.
- Allow the user to understand the health of the operations at a glance, and then provide drill hierarchies to perform root cause analysis.
- Limit a dashboard to 4-6 views per report. Because Oracle BAM is a push-based technology that streams updates to the dashboard, try to limit the number of views in the open report for optimum performance.
- Use Report prompts and parameters to filter data before report loading. This is especially useful when there is a large amount of information available that may not be relevant for the business user, e.g. a full month of data when all they want to see is last 2-5 days.
- Creating URLs with “Copy shortcuts” in Oracle BAM Active Studio can be used to save time in opening a dashboard.
- Make effective use of Action buttons and action forms to ensure the end user can take corrective action on the dashboard.
- Try to use summary /aggregate views such as bar charts, pie charts, collapsed lists. This way only the aggregates need to be maintained in the cache.
- List views can have a performance impact. Do not show too many lists on the report.
- Use lists with caution! Oracle BAM is used to providing a real-time status of the business. Listing hundreds/thousands of records in a list view will impact performance. If there is a lot of data for a list view, allow the user to provide filter criteria (using a prompt) for the list rather than display all records by default.
- Use the Oracle BAM Dashboard view to put together common reports that may be used by multiple user groups. For example, sales folks need two views while managers need the two common views plus a regional view. An Oracle BAM dashboard allows the user to bring in the common the two view report in both dashboards, while the manager dashboard will have an additional views.
- Oracle BAM Web applications cache lots of files on the browser, so it is recommended that the user does not clear the cache unless necessary.
- Oracle BAM Alerts are the convenient way to receive report snapshots as emails.
- Use recommended browser versions for better performance. (IE 7 and 8 for 11.1.1.2.0).
- Use BAM for operational monitoring where you want to take action in short term e.g. average time for processing over x amount of hrs or days/ faulted count of instances which could turn to xxx amount of orders that cannot be processed and need attention, orders in jeopardy since it hasn’t reached step 4 and only 2 days left from promised date.
--------------------
- Oracle BAM is used for real-time monitoring needs by business managers. The Oracle BAM ADC should not replace the customer’s data warehouse needs. Oracle BAM should keep only recent data in the schema. If required, the customer can archive the granular data and only keep aggregate data in Oracle BAM for a specific period of time.
- Oracle BAM supports star schema design. It supports one level of lookups, i.e. from one table to another. However, it does not support snowflake designs.
- It is recommended that Dimension and Fact tables (data objects) be separated. However, if your dimension table is growing at a fast pace, or at the same pace as the fact table, it is a good idea to not separate these two. For example, if Order table and Invoice table are growing at the same rate and have lookups from one to the other table it is better to keep this as a single table.
- It is better to handle calculated fields at data object level, rather than at the report level. For example, sales amount *1.2 could be an extra field in the data object rather than creating a calculated field in the report.
- Create indexes for key fields. For example if you are using BPEL sensors to do insert/upsert/update functions within a process, create the index on Oracle BAM schema on the keys. Create Keys with Integer format.
- BAM is a reporting tool -as with any other reporting tool, BAM should have its own DB instance
-------------------------------------
- Keep only the necessary data in your Data Object. Any data that is relevant for real-time operational monitoring and taking actions is a candidate for storing in the data object for the reporting.
- Do not keep older data for historical purposes in the same data object
- If you need the historical data available in Oracle BAM, try to either store aggregates in another Data object, or transfer the data to another data object that is only called upon for specific reporting.
- Oracle BAM has an alert configuration for purging data from the Data object. This can be scheduled for data older than a defined time period. It is recommended that the purge be scheduled at non-peak hours, e.g. nightly.
- If it is a requirement to archive the data prior to purging, then use ODI with Oracle BAM 11g, or Enterprise Link Plans in Oracle BAM 10g, to extract the data from the Data Object and store it in the data warehouse/table. Oracle BAM allows external data sources for reporting purposes without bringing in the data into Oracle BAM.
- ODI should have its own server . However, it should be co-located with the BAM server.
---------------------------
- Oracle BAM Server (ADC) is a singleton and available in Active /Passive Configuration. Oracle BAM Web can be deployed in Active-Active configuration. It is recommended that a sizing exercise is accomplished as part of the Oracle BAM design and system testing for a specific scenario.
- Oracle BAM deployment sizing guidelines are provided as a technical note on the Oracle BAM section of the Oracle Technology Network Web site.
- It is recommended that dedicated machines be used for Oracle BAM (separate Oracle BAM Server and database machines, and others based on install size) because Oracle BAM is a reporting tool. If the solution includes BPEL, use separate machines for BPEL and its storage to avoid contention.
- For high availability solutions, make sure that your servers are on the same subnet.
- Ensure that the application context is the same for Oracle BAM Web services if the Web services interface is used for pushing data in Oracle BAM.
-------------------------------------------------------
There are 4 ways to push data in Oracle BAM. Please note that we recommend that the DO should be updated via one common channel as this is the most efficient and optimized implementation for updating the DO. It is OK to update the DO from multiple projects as long as they are not writing to the same DO record concurrently. We strongly recommend against updating the same DO record via multiple sources (e.g. multiple EMS, or multiple BPEL projects etc.)
- Oracle BAM Adapter – JCA adapter available in 11g. This is also a first class citizen of SOA composite. This is the recommended approach for sending data to Oracle BAM for BPEL and other applications certified with this adapter.
ii. BPEL 11g uses Oracle BAM Adapter to send data into Oracle BAM via the Oracle BAM sensor actions.
iii. This is not guaranteed messaging. All batches are stored in virtual memory. If there is a requirement for guaranteed messaging, please use JMS sensors in BPEL to send information to Oracle BAM via Enterprise Message Sources.
iv. Enable batching to keep the BPEL-Oracle BAM sensor action communication asynchronous. This also applies to the Oracle BAM Adapter use at the composite level. Oracle BAM 11g allows configuration of batch size, time-out, retry, etc.
v. Select the Monitor perspective in Oracle JDevelepor BPEL Designer (top right drop-down with BPEL as default) to create sensors /monitors to allow process monitoring.
2. Web services – Each data object is exposed as a Web service in Oracle BAM.
i. BPEL 10.1.3.x uses the Web services route for sending data into Oracle BAM using Oracle BAM sensor actions.
ii. This is not guaranteed messaging. All messages are stored in virtual memory. Enable batching in BPEL – Oracle BAM sensor communication to maintain asynchronous communication between the two applications.
iii. The Oracle BAM ICommand utility is available as a Web service.
3. JMS – Oracle BAM 11g has native JMS connectivity. It has the ability to listen to any JMS (1.1 or above) queue or topic. This also allows durable subscription. This is a recommended mode of communication for high volume messaging scenarios.
- JMS supports XSLT transformations. Oracle BAM requires a flat schema where the XSLT can be used for nested messages. Please note the XSLT requires more resources for processing in high volume scenarios.
- Enable EMS message batching: This groups the messages in one single payload and saves on network round trips.
- As the JMS message is pulled from the JMS topic, if the record cannot be processed, it will not be written back to the same topic automatically. There are error configurations in EMS (post 11.1.1.3.0) that should be taken advantage of to capture records that are rejected by the EMS.
- Only 1 EMS should be used to write to 1 Data Object. This will sequence of updates as well as avoid any contention during the update of the same record via multiple sources.
- Recommend EMS to be configured with transactions disabled (11g)
- Do not recommend transformations on EMS especially in high volume scenarios. It is much better to transform the message in BPEL ( if that is being used) or the source system rather than overloading the reporting tool for transformation and then updating in real time.
- If you send null values for a column value into BAM, it will overwrite the existing value. If you want to preserve the value for a column ,then do not send a null – infact suppress the null value tags in the message.
(5) Use Oracle BAM ICommand command line tool for exporting and importing Oracle BAM artifacts.
(6) Ensure that the Data Object field size is suitable to the payload size. Recommend field sizes less than 1000 characters, if possible
(7) If there are multiple BPEL processes /composite writing to Oracle BAM, it is a good practice to have all the various processes raise EDN events (or write to a JMS topic) and then have one single composite with BPEL process write to BAM.
Oracle BAM Data Control
------------------------------------
- Oracle BAM data control instance sharing is not supported. When two or more ADF Faces components must display the same data, and are bound to the same Oracle BAM data control definition, make sure to wrap each ADF Faces component in an ADF task flow, and set the Data Control Scope to isolated. See the Oracle Fusion Middleware Web User Interface Developer's Guide for Oracle Application Development Framework <http://download.oracle.com/docs/cd/E15523_01/web.1111/b31973/toc.htm> for more information.

 
Hi Ranjit,
ReplyDeleteSaw your blog post just today while I was searching something related to Oracle BAM. Your blog is very informative and helpful. Keep up the good work.
Arun