feat(tsi1): add flags for --org-id and --bucket-id

pull/14470/head
Max U 2019-07-24 14:34:47 -07:00
parent bfd38d93d8
commit 5e5fa96c5b
2 changed files with 35 additions and 19 deletions

View File

@ -51,8 +51,8 @@ func NewReportTsiCommand() *cobra.Command {
// fs.BoolVar(&cmd.byTagKey, "tag-key", false, "Segment cardinality by tag keys (overrides `measurements`")
reportTsiCommand.Flags().IntVar(&tsiFlags.topN, "top", 0, "Limit results to top n")
reportTsiCommand.Flags().IntVar(&tsiFlags.concurrency, "c", runtime.GOMAXPROCS(0), "Set worker concurrency. Defaults to GOMAXPROCS setting.")
reportTsiCommand.Flags().StringVar(&tsiFlags.bucket, "bucket", "", "If bucket is specified, org must be specified")
reportTsiCommand.Flags().StringVar(&tsiFlags.org, "org", "", "Org to be reported")
reportTsiCommand.Flags().StringVarP(&tsiFlags.bucket, "bucket", "b", "", "If bucket is specified, org must be specified")
reportTsiCommand.Flags().StringVarP(&tsiFlags.org, "org", "o", "", "Org to be reported")
reportTsiCommand.SetOutput(tsiFlags.Stdout)

View File

@ -75,6 +75,7 @@ func newTsiSummary() *ReportTsiSummary {
// Run runs the report-tsi tool which can be used to find the cardinality
// any org or bucket. Run returns a *ReportTsiSummary, which contains maps for finding
// the cardinality of a bucket or org based on it's influxdb.ID
// The *ReportTsiSummary will be nil if there is a failure
func (report *ReportCommand) Run() (*ReportTsiSummary, error) {
report.Stdout = os.Stdout
@ -104,8 +105,26 @@ func (report *ReportCommand) Run() (*ReportTsiSummary, error) {
// Blocks until all work done.
report.calculateCardinalities(fn)
// Generate and print summary.
summary := report.printOrgBucketCardinality()
// Generate and print summary
var summary *ReportTsiSummary
tw := tabwriter.NewWriter(report.Stdout, 4, 4, 1, '\t', 0)
// if no org or bucket flags have been specified, print everything
// if not, only print the specified org/bucket
if report.OrgID == nil {
summary = report.printOrgBucketCardinality(true)
} else {
// still need to generate a summary, just without printing
summary = report.printOrgBucketCardinality(false)
// if we do not have a bucket, print the cardinality of OrgID
if report.BucketID == nil {
fmt.Fprintf(tw, "Org (%v) Cardinality: %v \n\n", report.OrgID, summary.OrgCardinality[*report.OrgID])
} else {
fmt.Fprintf(tw, "Bucket (%v) Cardinality: %v \n\n", report.BucketID, summary.BucketCardinality[*report.BucketID])
}
tw.Flush()
}
return summary, nil
}
@ -286,14 +305,9 @@ func (a results) Len() int { return len(a) }
func (a results) Less(i, j int) bool { return a[i].count < a[j].count }
func (a results) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
// func (report *ReportCommand) printSummaryByMeasurement() error {
// report.printOrgBucketCardinality()
// return nil
// }
// GetOrgCardinality returns the total cardinality of the org provided.
// Can only be called after Run().
func (report *ReportCommand) GetOrgCardinality(orgID influxdb.ID) int64 {
// Can only be called after Run()
func (report *ReportCommand) printOrgCardinality(orgID influxdb.ID) int64 {
orgTotal := int64(0)
for _, bucket := range report.orgBucketCardinality[orgID] {
orgTotal += bucket.cardinality()
@ -303,11 +317,11 @@ func (report *ReportCommand) GetOrgCardinality(orgID influxdb.ID) int64 {
// GetBucketCardinality returns the total cardinality of the bucket in the org provided
// Can only be called after Run()
func (report *ReportCommand) GetBucketCardinality(orgID, bucketID influxdb.ID) int64 {
func (report *ReportCommand) printBucketCardinality(orgID, bucketID influxdb.ID) int64 {
return report.orgBucketCardinality[orgID][bucketID].cardinality()
}
func (report *ReportCommand) printOrgBucketCardinality() *ReportTsiSummary {
func (report *ReportCommand) printOrgBucketCardinality(print bool) *ReportTsiSummary {
tw := tabwriter.NewWriter(report.Stdout, 4, 4, 1, '\t', 0)
// Generate a new summary
@ -327,14 +341,16 @@ func (report *ReportCommand) printOrgBucketCardinality() *ReportTsiSummary {
summary.OrgCardinality[org] = orgTotal
}
if print {
fmt.Fprintf(tw, "Summary (total): %v \n\n", totalCard)
fmt.Println(report.orgBucketCardinality)
for orgName, orgToBucket := range report.orgBucketCardinality {
fmt.Fprintf(tw, "Org %s total: %d \n\n", orgName.String(), orgTotals[orgName])
for bucketName, bucketCard := range orgToBucket {
fmt.Fprintf(tw, " Bucket %s %d\n", bucketName.String(), bucketCard.cardinality())
fmt.Fprintf(tw, "Org %s total: %d \n\n", orgName.String(), summary.OrgCardinality[orgName])
for bucketName := range orgToBucket {
fmt.Fprintf(tw, " Bucket %s %d\n", bucketName.String(), summary.BucketCardinality[bucketName])
}
}
}