- Explore MCP Servers
- langchaingo-mcp-adapter
Langchaingo Mcp Adapter
What is Langchaingo Mcp Adapter
langchaingo-mcp-adapter is a Go adapter that connects LangChain Go tools with Model Context Protocol (MCP) servers, enabling seamless integration of MCP tools into the LangChain Go library.
Use cases
Use cases include building AI agents that utilize tools from MCP servers, integrating external tools into LangChain Go applications, and enhancing functionality in AI-driven projects.
How to use
To use langchaingo-mcp-adapter, install it via ‘go get github.com/i2y/langchaingo-mcp-adapter’, create an MCP client, and initialize the adapter to access MCP tools for use with LangChain Go.
Key features
Key features include the ability to connect to any MCP server, automatic discovery of MCP tools, and wrapping MCP tools as LangChain Go tools for easy integration.
Where to use
langchaingo-mcp-adapter can be used in various fields such as AI development, tool integration, and applications that require interaction with MCP servers.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Overview
What is Langchaingo Mcp Adapter
langchaingo-mcp-adapter is a Go adapter that connects LangChain Go tools with Model Context Protocol (MCP) servers, enabling seamless integration of MCP tools into the LangChain Go library.
Use cases
Use cases include building AI agents that utilize tools from MCP servers, integrating external tools into LangChain Go applications, and enhancing functionality in AI-driven projects.
How to use
To use langchaingo-mcp-adapter, install it via ‘go get github.com/i2y/langchaingo-mcp-adapter’, create an MCP client, and initialize the adapter to access MCP tools for use with LangChain Go.
Key features
Key features include the ability to connect to any MCP server, automatic discovery of MCP tools, and wrapping MCP tools as LangChain Go tools for easy integration.
Where to use
langchaingo-mcp-adapter can be used in various fields such as AI development, tool integration, and applications that require interaction with MCP servers.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Content
LangChainGo MCP Adapter
A Go adapter that bridges LangChain Go tools with Model Context Protocol (MCP) servers.
Overview
This adapter allows you to use tools defined on an MCP server with the LangChain Go library. It implements the necessary interfaces to integrate MCP tools seamlessly with LangChain Go’s agent infrastructure.
Features
- Connect to any MCP server
- Automatically discover MCP tools from a specified MCP server and make them available to LangChain Go
- Wrap MCP tools as LangChain Go tools
Installation
go get github.com/i2y/langchaingo-mcp-adapter
Usage
package main
import (
"context"
"log"
"os"
"github.com/i2y/langchaingo-mcp-adapter"
"github.com/mark3labs/mcp-go/client"
"github.com/tmc/langchaingo/agents"
"github.com/tmc/langchaingo/chains"
"github.com/tmc/langchaingo/llms/googleai"
"github.com/tmc/langchaingo/tools"
)
func main() {
// Create an MCP client using stdio
mcpClient, err := client.NewStdioMCPClient(
"./an-mcp-server", // Path to an MCP server executable
nil, // Additional environment variables if needed
)
if err != nil {
log.Fatalf("Failed to create MCP client: %v", err)
}
defer mcpClient.Close()
// Create the adapter
adapter, err := langchaingo_mcp_adapter.New(mcpClient)
if err != nil {
log.Fatalf("Failed to create adapter: %v", err)
}
// Get all tools from MCP server
mcpTools, err := adapter.Tools()
if err != nil {
log.Fatalf("Failed to get tools: %v", err)
}
ctx := context.Background()
// Create a Google AI LLM client
llm, err := googleai.New(
ctx,
googleai.WithDefaultModel("gemini-2.0-flash"),
googleai.WithAPIKey(os.Getenv("GOOGLE_API_KEY")),
)
if err != nil {
log.Fatalf("Create Google AI client: %v", err)
}
// Create a agent with the tools
agent := agents.NewOneShotAgent(
llm,
mcpTools,
agents.WithMaxIterations(3),
)
executor := agents.NewExecutor(agent)
// Use the agent
question := "Can you help me analyze this data using the available tools?"
result, err := chains.Run(
ctx,
executor,
question,
)
if err != nil {
log.Fatalf("Agent execution error: %v", err)
}
log.Printf("Agent result: %s", result)
}
Example Applications
See the example directory for complete examples:
example/agent: Demonstrates how to use the adapter with various LLM providers (Google AI, OpenAI, Anthropic)example/server: A minimal MCP server example that provides a URL fetching tool
The example agent supports multiple LLM providers:
- Google AI (Gemini): Set
GOOGLE_API_KEY - OpenAI: Set
OPENAI_API_KEY - Anthropic (Claude): Set
ANTHROPIC_API_KEY
The example is cross-platform and works on Windows, macOS, and Linux. The example automatically builds and runs the MCP server from source. See the example README for detailed setup instructions.
The mcp-curl server in this sample is based on the code from this blog.
Requirements
- Go 1.23 or higher
- tmc/langchaingo
- mark3labs/mcp-go
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Dev Tools Supporting MCP
The following are the main code editors that support the Model Context Protocol. Click the link to visit the official website for more information.










