24 Using XStream with a CDB
You can use Oracle Database XStream in a multitenant container database (CDB).
This chapter contains the following topics:
- About XStream
 XStream consists of Oracle Database components and application programming interfaces (APIs) that enable client applications to receive data changes from an Oracle database and send data changes to an Oracle database.
- System-Created Rules and a Multitenant Environment
 A multitenant environment enables an Oracle database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database. This self-contained collection is called a pluggable database (PDB). A CDB contains PDBs.
- XStream Out and a Multitenant Environment
 A multitenant environment enables a database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database.
- Configuring XStream Out in a CDB
 When you configure XStream Out in a CDB, you must decide which database changes will be captured by XStream Out and sent to the client application.
- XStream In and a Multitenant Environment
 A multitenant environment enables an Oracle database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database.
Parent topic: Using Oracle Features in a Multitenant Environment
About XStream
XStream consists of Oracle Database components and application programming interfaces (APIs) that enable client applications to receive data changes from an Oracle database and send data changes to an Oracle database.
These data changes can be shared between Oracle databases and other systems. The other systems include non-Oracle databases, non-RDBMS Oracle products, file systems, third party software applications, and so on. A client application is designed by the user for specific purposes and use cases.
XStream consists of two major features: XStream Out and XStream In. XStream Out provides Oracle Database components and APIs that enable you to share data changes made to an Oracle database with other systems. XStream Out can retrieve both data manipulation language (DML) and data definition language (DDL) changes from the redo log and send these changes to a client application that uses the APIs, as shown in the following figure.
XStream In provides Oracle Database components and APIs that enable you to share data changes made to other systems with an Oracle database. XStream In can apply these changes to database objects in the Oracle database, as shown in the following figure.
XStream uses the capture and apply features of the Oracle database. These features enable the following functionality for XStream:
- 
                        The logical change record (LCR) format for streaming database changes An LCR is a message with a specific format that describes a database change. If the change was a data manipulation language (DML) operation, then a row LCR encapsulates each row change resulting from the DML operation. One DML operation might result in multiple row changes, and so one DML operation might result in multiple row LCRs. If the change was a data definition language (DDL) operation, then a single DDL LCR encapsulates the DDL change. 
- 
                        Rules and rule sets that control behavior, including inclusion and exclusion rules Rules enable the filtering of database changes at the database level, schema level, table level, and row/column level. 
- 
                        Rule-based transformations that modify captured data changes 
- 
                        Support for most data types in the database, including LOBs, LONG,LONGRAW, andXMLType
- 
                        Customized configurations, including multiple inbound streams to a single database instance, multiple outbound streams from a single database instance, multiple outbound streams from a single capture process, and so on 
- 
                        Full-featured apply for XStream In, including apply parallelism for optimal performance, SQL generation, conflict detection and resolution, error handling, and customized apply with apply handlers 
Note:
In both XStream Out and XStream In configurations, the client application must use a dedicated server connection.
Related Topics
Parent topic: Using XStream with a CDB
System-Created Rules and a Multitenant Environment
A multitenant environment enables an Oracle database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database. This self-contained collection is called a pluggable database (PDB). A CDB contains PDBs.
It can also contain application containers. An application container is an optional component of a CDB that consists of an application root and the application PDBs associated with it. An application container stores data for one or more applications. An application container shares application metadata and common data. In a CDB, each of the following is a container: the CDB root, each PDB, each application root, and each application PDB.
In a CDB, LCRs can contain the global name of the container where the change originated in the source_database_name attribute and the global name of the CDB root in the root_name attribute. The rules for XStream components can consider these attributes.
                  
This section contains the following topics:
- System-Created Rules in a CDB and XStream Out
 In a CDB, XStream Out must be configured in the CDB root. Therefore, the PL/SQL procedures in theDBMS_XSTREAM_ADMpackage that create system-created rules must be run in the CDB root while connected as a common user.
- System-Created Rules in a CDB and XStream In
 You can configure XStream In in the root or in any container in a CDB.
