axiom

package module
v0.21.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 17, 2024 License: MIT Imports: 0 Imported by: 0

README

axiom-go

Axiom.co banner  

Go Reference Workflow Latest Release License

Axiom unlocks observability at any scale.

  • Ingest with ease, store without limits: Axiom's next-generation datastore enables ingesting petabytes of data with ultimate efficiency. Ship logs from Kubernetes, AWS, Azure, Google Cloud, DigitalOcean, Nomad, and others.
  • Query everything, all the time: Whether DevOps, SecOps, or EverythingOps, query all your data no matter its age. No provisioning, no moving data from cold/archive to "hot", and no worrying about slow queries. All your data, all. the. time.
  • Powerful dashboards, for continuous observability: Build dashboards to collect related queries and present information that's quick and easy to digest for you and your team. Dashboards can be kept private or shared with others, and are the perfect way to bring together data from different sources.

For more information check out the official documentation and our community Discord.

Quickstart

Install using go get:

go get github.com/axiomhq/axiom-go/axiom

Import the package:

import "github.com/axiomhq/axiom-go/axiom"

If you use the Axiom CLI, run eval $(axiom config export -f) to configure your environment variables.

Otherwise create a personal token in the Axiom settings and export it as AXIOM_TOKEN. Set AXIOM_ORG_ID to the organization ID from the settings page of the organization you want to access.

[!NOTE] The organization ID is the slug below your organizations full name in the Axiom settings which resembles the full name. It has a copy button next to it. Alternatively you can just extract it from your browsers address bar when browsing the Axiom App: https://app.dev.axiomtestlabs.co/<your-org-id>/datasets.

You can also configure the client using options passed to the axiom.NewClient function:

client, err := axiom.NewClient(
    axiom.SetPersonalTokenConfig("AXIOM_TOKEN", "AXIOM_ORG_ID"),
)

[!NOTE] When only performing ingest or query operations, we recommend using an API token with minimal privileges, only! Create an API token with the appropriate scopes in the Axiom API tokens settings and export it as AXIOM_TOKEN.

Create and use a client like this:

package main

import (
    "context"
    "fmt"
    "log"

    "github.com/axiomhq/axiom-go/axiom"
    "github.com/axiomhq/axiom-go/axiom/ingest"
)

func main() {
    ctx := context.Background()

    client, err := axiom.NewClient()
    if err != nil {
        log.Fatal(err)
    }
    
    if _, err = client.IngestEvents(ctx, "my-dataset", []axiom.Event{
        {ingest.TimestampField: time.Now(), "foo": "bar"},
        {ingest.TimestampField: time.Now(), "bar": "foo"},
    }); err != nil {
        log.Fatal(err)
    }

    res, err := client.Query(ctx, "['my-dataset'] | where foo == 'bar' | limit 100")
    if err != nil {
        log.Fatal(err)
    } else if res.Status.RowsMatched == 0 {
        log.Fatal("No matches found")
    }

    rows := res.Tables[0].Rows()
    if err := rows.Range(ctx, func(_ context.Context, row query.Row) error {
        _, err := fmt.Println(row)
        return err
    }); err != nil {
        log.Fatal(err)
    }
}

For further examples, head over to the examples directory.

If you want to use a logging package, check if there is already an adapter in the adapters directory. We happily accept contributions for new adapters.

License

Distributed under the MIT License.

Documentation

Overview

Package axiom implements Go bindings for the Axiom API.

Usage:

import "github.com/axiomhq/axiom-go/axiom"
import "github.com/axiomhq/axiom-go/axiom/ingest" // When ingesting data
import "github.com/axiomhq/axiom-go/axiom/otel" // When using OpenTelemetry
import "github.com/axiomhq/axiom-go/axiom/query" // When constructing APL queries
import "github.com/axiomhq/axiom-go/axiom/querylegacy" // When constructing legacy queries

Construct a new Axiom client, then use the various services on the client to access different parts of the Axiom API. The package automatically takes its configuration from the environment if not specified otherwise. Refer to axiom.NewClient for details. The token can be an API or personal token. The API token however, will just allow ingestion or querying into or from the datasets the token is valid for, depending on its assigned permissions.

To construct a client:

client, err := axiom.NewClient()

or with axiom.Option functions:

client, err := axiom.NewClient(
    axiom.SetToken("..."),
    axiom.SetOrganizationID("..."),
)

