diff --git a/go/vt/vtadmin/cluster/cluster.go b/go/vt/vtadmin/cluster/cluster.go index 40c003b3db1..94d1e2caecc 100644 --- a/go/vt/vtadmin/cluster/cluster.go +++ b/go/vt/vtadmin/cluster/cluster.go @@ -1249,21 +1249,46 @@ func (c *Cluster) GetTablets(ctx context.Context) ([]*vtadminpb.Tablet, error) { func (c *Cluster) getTablets(ctx context.Context) ([]*vtadminpb.Tablet, error) { res, err := c.Vtctld.GetTablets(ctx, &vtctldatapb.GetTabletsRequest{}) - tablets := make([]*vtadminpb.Tablet, len(res.Tablets)) - for i, t := range res.Tablets { - tablets[i] = &vtadminpb.Tablet{ - Cluster: c.ToProto(), - Tablet: t, - // TODO: Add serving state, return these results - } - } - - rows, err := c.DB.ShowTablets(ctx) if err != nil { return nil, err } - return c.parseTablets(rows) + var ( + m sync.Mutex + wg sync.WaitGroup + tablets []*vtadminpb.Tablet + ) + + for _, t := range res.Tablets { + wg.Add(1) + + go func(tablet *topodatapb.Tablet) { + defer wg.Done() + + var state vtadminpb.Tablet_ServingState + _, err := c.Vtctld.RunHealthCheck(ctx, &vtctldatapb.RunHealthCheckRequest{ + TabletAlias: tablet.Alias, + }) + if err != nil { + state = vtadminpb.Tablet_NOT_SERVING + } else { + state = vtadminpb.Tablet_SERVING + } + + m.Lock() + defer m.Unlock() + + tablets = append(tablets, &vtadminpb.Tablet{ + Cluster: c.ToProto(), + Tablet: t, + State: state, + }) + }(t) + } + + wg.Wait() + + return tablets, nil } // GetSchemaOptions contains the options that modify the behavior of the