internal/website/docs/ai-integration.md
Go Micro is an AI-native microservices framework. Every service you build is automatically accessible to AI agents, and every service can call AI models. This page explains how the pieces fit together.
Your Services → write Go handlers, register with the framework
↓
Registry → automatic service discovery (mDNS, Consul, etcd)
↓
Gateways → micro api (HTTP→RPC) / micro mcp (MCP tools)
↓
ai.Tools → discovers services + executes RPCs programmatically
↓
ai.Model → calls LLMs (Anthropic, OpenAI, Gemini, Atlas Cloud, ...)
↓
micro chat / ai/flow → interactive or event-driven orchestration
Every layer is optional. You can use go-micro without AI. You can use the ai package without MCP. But when you stack them, you get services that AI agents can discover and orchestrate automatically.
Write normal Go handlers. Add doc comments for AI tool descriptions:
// CreateUser creates a new user account.
// @example {"name": "Alice", "email": "[email protected]"}
func (h *Users) CreateUser(ctx context.Context, req *pb.CreateRequest, rsp *pb.CreateResponse) error {
// your business logic
}
The doc comment becomes the tool description. The @example tag gives the LLM a usage hint. No AI-specific code in your handler.
Services register automatically. The registry is the source of truth for what's running:
service := micro.New("users")
service.Handle(handler.New())
service.Run() // registers with the registry
Pluggable: mDNS (default, zero config), Consul, etcd, NATS.
The MCP gateway walks the registry and exposes every endpoint as a tool via the Model Context Protocol:
// One line to expose all services as AI tools
service := micro.New("myservice", mcp.WithMCP(":3001"))
Or run it standalone:
micro mcp serve # stdio for Claude Code
micro mcp serve --address :3000 # HTTP for web agents
Any MCP-compatible agent (Claude Code, ChatGPT, custom agents) can discover and call your services.
ai.Tools turns registered services into LLM-callable tools — discovery plus RPC execution in one type:
tools := ai.NewTools(service.Registry())
discovered, _ := tools.Discover() // []ai.Tool from all registered services
// Wire execution into a model with one option:
m := ai.New("anthropic", ai.WithAPIKey(key), ai.WithTools(tools))
This is what powers micro chat and the agent playground. You can use it directly in your own services to build agentic workflows.
The ai package provides a pluggable interface for calling LLMs:
import (
"go-micro.dev/v5/ai"
_ "go-micro.dev/v5/ai/anthropic"
)
m := ai.New("anthropic", ai.WithAPIKey(key))
resp, _ := m.Generate(ctx, &ai.Request{
Prompt: "What users are in the system?",
Tools: discovered, // from ai.Tools
})
Seven text providers, two image providers, one video provider. Same interface, swap with an import.
| Provider | Text | Image | Video |
|---|---|---|---|
| Anthropic | yes | ||
| OpenAI | yes | yes | |
| Google Gemini | yes | ||
| Atlas Cloud | yes | yes | yes |
| Groq | yes | ||
| Mistral | yes | ||
| Together AI | yes |
The CLI ties it all together — discovers services, builds the tool list, and lets you talk to your services:
ANTHROPIC_API_KEY=sk-ant-... micro chat --provider anthropic
> list all users
> send a welcome email to [email protected]
> create an order for product-42
Multi-turn conversation with ai.History — the model remembers context across turns. Type reset to clear history.
Subscribe to broker events and let an LLM orchestrate the response:
import "go-micro.dev/v5/ai/flow"
f := flow.New("onboard",
flow.Trigger("events.user.created"),
flow.Prompt("New user: {{.Data}}. Send welcome email and create workspace."),
flow.Provider("anthropic"),
flow.APIKey(key),
)
f.Register(service.Registry(), service.Options().Broker, service.Client())
Or from the CLI:
micro flow run --trigger events.user.created \
--prompt "New user: {{.Data}}. Send welcome email." \
--provider anthropic
micro flow exec --prompt "List all users" --provider anthropic
A standalone HTTP-to-RPC gateway for exposing services over HTTP without the full dashboard:
micro api # listen on :8080
micro api --address :3000 # custom port
# Call services through the gateway
curl -XPOST -d '{"name":"Alice"}' http://localhost:8080/greeter/Greeter.Hello
The fastest path:
# Create a service with MCP enabled
micro new myservice --template crud
cd myservice
# Run it
micro run
# Chat with it
ANTHROPIC_API_KEY=sk-ant-... micro chat --provider anthropic
> list all records
See also: