Experiment Go SDK

Official documentation for Amplitude Experiment's server-side Go SDK implementation.

This documentation is split into two sections for remote and local evaluation:

Remote evaluation

Implements fetching variants for a user through remote evaluation.

Install

Install the Go Server SDK using go get.

go get github.com/amplitude/experiment-go-server

Quick start

  1. Initialize the experiment client
  2. Fetch variants for the user
  3. Access a flag's variant
// (1) Initialize the local evaluation client with a server deployment key.
client := remote.Initialize("<DEPLOYMENT_KEY>", nil)

// (2) Fetch variants for a user
user := &experiment.User{
  UserId:   "user@company.com",
  DeviceId: "abcdefg",
  UserProperties: map[string]interface{}{
    "premium": true,
  },
}
variants, err := client.Fetch(user)
if err != nil {
  // Handle error
}

// (3) Access a flag's variant
variant := variants["<FLAG_KEY>"]
if variant.Value == "on" {
    // Flag is on
} else {
    // Flag is off
}

Initialize

Initialize the SDK client in your server on startup. The deployment key argument passed into the apiKey parameter must reside within the same project that you are sending analytics events to.

func Initialize(apiKey string, config *Config) *Client
Parameter Requirement Description
apiKey required The deployment key which authorizes fetch requests and determines which flags should be evaluated for the user.
config optional The client configuration used to customize SDK client behavior.
client := remote.Initialize("<DEPLOYMENT_KEY>", nil)

Configuration

Configure the SDK client upon initialization.

EU data center

If you're using Amplitude's EU data center, configure the ServerZone option on initialization.

Name
Description Default Value
Debug Set to true to enable debug logging. false
LogLevel The minimum log level to output. Options: Verbose, Debug, Info, Warn, Error, Disable. See custom logging. Error
LoggerProvider Custom logger implementation. Implement the LoggerProvider interface to integrate with your logging solution. See custom logging. defaultLoggerProvider which outputs to stdout
ServerZone The Amplitude data center to use. Either USServerZone or EUServerZone. USServerZone
ServerUrl The host to fetch flag configurations from. https://api.lab.amplitude.com
FlagConfigPollingInterval The timeout for fetching variants in milliseconds. This timeout only applies to the initial request, not subsequent retries 500 * time.Millisecond
RetryBackoff.FetchRetries The number of retries to attempt if a request to fetch variants fails. 1
RetryBackoff.FetchRetryBackoffMin The minimum (initial) backoff after a request to fetch variants fails. This delay is scaled by the RetryBackoff.FetchRetryBackoffScalar 0
RetryBackoff.FetchRetryBackoffMax The maximum backoff between retries. If the scaled backoff becomes greater than the max, the max is used for all subsequent requests 10 * time.Second
RetryBackoff.FetchRetryBackoffScalar Scales the minimum backoff exponentially. 1
RetryBackoff.FetchRetryTimeout The request timeout for retrying variant fetches. 500 * time.Millisecond

Fetch

Fetches variants for a user and returns the results. This function remote evaluates the user for flags associated with the deployment used to initialize the SDK client.

func (c *Client) Fetch(user *experiment.User) (map[string]experiment.Variant, error)
Parameter Requirement Description
user required The user to remote fetch variants for.
user := &experiment.User{
    UserId:   "user@company.com",
    DeviceId: "abcdefg",
    UserProperties: map[string]interface{}{
        "premium": true,
    },
}
variants, err := client.Fetch(user)
if err != nil {
    // Handle error
}

After fetching variants for a user, you may to access the variant for a specific flag.

variant := variants["<FLAG_KEY>"]
if variant.Value == "on" {
    // Flag is on
} else {
    // Flag is off
}

Account-level bucketing and analysis (v1.7.0+)
If your organization has purchased the Accounts add-on you may perform bucketing and analysis on groups rather than users. Reach out to your representative to gain access to this beta feature.

Groups must either be included in the user sent with the fetch request (recommended), or identified with the user through a group identify call from the Group Identify API or through setGroup() from an analytics SDK.