Related Topics
Parent topic: Using XStream with a CDB
System-Created Rules in a CDB and XStream Out
In a CDB, XStream Out must be configured in the CDB root. Therefore, the PL/SQL procedures in the DBMS_XSTREAM_ADM package that create system-created rules must be run in the CDB root while connected as a common user.
                     
Excluding the procedures that create rules for propagations, the procedures that create system-created rules for XStream Out, such as the ADD_GLOBAL_RULES procedure, include the key parameters in the following table:
                     
Table 24-1 Key Procedure Parameters for System-Created Rules in a CDB
| Parameter | Description | 
|---|---|
| 
 | The global name of the source database. In a CDB, specify the global name of the container to which the rules pertain. The container can be the CDB root, a PDB, an application root, or an application PDB. The following are examples:  | 
| 
 | The global name of the CDB root in the source CDB. The following are examples:  | 
| 
 | The short name of the source container. The container can be the CDB root, a PDB, an application root, or an application PDB. The following are examples:  | 
If you do not include the domain name when you specify source_database or source_root_name, then the procedure appends it to the name automatically. For example, if you specify DBS1 and the domain is .EXAMPLE.COM, then the procedure specifies DBS1.EXAMPLE.COM automatically.
                     
The combination of these key parameters determines which containers' changes XStream Out captures and streams to the client application, based on the rules generated by the procedures. Regardless of the settings for these parameters, system-generated rules can still limit the changes captured and streamed to specific schemas and tables.
Local capture means that a capture process runs on the source CDB. In a local capture configuration, the source_root_name parameter specifies the global name of the CDB root in the local CDB. If this parameter is NULL, then the global name of the CDB root in the local CDB is specified automatically. The resulting rules include a condition for the global name of the CDB root in the current CDB.
                     
Downstream capture means that a capture process runs on a CDB other than the source CDB. In a downstream capture configuration, the source_root_name parameter must be non-NULL, and it must specify the global name of the CDB root in the remote source CDB. The resulting rules include a condition for the global name of the CDB root in the remote CDB. If this parameter is NULL, then local capture is assumed. 
                     
The following table describes the rule conditions for various source_database and source_container_name parameter settings in a local capture configuration.
                     
Table 24-2 Local Capture and XStream Out Container Rule Conditions
| source_database Parameter Setting | source_container_name Parameter Setting | Description | 
|---|---|---|
| 
 | 
 | XStream Out captures and streams changes made in any container in the local CDB, including the CDB root, all PDBs, all application roots, and all application PDBs. | 
| non- | 
 | XStream Out captures and streams changes made in the specified source container of the local CDB. The source container can be the CDB root, a PDB, an application root, or an application PDB. The  | 
| 
 | non- | XStream Out captures and streams changes made in the specified source container of the local CDB. The source container can be the CDB root, a PDB, an application root, or an application PDB. The  | 
| non- | non- | XStream Out captures and streams changes made in the specified source container of the local CDB. The source container can be the CDB root, a PDB, an application root, or an application PDB. If the prefix of the  | 
The following table describes the rule conditions for various source_database and source_container_name parameter settings in a downstream capture configuration.
                     
Table 24-3 Downstream Capture and XStream Out Container Rule Conditions
| source_database Parameter Setting | source_container_name Parameter Setting | Description | 
|---|---|---|
| 
 | 
 | XStream Out captures and streams changes made in any container in the remote source CDB, including the CDB root, all PDBs, all application roots, and all application PDBs. | 
| non- | 
 | XStream Out captures and streams changes made in the specified source container of the remote source CDB. The source container can be the CDB root, a PDB, an application root, or an application PDB. The  | 
| 
 | non- | The  | 
