SOA 11g AQ Adapters
Details AQ at Oracle.com
Database aq table and queue creation |
CONNECT sys/change_on_install as sysdba DROP USER aq_user CASCADE; CREATE USER aq_user IDENTIFIED BY aq_user DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp; ALTER USER aq_user QUOTA UNLIMITED ON users; GRANT aq_administrator_role TO aq_user; GRANT connect TO aq_user; GRANT create type TO aq_user; GRANT create sequence TO aq_user; EXECUTE dbms_aqadm.grant_type_access('aq_user'); -- Login as AQ_User CONNECT aq_user/aq_user CREATE TYPE message_type AS OBJECT ( message_id NUMBER(15) , subject VARCHAR2(100) , text VARCHAR2(100) , dollar_value NUMBER(4,2) ) / BEGIN -- ---------------------------------------------------- DBMS_AQADM.CREATE_QUEUE_TABLE ( queue_table => 'aq_user.msg_qt' , queue_payload_type => 'aq_user.message_type' ); -- ---------------------------------------------------- DBMS_AQADM.CREATE_QUEUE ( queue_name => 'msg_queue' , queue_table => 'aq_user.msg_qt' , queue_type => DBMS_AQADM.NORMAL_QUEUE , max_retries => 0 , retry_delay => 0 , retention_time => 1209600 , dependency_tracking => FALSE , comment => 'Test Object Type Queue' , auto_commit => FALSE ); -- ---------------------------------------------------- DBMS_AQADM.START_QUEUE('msg_queue'); -- ---------------------------------------------------- END; / --To Stop and Drop the Queue CONNECT aq_user/aq_user EXECUTE dbms_aqadm.stop_queue(queue_name => 'aq_user.msg_queue'); EXECUTE dbms_aqadm.drop_queue(queue_name => 'aq_user.msg_queue'); EXECUTE dbms_aqadm.drop_queue_table(queue_table => 'aq_user.msg_qt'); DROP TYPE aq_user.message_type;
Weblogic configuring aq adapter |
data:image/s3,"s3://crabby-images/3e694/3e694bcd9adc1e94116b49c1ce1d732d761ebfd6" alt="110"
Create JDBC Datasource localhost-aq whose JNDI name is jndi/localhost-aq
data:image/s3,"s3://crabby-images/6031a/6031ae60e49138271c72e3a6a9590cad1e9dcbc9" alt="110"
Under Deployments select AQAdapter , Configurations Tab and Outbound Connection , Create a new Outbound Connection eis/aq/localhost-aq whose XADataSourceName is jndi/localhost-aq
data:image/s3,"s3://crabby-images/2a356/2a3566585b140cf4cdeb9aa2bd6bcfd970409686" alt="110"
Below are Datasource details to aq_user user in database
data:image/s3,"s3://crabby-images/40f57/40f57e3f425cd4f394adc06855d6cbe02ef7511f" alt="110"
This will be deployed on Admin Server , as my SOA installation is running on Admin server
data:image/s3,"s3://crabby-images/e8830/e883063e8f2ef7ce003ad162360948490be4565d" alt="110"
Save
data:image/s3,"s3://crabby-images/a9731/a97311413c855593706c2225104015276bfc6d19" alt="110"
Update the AQAdapter Deployment , Update the plan , no restart needed.
SOA 11g BPEL process using enqueue |
data:image/s3,"s3://crabby-images/01b64/01b640640ba8c4959646729de79c6b8c81048f82" alt="110"
Edit the BPEL Process use Invoke activity to connect to AQ Adapter
data:image/s3,"s3://crabby-images/ab6c4/ab6c4a33d711c00b9e3398c4a1531ae87db2bf79" alt="110"
This is how the BPEL would look like
data:image/s3,"s3://crabby-images/86d7f/86d7fd132ab3a3365311344cca3305e822b1e8d2" alt="110"
Add assign before invoke to wire input variables to AQ input variables.
data:image/s3,"s3://crabby-images/cfe0e/cfe0e6264b5bffb4917c1187c4ab6a9547c9bdc5" alt="110"
These are Details of AQ Adapter
data:image/s3,"s3://crabby-images/fd53b/fd53b79ce2e1fa03bbef5dd8b1484d87ff38999f" alt="110"
Create a DB Connection by name localhost-aq
data:image/s3,"s3://crabby-images/630e7/630e72dd3e84a269e81a2370978dd1e62e530358" alt="110"
Note JNDI name should match to the one that we configured in the Weblogic Console
data:image/s3,"s3://crabby-images/0a979/0a979d6cdb3e903a4f36ef9ee4a3c8b34706cbec" alt="110"
Select Enqueue operation
data:image/s3,"s3://crabby-images/ebde6/ebde6039e331ee51aa44b5b3b0125b5f66328f59" alt="110"
Select the DB Schema as AQ_USER , click on Browse button and select MSG_QUEUE as Queue Name
data:image/s3,"s3://crabby-images/504d9/504d9a1065647b631dbb6bcd1c6f86dc009fe04f" alt="110"
Leave Correlation Id as blank
data:image/s3,"s3://crabby-images/a0eb0/a0eb007ca0f1425aa0b46302eeda81c229fda5b6" alt="110"
Select Object Payload as Whole MESSAGE_TYPE
data:image/s3,"s3://crabby-images/5bdd5/5bdd53a7217e6c429b72e1e06683c2c6ca00cce3" alt="110"
Save, Deploy and Test , You can see the Data being Written to Queue Table under AQ_USER.
SOA 11g bpel process using dequeue |
data:image/s3,"s3://crabby-images/11353/1135304cfcfbb7889da74285d41493c1cb26d956" alt="110"
The BPEL process is Mediator Driven one that has Dequeue inserted into Exposed Services side of composite.
data:image/s3,"s3://crabby-images/d4bb8/d4bb8b9de27ab559a27e397155bb0b72f5fe00d0" alt="110"
Details of Dequeue configuration , Connect to DB
data:image/s3,"s3://crabby-images/6794a/6794a56d1e3ddd76d30ec41ee3237118b7d4f2b6" alt="110"
Select Dequeue operation
data:image/s3,"s3://crabby-images/cf262/cf262358d53443614d66ac0a9df280fdfd1debb9" alt="110"
Select AQ_USER as schema and MSG_QUEUE as Queue name using Browse Operation
data:image/s3,"s3://crabby-images/a2d1c/a2d1cd434d166d86feb2eec881cacfb89c7b5ae5" alt="110"
Select MESSAGE_TYPE
data:image/s3,"s3://crabby-images/f48db/f48dbb59bee1178f5c3ad2c0bb75898f1f7a3f28" alt="110"
Edit the Mediator that connects the Dequeue and File Adapter, create new tranformation
data:image/s3,"s3://crabby-images/8e204/8e204b457c88357085a95dd7c7a0c36c0e449bb8" alt="110"
Assign variables in the XML transformation
data:image/s3,"s3://crabby-images/0ff70/0ff700629ede32e518d16c3d79881b6b610da1e4" alt="110"
Save, Deploy the Process and Test , the new message should be written into File system under /tmp folder with the filename given during Adapter configuration
TESTING PROCESS END TO END |
data:image/s3,"s3://crabby-images/a1848/a1848f5abd7957f0f56aa0bc45d039ba086b5028" alt="110"
Once the process is executed data is written into MSQ_QUEUE table under USER_DATA column
data:image/s3,"s3://crabby-images/4d334/4d3343a7bbb5444b5f4d1793e222750f6678d296" alt="110"
The 2nd BPEL Process Dequeues this message and through Mediator and File adapter writes into a File under /tmp folder
data:image/s3,"s3://crabby-images/2c305/2c305418b729ee7aa5244ae2c8478b6d4e7e6ecb" alt="110"
Gr8 post sir !!!!.....
ReplyDeletecould you please provide,the screen shots for Database aq table and queue creation .
Thanks and Regards