Get the current authenticated user:

user, err := client.Users.Current(ctx)

NOTE: Every client method mapping to an API method takes a context.Context as its first parameter to pass cancellation signals and deadlines to requests. In case there is no context available, then context.Background can be used as a starting point.

For more code samples, check out the examples.

Directories

Path Synopsis
Package adapters provides packages which implement integration into well known Go logging libraries.
Package adapters provides packages which implement integration into well known Go logging libraries.
apex
Package apex provides an adapter for the popular github.com/apex/log logging library.
Package apex provides an adapter for the popular github.com/apex/log logging library.
logrus
Package logrus provides an adapter for the popular github.com/sirupsen/logrus logging library.
Package logrus provides an adapter for the popular github.com/sirupsen/logrus logging library.
slog
Package slog provides an adapter for the standard libraries structured logging package.
Package slog provides an adapter for the standard libraries structured logging package.
zap
Package zap provides an adapter for the popular github.com/uber-go/zap logging library.
Package zap provides an adapter for the popular github.com/uber-go/zap logging library.
zerolog
Package zerolog provides an adapter for the popular github.com/rs/zerolog logging library.
Package zerolog provides an adapter for the popular github.com/rs/zerolog logging library.
Package axiom implements Go bindings for the Axiom API.
Package axiom implements Go bindings for the Axiom API.
ingest
Package ingest provides the datatypes and functions helping with ingesting data into Axiom.
Package ingest provides the datatypes and functions helping with ingesting data into Axiom.
otel
Package otel provides helpers for using [OpenTelemetry] with Axiom.
Package otel provides helpers for using [OpenTelemetry] with Axiom.
query
Package query provides the datatypes and functions for construction queries using the Axiom Processing Language (APL) and working with their results.
Package query provides the datatypes and functions for construction queries using the Axiom Processing Language (APL) and working with their results.
querylegacy
Package querylegacy provides the datatypes and functions for construction legacy queries and working with their results.
Package querylegacy provides the datatypes and functions for construction legacy queries and working with their results.
Package examples contains code examples on how to use Axiom Go.
Package examples contains code examples on how to use Axiom Go.
apex
The purpose of this example is to show how to integrate with apex/log.
The purpose of this example is to show how to integrate with apex/log.
ingestevent
The purpose of this example is to show how to send events to Axiom.
The purpose of this example is to show how to send events to Axiom.
ingestfile
The purpose of this example is to show how to stream the contents of a JSON logfile and gzip them on the fly.
The purpose of this example is to show how to stream the contents of a JSON logfile and gzip them on the fly.
ingesthackernews
The purpose of this example is to show how to replicate the contents of Hacker News into Axiom.
The purpose of this example is to show how to replicate the contents of Hacker News into Axiom.
logrus
The purpose of this example is to show how to integrate with logrus.
The purpose of this example is to show how to integrate with logrus.
otelinstrument
The purpose of this example is to show how to instrument the Axiom Go client using OpenTelemetry.
The purpose of this example is to show how to instrument the Axiom Go client using OpenTelemetry.
oteltraces
The purpose of this example is to show how to send OpenTelemetry traces to Axiom.
The purpose of this example is to show how to send OpenTelemetry traces to Axiom.
query
The purpose of this example is to show how to query a dataset using the Axiom Processing Language (APL).
The purpose of this example is to show how to query a dataset using the Axiom Processing Language (APL).
querylegacy
The purpose of this example is to show how to query a dataset using a legacy query.
The purpose of this example is to show how to query a dataset using a legacy query.
slog
The purpose of this example is to show how to integrate with slog.
The purpose of this example is to show how to integrate with slog.
zap
The purpose of this example is to show how to integrate with zap.
The purpose of this example is to show how to integrate with zap.
zerolog
The purpose of this example is to show how to integrate with zerolog.
The purpose of this example is to show how to integrate with zerolog.
internal
config
Package config provides the base configuration for Axiom related functionality like URLs and credentials for API access.
Package config provides the base configuration for Axiom related functionality like URLs and credentials for API access.
test/adapters
Package adapters provides helpers for dealing with adapter tests.
Package adapters provides helpers for dealing with adapter tests.
test/testhelper
Package testdata provides - big surprise - helper functions to be used in tests.
Package testdata provides - big surprise - helper functions to be used in tests.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL