This feature is in preview. This feature is subject to change. To share feedback and/or issues, contact Support.
This is an enterprise-only feature. Request a 30-day trial license to try it out.
New in v23.2:
The SHOW VIRTUAL CLUSTER
statement lists the virtual clusters running in a CockroachDB cluster. SHOW VIRTUAL CLUSTER
only supports inspecting virtual cluster status as part of the physical cluster replication workflow.
Physical cluster replication happens between an active primary cluster and a passive standby cluster that accepts updates from the primary cluster. The unit of replication is a virtual cluster, which is part of the underlying infrastructure in the primary and standby clusters. Each cluster has:
- The system interface manages the cluster's control plane and the replication of the virtual cluster.
- The virtual cluster manages its own data plane. Users connect to the virtual cluster that contains the application user data.
For more detail, refer to the Physical Cluster Replication Overview.
Required privileges
SHOW VIRTUAL CLUSTER
requires either:
- The
admin
role. - The
MANAGEVIRTUALCLUSTER
system privilege.
Use the GRANT SYSTEM
statement:
GRANT SYSTEM MANAGEVIRTUALCLUSTER TO user;
Synopsis
Parameters
Parameter | Description |
---|---|
virtual_cluster_spec |
The name of the virtual cluster. |
REPLICATION STATUS |
Display the details of a replication stream. |
CAPABILITIES |
Display the capabilities of a virtual cluster. |
Responses
This table lists all possible responses from the different SHOW VIRTUAL CLUSTER
statements:
Field | Response |
---|---|
id |
The ID of the virtual cluster. |
name |
The name of the standby (destination) virtual cluster. |
data_state |
The state of the data on the virtual cluster. This can show one of the following: initializing replication , ready , replicating , replication paused , replication pending cutover , replication cutting over , replication error . Refer to Data state for more detail on each response. |
service_mode |
The service mode shows whether the virtual cluster is ready to accept SQL requests. This can show one none or shared . When shared , the virtual cluster's SQL connections will be served by the same nodes that are serving the system interface. |
source_tenant_name |
The name of the primary (source) virtual cluster. |
source_cluster_uri |
The URI of the primary (source) cluster. The standby cluster connects to the primary cluster using this URI when starting a replication stream. |
replication_job_id |
The ID of the replication job. |
replicated_time |
The latest timestamp at which the standby cluser has consistent data — that is, the latest time you can cut over to. This time advances automatically as long as the replication proceeds without error. replicated_time is updated periodically (every 30s ). |
retained_time |
The earliest timestamp at which the standby cluster has consistent data — that is, the earliest time you can cut over to. |
cutover_time |
The time at which the cutover will begin. This can be in the past or the future. Refer to Cut over to a point in time. |
capability_name |
The capability name. |
capability_value |
Whether the capability is enabled for the virtual cluster. |
Data state
State | Description |
---|---|
initializing replication |
The replication job is completing the initial scan of data from the primary cluster before it starts replicating data in real time. |
ready |
The virtual cluster's data is ready for use. |
replicating |
The replication job has started and is replicating data. |
replication paused |
The replication job is paused due to an error or a manual request with ALTER VIRTUAL CLUSTER ... PAUSE REPLICATION . |
replication pending cutover |
The replication job is running and the cutover time has been set. Once the the replication reaches the cutover time, the cutover will begin automatically. |
replication cutting over |
The job has started cutting over. The cutover time can no longer be changed. Once complete, the virtual cluster will be available for use with ALTER VIRTUAL CLUSTER ... START SHARED SERVICE . |
replication error |
An error has occurred. You can find more detail in the error message and the logs. |
Examples
Show all virtual clusters
List all of the virtual clusters:
SHOW VIRTUAL CLUSTERS;
Show a virtual cluster
To show more details about the application
virtual cluster:
SHOW VIRTUAL CLUSTER application;
id | name | data_state | service_mode | source_tenant_name | source_cluster_uri | replication_job_id | replicated_time | retained_time | cutover_time
-----+--------------------+-------------+--------------+--------------------+-----------------------------------------------------------------------------------------------------------------------+--------------------+------------------------------+-------------------------------+---------------
5 | application | replicating | none | application | postgresql://user:redacted@host/?options=-ccluster%3Dsystem&sslmode=verify-full&sslrootcert=redacted | 911803003607220225 | 2023-10-26 17:36:52.27978+00 | 2023-10-26 14:36:52.279781+00 | NULL
Show replication status
To show the replication status of all virtual clusters:
SHOW VIRTUAL CLUSTERS WITH REPLICATION STATUS;
To show the replication status of the application
virtual cluster:
SHOW VIRTUAL CLUSTER application WITH REPLICATION STATUS;