Skip to content

VictoriaLogs Time Series Query Go SDK#

Constructor#

import "github.com/perses/perses-plugins/victorialogs/sdk/go/v1/query"

var options []query.Option
query.TimeSeriesQuery(`_stream:{job="nginx"} | stats count() by (_time:1m)`, options...)

Need to provide the LogsQL expression and a list of options.

Default options#

  • Query(): with the expression provided in the constructor.

Available options#

Query#

import "github.com/perses/perses-plugins/victorialogs/sdk/go/v1/query"

query.Query(`_stream:{service="api"} | stats sum(response_time) by (_time:5m)`)

Define the LogsQL query expression for time series data.

Datasource#

import "github.com/perses/perses-plugins/victorialogs/sdk/go/v1/query"

query.Datasource("MyVictoriaLogsDatasource")

Define the datasource the query will use.

Example#

package main

import (
    "github.com/perses/perses/go-sdk/dashboard"
    "github.com/perses/perses/go-sdk/panel"
    panelgroup "github.com/perses/perses/go-sdk/panel-group"
    "github.com/perses/perses-plugins/victorialogs/sdk/go/v1/query"
    timeseries "github.com/perses/perses-plugins/timeserieschart/sdk/go"
)

func main() {
    dashboard.New("VictoriaLogs Dashboard",
        dashboard.AddPanelGroup("Log Metrics",
            panelgroup.AddPanel("Request Rate",
                timeseries.Chart(),
                panel.AddQuery(
                    query.TimeSeriesQuery(`_stream:{job="nginx"} | stats count() by (_time:1m)`),
                ),
            ),
        ),
    )
}