A stored procedure in the primary database that works with replicate database stored procedure rs_ticket_report to measure the amount of time it takes for a command to move from the primary database to the replicate database. You can use this information to monitor Replication Server performance, module heartbeat, replication health and table-level quiesce.
rs_ticket h1 [, h2 [, h3 [, h4]]]
Short varchar strings. Header information.
Executes rs_ticket at regular intervals:
Exec rs_ticket 'heartbeat'
To measure performance, execute the following from the primary database:
Exec rs_ticket 'start' Execute replication benchmarks Exec rs_ticket 'stop'
The rs_ticket stored procedure executes the following command:
rs_marker 'rs_ticket rs_ticket_param'
To avoid issuing wrongly formatted rs_marker and to enforce the rs_ticket_param standard, you should invoke rs_ticket instead of rs_marker. If you call rs_marker directly and form an incorrect rs_marker subcommand, the Replication Server refuses the rs_marker and shuts down the RepAgent connection. In this case, you must skip rs_marker from the transaction log, which may cause data loss.
The Replication Server EXEC, DIST, and DSI modules parse and process rs_ticket subcommand:
When EXEC processes rs_ticket, it appends a timestamp, and then the total bytes received from RepAgent after rs_ticket_param. An EXEC timestamp takes the form ''EXEC(spid)=hh:mm:ss.ddd''. The byte information is ''B(spid)=ddd''. EXEC writes rs_ticket back to inbound queue.
When DIST processes rs_ticket, it appends another timestamp to rs_ticket_param. A DIST timestamp takes the form ''DIST(spid)=hh:mm:ss.ddd''.
When DSI processes rs_ticket, it appends yet another timestamp to rs_ticket_param. A DSI timestamp takes the form ''DSI(spid)=hh:mm:ss.ddd''.
There are no subscriptions for rs_ticket. DIST does not send rs_ticket to DSI unless there is at least one subscription from the replicate site.
rs_ticket is lightweight and nonintrusive and can be used in test environments as well as production environments.
rs_ticket lets you know, without quiescing the Replication Server, when the data has been completely flushed out of replication path.
The movement of rs_ticket is tracked by the EXEC, DIST, and DSI threads through RSTicket counter. Each thread has one RSTicket counter which is increased by one whenever the corresponding thread receives rs_ticket. This counter is never reset.
You can monitor the module that rs_ticket has reached by sampling the RSTicket counters. RMS or other Replication Server monitoring tool uses these counters to produce EXEC, DIST, and DSI heartbeat.
You can also monitor the health of the replication path by sending an rs_ticket at primary and checking the RSTicket counters. If RSTicket counter of a module is not increasing, it shows that replication path at this stage is broken.
Use rs_ticket only when Replication Server is 15.0 or higher.
rs_ticket_report stored procedure, rs_ticket_report function string