modelcontextprotocol/go-sdk
{ "createdAt": "2025-04-23T10:07:33Z", "defaultBranch": "main", "description": "The official Go SDK for Model Context Protocol servers and clients. Maintained in collaboration with Google.", "fullName": "modelcontextprotocol/go-sdk", "homepage": "", "language": "Go", "name": "go-sdk", "pushedAt": "2025-11-26T15:27:32Z", "stargazersCount": 3201, "topics": [], "updatedAt": "2025-11-27T06:05:56Z", "url": "https://github.com/modelcontextprotocol/go-sdk"}MCP Go SDK
Section titled “MCP Go SDK”This repository contains an implementation of the official Go software development kit (SDK) for the Model Context Protocol (MCP).
Package / Feature documentation
Section titled “Package / Feature documentation”The SDK consists of several importable packages:
- The
github.com/modelcontextprotocol/go-sdk/mcppackage defines the primary APIs for constructing and using MCP clients and servers. - The
github.com/modelcontextprotocol/go-sdk/jsonrpcpackage is for users implementing their own transports. - The
github.com/modelcontextprotocol/go-sdk/authpackage provides some primitives for supporting OAuth. - The
github.com/modelcontextprotocol/go-sdk/oauthexpackage provides extensions to the OAuth protocol, such as ProtectedResourceMetadata.
The SDK endeavors to implement the full MCP spec. The [docs/]!(/docs/) directory
contains feature documentation, mapping the MCP spec to the packages above.
Getting started
Section titled “Getting started”To get started creating an MCP server, create an mcp.Server instance, add
features to it, and then run it over an mcp.Transport. For example, this
server adds a single simple tool, and then connects it to clients over
stdin/stdout:
package main
import ( "context" "log"
"github.com/modelcontextprotocol/go-sdk/mcp")
type Input struct { Name string `json:"name" jsonschema:"the name of the person to greet"`}
type Output struct { Greeting string `json:"greeting" jsonschema:"the greeting to tell to the user"`}
func SayHi(ctx context.Context, req *mcp.CallToolRequest, input Input) ( *mcp.CallToolResult, Output, error,) { return nil, Output{Greeting: "Hi " + input.Name}, nil}
func main() { // Create a server with a single tool. server := mcp.NewServer(&mcp.Implementation{Name: "greeter", Version: "v1.0.0"}, nil) mcp.AddTool(server, &mcp.Tool{Name: "greet", Description: "say hi"}, SayHi) // Run the server over stdin/stdout, until the client disconnects. if err := server.Run(context.Background(), &mcp.StdioTransport{}); err != nil { log.Fatal(err) }}To communicate with that server, create an mcp.Client and connect it to the
corresponding server, by running the server command and communicating over its
stdin/stdout:
package main
import ( "context" "log" "os/exec"
"github.com/modelcontextprotocol/go-sdk/mcp")
func main() { ctx := context.Background()
// Create a new client, with no features. client := mcp.NewClient(&mcp.Implementation{Name: "mcp-client", Version: "v1.0.0"}, nil)
// Connect to a server over stdin/stdout. transport := &mcp.CommandTransport{Command: exec.Command("myserver")} session, err := client.Connect(ctx, transport, nil) if err != nil { log.Fatal(err) } defer session.Close()
// Call a tool on the server. params := &mcp.CallToolParams{ Name: "greet", Arguments: map[string]any{"name": "you"}, } res, err := session.CallTool(ctx, params) if err != nil { log.Fatalf("CallTool failed: %v", err) } if res.IsError { log.Fatal("tool failed") } for _, c := range res.Content { log.Print(c.(*mcp.TextContent).Text) }}The [examples/]!(/examples/) directory contains more example clients and
servers.
Contributing
Section titled “Contributing”We welcome contributions to the SDK! Please see [CONTRIBUTING.md]!(/CONTRIBUTING.md) for details of how to contribute.
Acknowledgements / Alternatives
Section titled “Acknowledgements / Alternatives”Several third party Go MCP SDKs inspired the development and design of this official SDK, and continue to be viable alternatives, notably mcp-go, originally authored by Ed Zynda. We are grateful to Ed as well as the other contributors to mcp-go, and to authors and contributors of other SDKs such as mcp-golang and go-mcp. Thanks to their work, there is a thriving ecosystem of Go MCP clients and servers.
License
Section titled “License”This project is licensed under the MIT License - see the [LICENSE]!(./LICENSE) file for details.