Files
Beyhan Oğur 880f412e2c first commit
2026-04-26 21:52:23 +03:00

226 lines
6.4 KiB
Plaintext

---
title: "Maxim AI"
description: "Integrate Maxim SDK for comprehensive LLM observability, tracing, and evaluation."
icon: "infinity"
---
## Overview
Bifrost provides comprehensive LLM observability through the **Maxim plugin**, enabling seamless tracking, evaluation, and analysis of AI interactions. The plugin automatically forwards all LLM requests and responses to Maxim's platform for detailed monitoring and performance insights.
![Maxim Logs](https://github.com/maximhq/bifrost/blob/main/docs/media/maxim-logs.png?raw=true)
---
## Setup
The Maxim plugin enables seamless observability and evaluation of LLM interactions by forwarding inputs/outputs to Maxim's platform:
<Tabs group="setup-method">
<Tab title="Go SDK">
```go
package main
import (
"context"
bifrost "github.com/maximhq/bifrost/core"
"github.com/maximhq/bifrost/core/schemas"
maxim "github.com/maximhq/bifrost/plugins/maxim"
)
func main() {
// Initialize Maxim plugin
maximPlugin, err := maxim.Init(maxim.Config{
ApiKey: "your_maxim_api_key",
LogRepoId: "your_default_repo_id", // Optional: fallback repository
})
if err != nil {
panic(err)
}
// Initialize Bifrost with the plugin
client, err := bifrost.Init(context.Background(), schemas.BifrostConfig{
Account: &yourAccount,
LLMPlugins: []schemas.LLMPlugin{maximPlugin},
})
if err != nil {
panic(err)
}
defer client.Shutdown()
// All requests will now be traced to Maxim
}
```
</Tab>
<Tab title="config.json">
For HTTP transport, configure via environment variables:
```json
{
"plugins": [
{
"enabled": true,
"name": "maxim",
"config": {
"api_key": "your_maxim_api_key",
"log_repo_id": "your_default_repo_id"
}
}
]
}
```
</Tab>
</Tabs>
## Configuration
| Field | Type | Required | Description |
|-------|------|----------|-------------|
| `ApiKey` | `string` | ✅ Yes | Your Maxim API key for authentication |
| `LogRepoId` | `string` | ❌ No | Default log repository ID (can be overridden per request) |
## Repository Selection
The plugin uses repository selection with the following priority:
1. **Header/Context Repository** - Highest priority
2. **Default Repository** (from plugin config) - Fallback
3. **Skip Logging** - If neither is available
<Tabs group="repository-selection" >
<Tab title="Go SDK">
```go
ctx := context.Background()
// Use specific repository for this request
ctx = context.WithValue(ctx, maxim.LogRepoIDKey, "project-specific-repo")
```
</Tab>
<Tab title="Gateway">
```bash
# Use default repository (from config)
curl -X POST http://localhost:8080/v1/chat/completions \
-d '{"model": "gpt-4", "messages": [...]}'
# Override with specific repository
curl -X POST http://localhost:8080/v1/chat/completions \
-H "x-bf-maxim-log-repo-id: project-specific-repo" \
-d '{"model": "gpt-4", "messages": [...]}'
```
</Tab>
</Tabs>
## Custom Trace Management
### Trace Propagation
The plugin supports custom session, trace, and generation IDs for advanced tracing scenarios:
<Tabs group="trace-propagation">
<Tab title="Go SDK">
```go
ctx := context.Background()
// Prefer typed keys from the Maxim plugin
ctx = context.WithValue(ctx, maxim.TraceIDKey, "custom-trace-123")
ctx = context.WithValue(ctx, maxim.GenerationIDKey, "custom-gen-456")
ctx = context.WithValue(ctx, maxim.SessionIDKey, "user-session-789")
// Optionally set human-friendly names
ctx = context.WithValue(ctx, maxim.TraceNameKey, "checkout-flow")
ctx = context.WithValue(ctx, maxim.GenerationNameKey, "rerank-step")
```
</Tab>
<Tab title="Gateway">
```bash
curl -X POST http://localhost:8080/v1/chat/completions \
-H "x-bf-maxim-trace-id: custom-trace-123" \
-H "x-bf-maxim-generation-id: custom-gen-456" \
-H "x-bf-maxim-session-id: user-session-789" \
-H "x-bf-maxim-trace-name: checkout-flow" \
-H "x-bf-maxim-generation-name: rerank-step" \
-d '{"model": "gpt-4", "messages": [...]}'
```
</Tab>
</Tabs>
### Custom Tags
You can add custom tags to traces for enhanced filtering and analytics:
<Tabs group="custom-tags">
<Tab title="Go SDK">
```go
ctx := context.Background()
// Pass arbitrary tag key-values via context map
tags := map[string]string{
"environment": "production",
"user-id": "user-123",
"feature-flag": "new-ui",
}
ctx = context.WithValue(ctx, maxim.TagsKey, tags)
```
</Tab>
<Tab title="Gateway">
```bash
curl -X POST http://localhost:8080/v1/chat/completions \
-H "x-bf-maxim-environment: production" \
-H "x-bf-maxim-user-id: user-123" \
-H "x-bf-maxim-feature-flag: new-ui" \
-d '{"model": "gpt-4", "messages": [...]}'
```
Reserved keys are `session-id`, `trace-id`, `trace-name`, `generation-id`, `generation-name`, `log-repo-id`. All other `x-bf-maxim-*` headers are treated as tags.
</Tab>
</Tabs>
## Supported Request Types
The plugin supports the following Bifrost request types:
- Text Completion
- Chat Completion
## Monitoring & Analytics
Once configured, monitor your AI apps in the [Maxim Dashboard](https://getmaxim.ai/). Maxim is an end-to-end evaluation & observability platform built to help teams ship AI agents faster while maintaining high quality.
* **Experiment / Prompt Engineering**
Playground++ for prompt design: versioning, comparison (A/B), visual chaining, low-code tooling.
* **Simulation & Evaluation**
Test agents over thousands of scenarios, both automated (statistical, programmatic) and human-in-the-loop for edge cases. Custom and off-the-shelf evaluators.
* **Observability / Monitoring**
Real-time traces, logging, debugging of multi-agent workflows, live issue tracking, alerts when quality or performance degrade.
* **Data Engine & Dataset Management**
Support for multi-modal datasets, import & continuous curation, feedback/annotation pipelines, data splitting for experiments.
* **Governance, Security & Compliance**
Features like SOC 2 Type II compliance, enterprise security controls, permissions, auditability.
* **Alerts & SLAs**: Threshold-based notifications to keep quality and latency in guardrails
## Next Steps
Now that you have observability set up with the Maxim plugin, explore these related topics:
- **[Tracing](./default)** - Deep-dive into request/response logging and correlation
- **[Telemetry](../telemetry)** - Prometheus metrics, dashboards, and alerting
- **[Governance](../governance/virtual-keys)** - Virtual keys, per-team controls, and usage limits