firehol/netdata

View on GitHub
src/go/plugin/go.d/modules/clickhouse/collect_system_parts.go

Summary

Maintainability
A
1 hr
Test Coverage
// SPDX-License-Identifier: GPL-3.0-or-later

package clickhouse

import (
    "fmt"
    "strconv"

    "github.com/netdata/netdata/go/plugins/plugin/go.d/pkg/web"
)

const querySystemParts = `
SELECT
    database,
    table,
    sum(bytes) as bytes,
    count() as parts,
    sum(rows) as rows 
FROM
    system.parts 
WHERE
    active = 1 
GROUP BY
    database,
    table FORMAT CSVWithNames
`

type tableStats struct {
    database string
    table    string
    bytes    int64
    parts    int64
    rows     int64
}

func (c *ClickHouse) collectSystemParts(mx map[string]int64) error {
    req, _ := web.NewHTTPRequest(c.RequestConfig)
    req.URL.RawQuery = makeURLQuery(querySystemParts)

    seen := make(map[string]*tableStats)

    getTable := func(db, table string) *tableStats {
        k := table + db
        s, ok := seen[k]
        if !ok {
            s = &tableStats{database: db, table: table}
            seen[k] = s
        }
        return s
    }

    var database, table string

    err := c.doHTTP(req, func(column, value string, lineEnd bool) {
        switch column {
        case "database":
            database = value
        case "table":
            table = value
        case "bytes":
            v, _ := strconv.ParseInt(value, 10, 64)
            getTable(database, table).bytes = v
        case "parts":
            v, _ := strconv.ParseInt(value, 10, 64)
            getTable(database, table).parts = v
        case "rows":
            v, _ := strconv.ParseInt(value, 10, 64)
            getTable(database, table).rows = v
        }
    })
    if err != nil {
        return err
    }

    for _, table := range seen {
        k := table.table + table.database
        if _, ok := c.seenDbTables[k]; !ok {
            v := &seenTable{db: table.database, table: table.table}
            c.seenDbTables[k] = v
            c.addTableCharts(v)
        }

        px := fmt.Sprintf("table_%s_database_%s_", table.table, table.database)

        mx[px+"size_bytes"] = table.bytes
        mx[px+"parts"] = table.parts
        mx[px+"rows"] = table.rows
    }

    for k, v := range c.seenDbTables {
        if _, ok := seen[k]; !ok {
            delete(c.seenDbTables, k)
            c.removeTableCharts(v)
        }
    }

    return nil
}