Monitor
Status of the deployed connector
You can use the rest APIs to monitor your deployed connectors. The following operations are available:
-
List all connectors
curl -X GET localhost:8083/connectors/
-
Get a connector's configuration
curl -X GET localhost:8083/connectors/<connector-name>
-
Get the status of all tasks with their configuration
curl -X GET localhost:8083/connectors/<connector-name>/tasks
-
Get the status of the specified task
curl -X GET localhost:8083/connectors/<connector-name>/tasks/<task-id>
-
Get the connector's status, and the status of its tasks
curl -X GET localhost:8083/connectors/<connector-name>/status
Note
It is possible that upon retrieving the status of the connector, it can show a RUNNING state while no data is being ingested to Kafka. As a connector consists of one or more tasks, the tasks have likely failed, independently from the connector. To verify this, you need to check for the status of the tasks.
To show the status, use the following command:
curl -X GET localhost:8083/connectors/<connector-name>/status
You can also get the status of a specific task by passing in the task ID as follows:
curl -X GET localhost:8083/connectors/<connector-name>/tasks/<task-id>/status
Metrics
In addition to the built-in support for JMX metrics that Zookeeper, Kafka, and Kafka Connect provide, the YugabyteDB source connector provides the following types of metrics.
CDC Service metrics
Provide information about CDC service in YugabyteDB.
Metric name | Type | Description |
---|---|---|
cdcsdk_change_event_count | long |
The Change Event Count metric shows the number of records sent by the CDC Service. |
cdcsdk_traffic_sent | long |
Total traffic sent, in bytes. |
cdcsdk_sent_lag_micros | long |
The LAG metric is calculated by subtracting the timestamp of the latest record in the WAL of a tablet from the last record sent to the CDC connector. |
cdcsdk_expiry_time_ms | long |
The time left to read records from WAL is tracked by the Stream Expiry Time (ms). |
Snapshot metrics
The MBean is debezium.yugabytedb:type=connector-metrics,server=<database.server.name>,task=<task.id>,context=snapshot
.
Snapshot metrics are only available when a snapshot operation is active, or if a snapshot has occurred since the last connector start. The following snapshot metrics are available:
Metric name | Type | Description |
---|---|---|
LastEvent | string |
The last snapshot event that the connector has read. |
MilliSecondsSinceLastEvent | long |
The number of milliseconds since the connector has read and processed the most recent event. |
TotalNumberOfEventsSeen | long |
The total number of events that this connector has seen since the last start or metrics reset. |
NumberOfEventsFiltered | long |
The number of events that have been filtered by include/exclude list filtering rules configured on the connector. |
QueueTotalCapacity | int |
The length the queue used to pass events between the snapshotter and the main Kafka Connect loop. |
QueueRemainingCapacity | int |
The free capacity of the queue used to pass events between the snapshotter and the main Kafka Connect loop. |
SnapshotRunning | boolean |
Whether the snapshot is currently running. |
SnapshotPaused | boolean |
Whether the snapshot was paused one or more times. |
SnapshotAborted | boolean |
Whether the snapshot has been aborted. |
SnapshotCompleted | boolean |
Whether the snapshot has been completed. |
SnapshotDurationInSeconds | long |
The total number of seconds that the snapshot has taken so far, even if not complete. Includes also time when snapshot was paused. |
SnapshotPausedDurationInSeconds | long |
The total number of seconds that the snapshot was paused. If the snapshot was paused more than once, this is the cumulative pause time. |
MaxQueueSizeInBytes | long |
The maximum buffer of the queue, in bytes. This metric is available if max.queue.size.in.bytes is set to a positive long value. |
CurrentQueueSizeInBytes | long |
The current volume, in bytes, of records in the queue. |
Streaming metrics
The MBean is debezium.yugabytedb:type=connector-metrics,server=<database.server.name>,task=<task.id>,context=streaming
.
The following streaming metrics are available:
Metric name | Type | Description |
---|---|---|
LastEvent | string |
The last streaming event that the connector has read. |
MilliSecondsSinceLastEvent | long |
The number of milliseconds since the connector has read and processed the most recent event. |
TotalNumberOfEventsSeen | long |
The total number of events that this connector has seen since the last start or metrics reset. |
TotalNumberOfCreateEventsSeen | long |
The total number of create events that this connector has seen since the last start or metrics reset. |
TotalNumberOfUpdateEventsSeen | long |
The total number of update events that this connector has seen since the last start or metrics reset. |
TotalNumberOfDeleteEventsSeen | long |
The total number of delete events that this connector has seen since the last start or metrics reset. |
NumberOfEventsFiltered | long |
The total number of events (since the last start or metrics reset) that have been filtered by include/exclude list filtering rules configured on the connector. |
QueueTotalCapacity | int |
The length the queue used to pass events between the streamer and the main Kafka Connect loop. |
QueueRemainingCapacity | int |
The free capacity of the queue used to pass events between the streamer and the main Kafka Connect loop. |
Connected | boolean |
Indicates whether the connector is currently connected to the database server. |
MilliSecondsBehindSource | long |
The number of milliseconds between the last change event's timestamp and when the connector processed it. The value incorporates any differences between the clocks on the machines where the database server and the connector are running. |
SourceEventPosition | Map<String, String> |
The coordinates of the last received event. |
LastTransactionId | string |
Transaction identifier of the last processed transaction. |
MaxQueueSizeInBytes | long |
The maximum buffer of the queue in bytes. This metric is available if max.queue.size.in.bytes is set to a positive long value. |
CurrentQueueSizeInBytes | long |
The current volume, in bytes, of records in the queue. |