user := &experiment.User{
    UserId:   "user@company.com",
    DeviceId: "abcdefg",
    UserProperties: map[string]interface{}{
        "premium": true,
    },
    Groups: map[string]interface{}(
      "org name": ["Amplitude"]
    )
}
variants, err := client.Fetch(user)

To pass freeform group properties, review this example:

user := &experiment.User{
    UserId:   "user@company.com",
    DeviceId: "abcdefg",
    UserProperties: map[string]interface{}{
        "premium": true,
    },
    GroupsProperties: map[string]interface{}(
      "org name": ["Amplitude"]
    )
}
variants, err := client.Fetch(user)

Local evaluation

Implements evaluating variants for a user through local evaluation. If you plan on using local evaluation, you should understand the tradeoffs.

Install

Install the Go Server SDK using go get.

go get github.com/amplitude/experiment-go-server

Quick start

  1. Initialize the local evaluation client.
  2. Start the local evaluation client.
  3. Evaluate a user.
// (1) Initialize the local evaluation client with a server deployment key.
client := local.Initialize("<DEPLOYMENT_KEY>", &local.Config{
 // (Recommended) Enable local evaluation cohort targeting.
 CohortSyncConfig: &local.CohortSyncConfig {
   ApiKey: "<API_KEY>",
   SecretKey: "<SECRET_KEY>"
 }
})

// (2) Start the local evaluation client.
err := client.Start()
if err != nil {
  panic(err)
}

  // (3) Evaluate a user.
user := &experiment.User{DeviceId: "abcdefg"}
variants, err := client.EvaluateV2(user, nil)
if err != nil {
  panic(err)
}

Initialize

Initializes a local evaluation client.

Server deployment key

You must initialize the local evaluation client with a server deployment key to get access to local evaluation flag configs.

func Initialize(apiKey string, config *Config) *Client
Parameter Requirement Description
apiKey required The server deployment key which authorizes fetch requests and determines which flags should be evaluated for the user.
config optional The client configuration used to customize SDK client behavior.

Flag streaming

Use the StreamUpdates configuration to push flag config updates to the SDK (default false), instead of polling every FlagConfigPollingInterval milliseconds. Typically, the time for SDK to receive the update after saving is under one (1) second. It reverts to polling if streaming fails. Configure FlagConfigPollingInterval configuration to set how much time flag configs take to update after they are modified (default 30s), as well for fallback.

Configuration

Configure the SDK client upon initialization.

EU data center

If you're using Amplitude's EU data center, configure the ServerZone option on initialization.

Config

Name
Description Default Value
Debug Set to true to enable debug logging. false
LogLevel The minimum log level to output. Options: Verbose, Debug, Info, Warn, Error, Disable. See custom logging. Error
LoggerProvider Custom logger implementation. Implement the LoggerProvider interface to integrate with your logging solution. See custom logging. defaultLoggerProvider which outputs to stdout
ServerZone The Amplitude data center to use. Either USServerZone or EUServerZone. USServerZone
ServerUrl The host to fetch flag configurations from. https://api.lab.amplitude.com
FlagConfigPollingInterval The interval to poll for updated flag configs after calling Start() 30 * time.Second
FlagConfigPollerRequestTimeout The timeout for the request made by the flag config poller 10 * time.Second
AssignmentConfig Configuration for automatically tracking assignment events after an evaluation. nil
StreamUpdates Enable streaming to replace polling for receiving flag config updates. Instead of polling every second, Amplitude servers push updates to SDK. Typically within one second. If the stream fails for any reason, it reverts to polling automatically and retry streaming after some interval. false
StreamServerUrl The URL of the stream server. https://stream.lab.amplitude.com
StreamFlagConnTimeout The timeout for establishing a valid flag config stream. This includes time for establishing a connection to stream server and time for receiving initial flag configs. 1500
CohortSyncConfig Configuration to enable cohort downloading for local evaluation cohort targeting. nil

AssignmentConfig

Name
Description Default Value
CacheCapacity The maximum number of assignments stored in the assignment cache 524288
Config Options to configure the underlying Amplitude Analytics SDK used to track assignment events

CohortSyncConfig