| non- | non- | XStream Out captures and streams changes made in the specified source container of the remote source CDB. The source container can be the CDB root, a PDB, an application root, or an application PDB. If the prefix of the  | 
System-Created Rules in a CDB and XStream In
You can configure XStream In in the root or in any container in a CDB.
Typically, an inbound server does not use rule sets or rules. Instead, it usually processes all LCRs that it receives from its client application. An inbound server can apply changes to the current container only. Therefore, if an inbound server is configured in the CDB root, then it can apply changes only to the CDB root. If an inbound server is configured in a PDB, then it can apply changes only to that PDB. If an inbound server is configured in an application root, then it can apply changes only to that application root, and if an inbound server is configured in an application PDB, then it can apply changes only to that application PDB.
Related Topics
Parent topic: System-Created Rules and a Multitenant Environment
XStream Out and a Multitenant Environment
A multitenant environment enables a database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database.
This self-contained collection is called a pluggable database (PDB). A multitenant container database (CDB) contains PDBs. In a CDB, XStream Out functions much the same as it does in a non-CDB.
A CDB can also contain application containers. An application container is an optional component of a CDB that consists of an application root and all application PDBs associated with it. An application container stores data for one or more applications. An application container shares application metadata and common data. In a CDB, each of the following is a container: the CDB root, each PDB, each application root, and each application PDB.
The main differences in the way XStream Out functions in a CDB and non-CDB are:
- 
                        XStream Out must be configured only in the CDB root. 
- 
                        XStream Out can see changes made to any container within the CDB. 
- 
                        XStream Out capture rules can limit the LCRs to those that are needed for the client application. The system-generated capture rules select the appropriate LCRs based on the parameters that were passed to the ADD_OUTBOUNDandCREATE_OUTBOUNDprocedures in theDBMS_XSTREAM_ADMpackage. You can use theADD_*_RULESprocedures in the same package for more fine-grained control over the rules used by the XStream Out components.
- 
                        The user who performs XStream Out tasks must be a common user. 
Unplug and Plug Operations in an XStream Environment
When a PDB, application root, or application PDB involved with XStream Out is unplugged from its CDB and plugged into another CDB, any capture process or outbound server is not considered part of the container. You must configure the capture process and outbound server again in the other CDB.
If an outbound server is configured in a different database than the capture process, then unplug and plug operations have additional considerations.
For this example, assume the following:
- 
                           A CDB named CDB1contains PDBPDB1.
- 
                           A capture process is configured in CDB1, and it sends LCRs fromPDB1to an outbound server in a CDB namedCDB2.
- 
                           You unplug PDB1fromCDB1, and then plug it into a CDB namedCDB3.
To continue delivering LCRs from PDB1 to the outbound server in CDB2, you must configure a new capture process in CDB3 to capture and send LCRs to CDB2.
                     
The rules used by the outbound server in database B must be altered to change references to the root of CDB1 to the root of CDB3. In addition, if PDB1 was given a different name in CDB3, then the rules must be altered to reflect the new PDB name.
                     
Application Containers in an XStream Environment
When a CDB has one or more application containers, XStream Out must be configured in the CDB root, and XStream Out can capture changes made in any container in the CDB, including the application roots and application PDBs. Changes captured in an application container can be sent to containers of any type, including PDBs, application roots, and application PDBs.
When replicating changes from one application root to another application root, XStream can replicate ALTER PLUGGABLE DATABASE APPLICATION statements. To avoid errors, the target application root that applies the statements must have the same application installed as the source application root, and the application name must be identical in both application roots.
                     
To avoid errors when replicating changes from an application root to a container that is not an application root, you must ensure that ALTER PLUGGABLE DATABASE APPLICATION statements are not replicated.
                     
With the XStream OCI API, you can control whether ALTER PLUGGABLE DATABASE APPLICATION statements are replicated using the OCIXStreamOutAttach function and the OCILCRHeaderGet function. With the XStream Java API, you can control this behavior using the mode parameter in the XStreamOut.attach method.
                     
