Database Changelog (triggers) connector
When a database object is configured as a publisher, triggers are installed on the object and document all changes to a log table. This object name has the syntax {TABLE_NAME}_LOG
. In the log table, two predefined column names are required: RLICHANGEID
and RLICHANGETYPE
. RLICHANGEID
uniquely identifies one row in the change log table, and RLICHANGETYPE
identifies the operation (insert, update, delete, abort). The database connector queries the log table to check for changes based on the polling interval.
The RLI_CON
user (configurable) is the default owner of the log table. This special user can also prevent a constant loop of changes when the database objects have been configured as both a publisher and subscriber. When this user makes changes to the database objects, the connector knows to ignore the change.
Database connector failover
Database connectors can leverage a failover backend that has been configured for the data source. When you configure a data source for your backend database, indicate a failover server. An example is shown below.
For SQL Server backends, indicating the failover server in the data source is not required. You only need to indicate the primary server in the data source and the connector can automatically detect the failover/mirrored server.
If a connection cannot be made to the primary server, and max retries is exhausted, the connector connects to the failover server.
The backend servers must be configured for replication/mirroring. Please check the vendor documentation for assistance with configuring replication for your backends.
For SQL Server backends, make sure the database connector user exists on the mirrored server. User logins created on a database server are at the instance level and are not automatically propagated to mirrored instances (because mirroring works at the database level).
The method to fix the problem of the database connector user not existing on the mirrored server is to create a login in the mirrored server using the same SID of the user which already exists in the principal server.
To find the user's sid, use the query below on the principal server:
Select sid from dbo.sysusers where name='rli_con';
To create the login on the mirrored server, use the query below (with the sid retrieved from the principal server):
Create login rli_con with password ='password'
sid=0xC82A450E586CCC4CADDD802E9D9CA404;
In the case where the principal/primary SQL Server is not available, the connector fails over to the mirrored server. Once the principal server is back online, the connector continues to read from the mirror (it essentially becomes the new principal server) until the mirror is not available, in which case it reverts to the original primary server.
Configuration
To detect changes using Changelog (triggers), set the connector type in the pipeline configuration by choosing the Capture component. In the Core Properties section, select DB Changelog from the drop-down list.
After the DB Changelog connector type has been selected and configured, you can configure the properties in the Core Properties, Advanced Properties, and Event Content sections at the bottom. For properties common to all connectors, see Configure capture connector types and properties.
Log Table User
Enter the user name for the connector's dedicated credentials for connecting to the log table. If you do not have the user name, contact your DBA to get the information to use.
Log Table User password
The password for the user configured in the Log Table User property. If you do not have the password, contact your DBA to get the credentials.
Table name
The name of the database table where changes to database entries are logged. You can use an existing table by entering the name in this property. Or enter the name of the table to create using the RadiantOne configuration scripts. Be sure to use the proper syntax for your database vendor (e.g. {USER}.{TABLE}_LOG
).
Apply configuration to database
When you save the connector type configuration, you are prompted to execute the scripts on the database server. An example is shown below.
Select OK to execute the DB Changelog scripts, SELECT
, INSERT
, UPDATE
, and DELETE
access are granted for PUBLIC to the LOG table. Check with your database administrator if you need to restrict access rights on the log table. You can select the NO option and the generated script can be reviewed, modified if needed, and run on the database by a DBA. The location of the generated scripts is: {RLI_HOME}/work/sql/{PIPELINE_ID}
SQL Filter
SQL Filter is used as part of the request for entries captured by the timestamp connector. Only changes that match the filter are published by the connector.
A SQL filter is either a single expression or several single expressions joined by binary operators and brackets ( ). Possible binary operators are:
AND
OR
NOT
Some examples of valid SQL Filters are:
ID='5'
ID='5' AND NAME='ALLEN'
ID='5' AND NAME='ALLEN' OR CITY='SAN FRANCISCO'
ID='5' AND (NAME='ALLEN' OR CITY='SAN FRANCISCO')
NAME LIKE 'AL%'
NAME LIKE 'ALLE_'
If the SQL Filter syntax entered in the property is not correct, an error occurs. The connector waits for the length of time specified in the Retry Interval on Error and then tries to get the changed entries in the database again. After the maximum number of retries (indicated in the Max Retries on Error property) is exhausted, if the SQL syntax is still invalid, the connector stops. You must either remove or correct the SQL filter before restarting the connector. It is recommended that you set the connector Log Level to DEBUG
and check the connector log for the SQL query (Executing query:) that is generated to ensure the value entered in the SQL Filter property is translated properly. The capture connector log is located at {RLI_HOME}\logs\sync_agents\{PIPELINE_ID}\connector.log
on the RadiantOne node where the sync agent is running. Run {RLI_HOME}/bin/monitoring.bat
(.sh
on Linux) -d pipeline
to locate your sync process and the value of the captureHostname
propertyId value indicates the machine where the connector.log is located.
If the connector should process all changed entries, do not enter a SQL filter.
Force Sequential Counters
This property accepts a value of true
or false
and dictates how the connector treats entries it picks up from the LOG table that have non-sequential change IDs. The default is true
meaning that if the connector detects a non-sequential change ID for an entry in the LOG table, it behaves as if there is an error (non-connection error) and the retry logic based on the Max Retries on Error and Retry Interval on Error properties takes effect. Sometimes rows in the log table are not written in the order of the change ID, and if the connector does not wait for the entries to have sequential IDs, some changes could be missed. The connector waits for the length of time specified in the Retry Interval on Error and then tries to get the changed entries in the database again. After the maximum number of retries (indicated in the Max Retries on Error property) is exhausted, if it still detects non-sequential change IDs, the connector stops. You can manually edit the cursor value before restarting the connector to avoid the non-sequential number. Or you can disable the Force Sequential Counters
property for the connector.
If the connector should ignore non-sequential change IDs, and process all changes immediately, set the property to false
.
To learn more about connectors, please read the document that describes properties specific to the Database timestamp connector.