Name
Description Default Value
ApiKey The analytics API key and NOT the experiment deployment key required
SecretKey The analytics secret key required
MaxCohortSize The maximum size of cohort that the SDK will download. Cohorts larger than this size won't download. 2147483647
CohortPollingIntervalMillis The interval, in milliseconds, to poll Amplitude for cohort updates (60000 minimum). 60000
CohortServerUrl The cohort server endpoint from which to fetch cohort data. For hitting the EU data center, set ServerZone to EUServerZone. Setting this value will override ServerZone defaults. https://cohort-v2.lab.amplitude.com

Start

Start the local evaluation client, pre-fetching local evaluation mode flag configs for evaluation and starting the flag config poller at the configured interval.

func (c *Client) Start() error

You should await the result of Start() to ensure that flag configs are ready before calling Evaluate()

err := client.Start()
if err != nil {
    panic(err)
}

Evaluate

Executes the evaluation logic using the flags pre-fetched on Start(). Evaluate must be given a user object argument and can optionally be passed an array of flag keys if only a specific subset of required flag variants are required.

Automatic assignment tracking

Set AssignmentConfig to automatically track an assignment event to Amplitude when EvaluateV2() is called.

func (c *Client) EvaluateV2(user *experiment.User, flagKeys []string) (map[string]experiment.Variant, error)
Parameter Requirement Description
user required The user to evaluate.
flagKeys optional Specific flags or experiments to evaluate. If nil, or empty, all flags and experiments are evaluated.
// The user to evaluate
user := &experiment.User{DeviceId: "abcdefg"}

// Evaluate all flag variants
allVariants, err := client.EvaluateV2(user, nil)
if err != nil {
    // Handle Error
}

// Evaluate a specific subset of flag variants
specificVariants, err := client.EvaluateV2(user, []string{
    "<FLAG_KEY_1>",
    "<FLAG_KEY_2>",
})

// Access a variant
variant := allVariants["<FLAG_KEY>"]
if variant.Value == "on" {
    // Flag is on
} else {
    // Flag is off
}

Local evaluation cohort targeting

Since version 1.7.0, the local evaluation SDK client supports downloading cohorts for local evaluation targeting. Configure the CohortSyncConfig option with the analytics ApiKey and SecretKey on initialization to enable this support.

client := local.Initialize("<DEPLOYMENT_KEY>", &local.Config{
  // (Recommended) Enable local evaluation cohort targeting.
  CohortSyncConfig: &local.CohortSyncConfig {
    ApiKey: "<API_KEY>",
    SecretKey: "<SECRET_KEY>"
  }
})

Custom logging

Control log verbosity with the LogLevel configuration, or implement the LoggerProvider interface to integrate your own logger.

Log levels

The SDK supports these log levels:

  • Verbose: Detailed logging for deep debugging
  • Debug: Logging for development and troubleshooting
  • Info: General informational messages
  • Warn: Warning messages
  • Error: Error messages (default)
  • Disable: No logging

Custom logger

Implement the LoggerProvider interface to integrate your logging solution:

import "github.com/amplitude/experiment-go-server/logger"

type MyCustomLogger struct {
    // Your logger implementation
}

func (l *MyCustomLogger) Verbose(message string, args ...interface{}) {
    // Implement verbose logging
}

func (l *MyCustomLogger) Debug(message string, args ...interface{}) {
    // Implement debug logging
}

func (l *MyCustomLogger) Info(message string, args ...interface{}) {
    // Implement info logging
}

func (l *MyCustomLogger) Warn(message string, args ...interface{}) {
    // Implement warn logging
}

func (l *MyCustomLogger) Error(message string, args ...interface{}) {
    // Implement error logging
}

// Initialize with custom logger
client := local.Initialize("<DEPLOYMENT_KEY>", &local.Config{
    LogLevel: logger.Debug,
    LoggerProvider: &MyCustomLogger{},
})

Backward compatibility

The Debug configuration field is still supported. When set to true, it overrides LogLevel to Debug.

Was this page helpful?

June 4th, 2024

Need help? Contact Support

Visit Amplitude.com

Have a look at the Amplitude Blog

Learn more at Amplitude Academy

© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.