Configuring XStream Out in a CDB
When you configure XStream Out in a CDB, you must decide which database changes will be captured by XStream Out and sent to the client application.
XStream Out can stream all database changes for all containers, including the CDB root and all PDBs, application roots, and application PDBs, or XStream Out can stream the changes from specific containers. In addition, you can configure XStream Out with local capture, or you can configure it with downstream capture to offload the work required to capture changes from the source database.
The following restrictions apply when you configure XStream Out in a CDB:
- 
                        The capture process and outbound server must be in the CDB root. 
- 
                        The capture process and outbound server must be in the same CDB. 
- 
                        Each container in the CDB must be open during XStream Out configuration. 
- 
                        When changes made to an application root are captured, you must ensure that ALTER PLUGGABLE DATABASE APPLICATIONstatements are replicated only to other application roots.
In addition, ensure that you create the XStream administrator properly for a CDB.
Note:
When a container is created using a non-CDB, any XStream Out components from the non-CDB cannot be used in the container. You must drop and re-create the XStream Out components, including the capture process and outbound servers, in the CDB root.
This section contains the following topics:
- Configuring XStream Out with Local Capture in a CDB
 An example illustrates configuring XStream Out with local capture in a CDB.
- Configuring XStream Out with Downstream Capture in CDBs
 Using downstream capture, the XStream Out components can reside in databases other than the source database.
Related Topics
Parent topic: Using XStream with a CDB
Configuring XStream Out with Local Capture in a CDB
An example illustrates configuring XStream Out with local capture in a CDB.
Prerequisites
Before configuring XStream Out, ensure that all containers in the CDB are in open read/write mode during XStream Out configuration.
Assumptions
This section makes the following assumptions:
- 
                              The capture process will be a local capture process, and it will run on the same database as the outbound server. 
- 
                              The name of the outbound server is xout.
- 
                              Data manipulation language (DML) and data definition language (DDL) changes made to the oe.ordersandoe.order_itemstables in PDBpdb1.example.comare sent to the outbound server.
- 
                              DML and DDL changes made to the hrschema in the PDBpdb1.example.comare sent to the outbound server.
Figure 24-3 provides an overview of this XStream Out configuration.
Figure 24-3 Sample XStream Out Configuration Created Using CREATE_OUTBOUND for a PDB

Description of "Figure 24-3 Sample XStream Out Configuration Created Using CREATE_OUTBOUND for a PDB"
To create an outbound server using the CREATE_OUTBOUND procedure:
                        
- 
                              In SQL*Plus, connect to the root in the CDB (not to the PDB pdb1.example.com) as the XStream administrator.
- 
                              Create the outbound server and other XStream components. - 
                                    Ensure that all containers in the source CDB are in open read/write mode. 
- 
                                    Run the CREATE_OUTBOUNDprocedure.Given the assumptions for this example, run the following CREATE_OUTBOUNDprocedure:DECLARE tables DBMS_UTILITY.UNCL_ARRAY; schemas DBMS_UTILITY.UNCL_ARRAY; BEGIN tables(1) := 'oe.orders'; tables(2) := 'oe.order_items'; schemas(1) := 'hr'; DBMS_XSTREAM_ADM.CREATE_OUTBOUND( server_name => 'xout', source_database => 'pdb1.example.com', table_names => tables, schema_names => schemas); END; /Note: To capture changes in all containers in a CDB, including the CDB root, all PDBs, all application roots, and all application PDBs, and send those changes to the XStream client application, you can omit the source_databaseparameter when you run theCREATE_OUTBOUNDprocedure.
- 
                                    After the CREATE_OUTBOUNDprocedure completes successfully, optionally change the open mode of one or more containers if necessary.
 Running the procedure in Step b performs the following actions: - 
                                    Configures supplemental logging for the oe.ordersandoe.order_itemstables and for all tables in thehrschema in thepdb1.example.comPDB.
- 
                                    Creates a queue with a system-generated name that is used by the capture process and the outbound server. 
- 
                                    Creates and starts a capture process with a system-generated name with rule sets that instruct it to capture DML and DDL changes to the oe.orderstable, theoe.order_itemstable, and thehrschema from thepdb1.example.comPDB.
