Skip to content

Commit

Permalink
Merge pull request #3992 from Yelp/u/gonabavi/DREIMP-11112_cleanup_vi…
Browse files Browse the repository at this point in the history
…tess_from_paasta

Clean up Vitess from PaaSTA
  • Loading branch information
VinaySagarGonabavi authored Dec 11, 2024
2 parents 7d34801 + d1e6b20 commit 03fd1b2
Show file tree
Hide file tree
Showing 13 changed files with 0 additions and 2,214 deletions.
17 changes: 0 additions & 17 deletions paasta_tools/api/api_docs/oapi.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -339,12 +339,6 @@ components:
InstanceSpecCassandraCluster:
description: Cassandra instance spec
type: object
InstanceMetadataVitessCluster:
description: VitessCluster instance metadata
type: object
InstanceSpecVitessCluster:
description: VitessCluster instance spec
type: object
InstanceStatus:
properties:
adhoc:
Expand Down Expand Up @@ -383,14 +377,6 @@ components:
status:
$ref: '#/components/schemas/InstanceStatusCassandraCluster'
type: object
vitesscluster:
description: Nullable VitessCluster instance status and metadata
properties:
metadata:
$ref: '#/components/schemas/InstanceMetadataVitessCluster'
status:
$ref: '#/components/schemas/InstanceStatusVitessCluster'
type: object
kafkacluster:
description: Nullable KafkaCluster instance status and metadata
properties:
Expand Down Expand Up @@ -426,9 +412,6 @@ components:
InstanceStatusCassandraCluster:
description: Cassandra instance status
type: object
InstanceStatusVitessCluster:
description: VitessCluster instance status
type: object
InstanceStatusKafkaCluster:
description: Kafka instance status
type: object
Expand Down
20 changes: 0 additions & 20 deletions paasta_tools/api/api_docs/swagger.json
Original file line number Diff line number Diff line change
Expand Up @@ -960,18 +960,6 @@
}
},
"description": "Nullable CassandraCluster instance status"
},
"vitesscluster": {
"type": "object",
"properties": {
"status": {
"$ref": "#/definitions/InstanceStatusVitessCluster"
},
"metadata": {
"$ref": "#/definitions/InstanceMetadataVitessCluster"
}
},
"description": "Nullable VitessCluster instance status and metadata"
}
}
},
Expand Down Expand Up @@ -1756,14 +1744,6 @@
"type": "object",
"description": "Cassandra instance status"
},
"InstanceStatusVitessCluster": {
"type": "object",
"description": "VitessCluster instance status"
},
"InstanceMetadataVitessCluster": {
"type": "object",
"description": "VitessCluster instance metadata"
},
"InstanceTasks": {
"type": "array",
"description": "List of tasks associated with instance",
Expand Down
250 changes: 0 additions & 250 deletions paasta_tools/cli/cmds/status.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@
from typing import Sequence
from typing import Tuple
from typing import Type
from typing import TypedDict
from typing import Union

import a_sync
Expand Down Expand Up @@ -95,14 +94,12 @@
from paasta_tools.utils import PaastaColors
from paasta_tools.utils import remove_ansi_escape_sequences
from paasta_tools.utils import SystemPaastaConfig
from paasta_tools.vitesscluster_tools import VitessDeploymentConfig

FLINK_STATUS_MAX_THREAD_POOL_WORKERS = 50
ALLOWED_INSTANCE_CONFIG: Sequence[Type[InstanceConfig]] = [
FlinkDeploymentConfig,
FlinkEksDeploymentConfig,
CassandraClusterDeploymentConfig,
VitessDeploymentConfig,
KafkaClusterDeploymentConfig,
KubernetesDeploymentConfig,
EksDeploymentConfig,
Expand All @@ -115,7 +112,6 @@
FlinkDeploymentConfig,
FlinkEksDeploymentConfig,
CassandraClusterDeploymentConfig,
VitessDeploymentConfig,
KafkaClusterDeploymentConfig,
KubernetesDeploymentConfig,
EksDeploymentConfig,
Expand All @@ -137,7 +133,6 @@
EKS_DEPLOYMENT_CONFIGS = [
EksDeploymentConfig,
FlinkEksDeploymentConfig,
VitessDeploymentConfig,
]
FLINK_DEPLOYMENT_CONFIGS = [FlinkDeploymentConfig, FlinkEksDeploymentConfig]

Expand Down Expand Up @@ -1906,250 +1901,6 @@ def print_kafka_status(
return 0


class EtcdLockServerStatus(TypedDict, total=False):
observedGeneration: int
available: str
clientServiceName: str


class LockServerStatus(TypedDict, total=False):
etcd: EtcdLockServerStatus


class VitessClusterCellStatus(TypedDict, total=False):
pendingChanges: str
gatewayAvailable: str


class VitessClusterKeyspaceStatus(TypedDict, total=False):
pendingChanges: str
cells: List[str]
desiredShards: int
shards: int
readyShards: int
updatedShards: int
desiredTablets: int
tablets: int
readyTablets: int
updatedTablets: int


class VitessDashboardStatus(TypedDict, total=False):
available: str
serviceName: str


class VTAdminStatus(TypedDict, total=False):
available: str
serviceName: str


class OrphanStatus(TypedDict, total=False):
reason: str
message: str


class VitessClusterStatus(TypedDict, total=False):
observedGeneration: int
globalLockserver: LockServerStatus
gatewayServiceName: str
vitessDashboard: VitessDashboardStatus
cells: Dict[str, VitessClusterCellStatus]
keyspaces: Dict[str, VitessClusterKeyspaceStatus]
vtadmin: VTAdminStatus
orphanedCells: Dict[str, OrphanStatus]
orphanedKeyspaces: Dict[str, OrphanStatus]


def print_vitess_status(
cluster: str,
service: str,
instance: str,
output: List[str],
vitess_status: Mapping[str, Any],
verbose: int = 0,
) -> int:
tab = " "
indent = 1

status: VitessClusterStatus = vitess_status.get("status")
if status is None:
output.append(
PaastaColors.red("indent * tab + Vitess cluster is not available yet")
)
return 1

output.append(indent * tab + "Vitess Cluster:")
indent += 1

output.append(
indent * tab
+ "Observed Generation: "
+ str(status.get("observedGeneration", 0))
)
output.append(
indent * tab + "Gateway Service Name: " + status.get("gatewayServiceName", "")
)

output.append(indent * tab + "Cells:")
indent += 1
cells: Dict[str, VitessClusterCellStatus] = status.get("cells")
if not cells:
output.append(
indent * tab + "Cells: " + PaastaColors.red("No cell status available")
)
return 0
for cell, cell_status in cells.items():
gateway_available: str = cell_status.get("gatewayAvailable")
if gateway_available == "True":
output.append(
indent * tab
+ f"Cell: {cell} - VTGate: {PaastaColors.green('available')}"
)
else:
output.append(
indent * tab
+ f"Cell: {cell} - VTGate: {PaastaColors.red('unavailable')}"
)
cell_pending_changes: str = cell_status.get("pendingChanges", None)
if cell_pending_changes:
output.append(indent * tab + f" Pending Changes: {cell_pending_changes}")
indent -= 1

output.append(indent * tab + "Vitess Dashboard:")
indent += 1
vitess_dashboard: VitessDashboardStatus = status.get("vitessDashboard")
if not vitess_dashboard:
output.append(
indent * tab
+ "Vitess Dashboard: "
+ PaastaColors.red("No dashboard status available")
)
return 0
vitess_dashboard_available: str = vitess_dashboard.get("available", "")
vitess_dashboard_service_name: str = vitess_dashboard.get("serviceName", "")
if vitess_dashboard_available == "True":
output.append(
indent * tab
+ f"Vitess Dashboard: {vitess_dashboard_service_name} - {PaastaColors.green('available')}"
)
else:
output.append(
indent * tab
+ f"Vitess Dashboard: {vitess_dashboard_service_name} - {PaastaColors.red('unavailable')}"
)
indent -= 1

output.append(indent * tab + "VTAdmin:")
indent += 1
vtadmin: VTAdminStatus = status.get("vtadmin")
if not vtadmin:
output.append(
indent * tab + "VTAdmin: " + PaastaColors.red("No VTAdmin status available")
)
return 0
vtadmin_available: str = vtadmin.get("available", "")
vtadmin_service_name: str = vtadmin.get("serviceName", "")
if vtadmin_available == "True":
output.append(
indent * tab
+ f"VTAdmin: {vtadmin_service_name} - {PaastaColors.green('available')}"
)
else:
output.append(
indent * tab
+ f"VTAdmin: {vtadmin_service_name} - {PaastaColors.red('unavailable')}"
)
indent -= 1

output.append(indent * tab + "Keyspaces:")
indent += 1
keyspaces: Dict[str, VitessClusterKeyspaceStatus] = status.get("keyspaces")
if not keyspaces:
output.append(
indent * tab
+ "Keyspaces: "
+ PaastaColors.red("No keyspace status available")
)
return 0
for keyspace, keyspace_status in keyspaces.items():
output.append(indent * tab + f"Keyspace: {keyspace}")
indent += 1
keyspace_pending_changes: str = keyspace_status.get("pendingChanges", None)
if keyspace_pending_changes:
output.append(
indent * tab
+ f"Keyspace: {keyspace} - Pending Changes: {keyspace_pending_changes}"
)
keyspace_cells: List[str] = keyspace_status.get("cells", [])
output.append(indent * tab + f" Cells: {', '.join(keyspace_cells)}")
desired_shards: int = keyspace_status.get("desiredShards", 0)
shards: int = keyspace_status.get("shards", 0)
ready_shards: int = keyspace_status.get("readyShards", 0)
updated_shards: int = keyspace_status.get("updatedShards", 0)
output.append(
indent * tab
+ f" Shards: {shards} observed, {ready_shards}/{desired_shards} ready, {updated_shards}/{desired_shards} updated"
)
desired_tablets: int = keyspace_status.get("desiredTablets", 0)
tablets: int = keyspace_status.get("tablets", 0)
ready_tablets: int = keyspace_status.get("readyTablets", 0)
updated_tablets: int = keyspace_status.get("updatedTablets", 0)
output.append(
indent * tab
+ f" Tablets: {tablets} observed, {ready_tablets}/{desired_tablets} ready, {updated_tablets}/{desired_tablets} updated"
)
indent -= 1
indent -= 1

# This is not needed when not using etcd. We use zk instead
global_lockserver: LockServerStatus = status.get("globalLockserver", {})
if global_lockserver:
output.append(indent * tab + "Global Lockserver:")
indent += 1
etcd: EtcdLockServerStatus = global_lockserver.get("etcd")
if etcd:
output.append(indent * tab + "Global Lockserver:")
indent += 1
observed_generation: int = etcd.get("observedGeneration", 0)
available: str = etcd.get("available", "")
client_service_name: str = etcd.get("clientServiceName", "")
output.append(
indent * tab
+ f"Observed Generation: {observed_generation}, Available: {available}, Client Service Name: {client_service_name}"
)
indent -= 1

# Orphaned Cells are not mandatorily seen each time
orphaned_cells: Dict[str, OrphanStatus] = status.get("orphanedCells", {})
if orphaned_cells:
output.append(indent * tab + "Orphaned Cells:")
indent += 1
for cell, orphan_status in orphaned_cells.items():
orphaned_cell_reason: str = orphan_status.get("reason", "")
orphaned_cell_message: str = orphan_status.get("message", "")
output.append(
indent * tab
+ f"Cell: {cell} - Reason: {orphaned_cell_reason}, Message: {orphaned_cell_message}"
)
indent -= 1

# Orphaned Keyspaces are not mandatorily seen each time
orphaned_keyspaces: Dict[str, OrphanStatus] = status.get("orphanedKeyspaces", {})
if orphaned_keyspaces:
output.append(indent * tab + "Orphaned Keyspaces:")
indent += 1
for keyspace, orphan_status in orphaned_keyspaces.items():
orphaned_keyspace_reason: str = orphan_status.get("reason", "")
orphaned_keyspace_message: str = orphan_status.get("message", "")
output.append(
indent * tab
+ f"Keyspace: {keyspace} - Reason: {orphaned_keyspace_reason}, Message: {orphaned_keyspace_message}"
)
indent -= 1
return 0


def report_status_for_cluster(
service: str,
cluster: str,
Expand Down Expand Up @@ -2548,5 +2299,4 @@ def _use_new_paasta_status(args, system_paasta_config) -> bool:
flinkeks=print_flinkeks_status,
kafkacluster=print_kafka_status,
cassandracluster=print_cassandra_status,
vitesscluster=print_vitess_status,
)
7 changes: 0 additions & 7 deletions paasta_tools/cli/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,6 @@
from paasta_tools.utils import PaastaColors
from paasta_tools.utils import SystemPaastaConfig
from paasta_tools.utils import validate_service_instance
from paasta_tools.vitesscluster_tools import load_vitess_instance_config

try:
from vault_tools.paasta_secret import get_client as get_vault_client
Expand Down Expand Up @@ -683,9 +682,6 @@ class LongRunningInstanceTypeHandler(NamedTuple):
kafkacluster=InstanceTypeHandler(
get_service_instance_list, load_kafkacluster_instance_config
),
vitesscluster=InstanceTypeHandler(
get_service_instance_list, load_vitess_instance_config
),
nrtsearchservice=InstanceTypeHandler(
get_service_instance_list, load_nrtsearchservice_instance_config
),
Expand Down Expand Up @@ -716,9 +712,6 @@ class LongRunningInstanceTypeHandler(NamedTuple):
kafkacluster=LongRunningInstanceTypeHandler(
get_service_instance_list, load_kafkacluster_instance_config
),
vitesscluster=LongRunningInstanceTypeHandler(
get_service_instance_list, load_vitess_instance_config
),
nrtsearchservice=LongRunningInstanceTypeHandler(
get_service_instance_list, load_nrtsearchservice_instance_config
),
Expand Down
Loading

0 comments on commit 03fd1b2

Please sign in to comment.