- 
                                    Creates and starts an outbound server named xoutwith rule sets that instruct it to send DML and DDL changes to theoe.orderstable, theoe.order_itemstable, and thehrschema to the client application.
- 
                                    Sets the current user as the connect user for the outbound server. In this example, the current user is the XStream administrator. The client application must connect to the database as the connect user to interact with the outbound server. 
 Note: The server_namevalue cannot exceed 30 bytes.Tip: To capture and send all database changes from the pdb1.example.comdatabase to the outbound server, specifyNULL(the default) for thetable_namesandschema_namesparameters.
- 
                                    
- 
                              Create and run the client application that will connect to the outbound server in the root of the CDB and receive the LCRs. When you run the client application, the outbound server is started automatically. 
Related Topics
Parent topic: Configuring XStream Out in a CDB
Configuring XStream Out with Downstream Capture in CDBs
Using downstream capture, the XStream Out components can reside in databases other than the source database.
Prerequisites
Before configuring XStream Out, the following prerequisites must be met:
- 
                              Ensure that all containers in the CDB are in open read/write mode during XStream Out configuration. 
- 
                              This example uses downstream capture. Therefore, you must configure log file transfer from the source database to a downstream database. 
- 
                              If you want to use real-time downstream capture, then you must also add the required standby redo logs. 
Assumptions
This section makes the following assumptions:
- 
                              The name of the outbound server is xout.
- 
                              The queue used by the outbound server is c##xstrmadmin.xstream_queue.
- 
                              The source database is the PDB pdb1.example.comin the CDBdata.example.com.
- 
                              The capture process runs in the CDB capture.example.com.
- 
                              The outbound server runs in the CDB capture.example.com.
- 
                              DML and DDL changes made to the oe.ordersandoe.order_itemstables from the PDBpdb1.example.comare sent to the outbound server.
- 
                              DML and DDL changes made to the hrschema from the PDBpdb1.example.comare sent to the outbound server.
The following figure gives an overview of this XStream Out configuration.
Figure 24-4 Sample XStream Out Configuration Using Multiple CDBs and Downstream Capture

Description of "Figure 24-4 Sample XStream Out Configuration Using Multiple CDBs and Downstream Capture "
To configure XStream Out with downstream capture in CDBs:
- 
                              In SQL*Plus, connect to the root of the downstream capture CDB as the XStream administrator. In this example. the downstream capture CDB is capture.example.com.
- 
                              Create the queue that will be used by the capture process. For example, run the following procedure: BEGIN DBMS_XSTREAM_ADM.SET_UP_QUEUE( queue_table => 'c##xstrmadmin.xstream_queue_table', queue_name => 'c##xstrmadmin.xstream_queue'); END; /
- 
                              Optionally, create the database link from the root in the downstream capture CDB to the root in the source CDB. In this example, create a database link from the root in capture.example.comto the root indata.example.com. For example, if the userc##xstrmadminis the XStream administrator on both databases, then create the following database link:CREATE DATABASE LINK data.example.com CONNECT TO c##xstrmadmin IDENTIFIED BY password USING 'data.example.com';
- 
                              Ensure that all containers in the source CDB are in open read/write mode. 
- 
                              If you did not create the database link in Step 3, then you must complete additional steps in the root of the source CDB. These steps are not required if you created the database link in Step 3. Run the BUILDprocedure and ensure that required supplemental logging is specified for the database objects in the source CDB:- 
                                    Connect to the root in the source CDB as the XStream administrator. 
- 
                                    Run the DBMS_CAPTURE_ADM.BUILDprocedure. For example:SET SERVEROUTPUT ON DECLARE scn NUMBER; BEGIN DBMS_CAPTURE_ADM.BUILD( first_scn => scn); DBMS_OUTPUT.PUT_LINE('First SCN Value = ' || scn); END; / First SCN Value = 409391This procedure displays the valid first SCN value for the capture process that will be created in the root in the capture.example.comCDB. Make a note of the SCN value returned because you will use it when you create the capture process in Step 6.
- 
                                    Ensure that required supplemental logging is specified for the database objects in the source CDB. For this example, ensure that supplemental logging is configured for the hrschema, theoe.orderstable, and theoe.order_itemstable in thepdb1.example.comPDB.
 
- 
                                    
- 
                              While connected to the root in the downstream capture CDB, create the capture process. For example, run the following procedure to create the capture process while connected as the XStream administrator to capture.example.com:BEGIN DBMS_CAPTURE_ADM.CREATE_CAPTURE( queue_name => 'c##xstrmadmin.xstream_queue', capture_name => 'real_time_capture', rule_set_name => NULL, start_scn => NULL, source_database => NULL, use_database_link => TRUE, first_scn => NULL, logfile_assignment => 'implicit', source_root_name => 'data.example.com', capture_class => 'xstream'); END; /If you did not create a database link in Step 3, then specify the SCN value returned by the DBMS_CAPTURE_ADM.BUILDprocedure for thefirst_scnparameter.Do not start the capture process. 
- 
                              After the capture process is created, optionally change the open mode of one or more PDBs if necessary. 
- 
                              Run the ADD_OUTBOUNDprocedure.Given the assumption for this section, run the following ADD_OUTBOUNDprocedure:DECLARE tables DBMS_UTILITY.UNCL_ARRAY; schemas DBMS_UTILITY.UNCL_ARRAY; BEGIN tables(1) := 'oe.orders'; tables(2) := 'oe.order_items'; schemas(1) := 'hr'; DBMS_XSTREAM_ADM.ADD_OUTBOUND( server_name => 'xout', queue_name => 'c##xstrmadmin.xstream_queue', source_database => 'pdb1.example.com', table_names => tables, schema_names => schemas, source_root_name => 'data.example.com', source_container_name => 'pdb1'); END; /Running this procedure performs the following actions: - 
                                    Creates an outbound server named xout. The outbound server has rule sets that instruct it to send DML and DDL changes to theoe.orderstable, theoe.order_itemstable, and thehrschema to the client application. The rules specify that these changes must have originated at the PDBpdb1.example.comin the CDBdata.example.com. The outbound server dequeues LCRs from the queuec##xstrmadmin.xstream_queue.
- 
                                    Sets the current user as the connect_userfor the outbound server. In this example, thecurrent_useris the XStream administrator. The client application must connect to the database as theconnect_userto interact with the outbound server.
 Note: The server_namevalue cannot exceed 30 bytes.
- 
                                    
- 
                              Create and run the client application that will connect to the outbound server and receive the LCRs. When you run the client application, the outbound server is started automatically at the downstream capture CDB. 
Related Topics
Parent topic: Configuring XStream Out in a CDB
XStream In and a Multitenant Environment
A multitenant environment enables an Oracle database to contain a portable set of schemas, objects, and related structures that appears logically to an application as a separate database.
This self-contained collection is called a pluggable database (PDB). A multitenant container database (CDB) contains PDBs. It can also contain application containers. An application container is an optional component of a CDB that consists of an application root and all application PDBs associated with it. An application container stores data for one or more applications. An application container shares application metadata and common data. In a CDB, each of the following is a container: the CDB root, each PDB, each application root, and each application PDB.
In a CDB, the inbound server is restricted to receiving LCRs from one source database and only executing changes in the current container (one PDB, one application root, one application PDB, or the CDB root). A single inbound server cannot apply changes to more than one container in a CDB.
When the inbound server is in the CDB root, the apply user must be a common user. When the inbound server is in an application root, the apply user must be a common user or an application common user. When the inbound server is in a PDB or application PDB, the apply user can be a common user or a local user.
Note:
XStream does not synchronize changes done in the application root container. Do not use the XStream In replication to replicate operations done in the application root container. You can manually apply these changes in the application root containers in the target. Note that the operations done in the PDBs can still be replicated.
Parent topic: Using XStream with a CDB

