Go语言Stdio传输MCP Server示例【Cline、Roo Code】

Go语言 Stdio 传输 MCP Server 示例

AI 应用开发正处于加速发展阶段,新技术和新方法不断涌现。Model Context Protocol (MCP) 作为一个开放标准,正在改变 AI 应用与数据源和工具集成的方式。

Go-MCP 是一个 MCP 协议的 GO 实现,此 SDK 采用清晰的分层架构设计,确保代码模块化、可扩展性和可维护性。通过深入了解这一架构,开发者可以更好地利用 Go-MCP 的所有功能,甚至根据自己的需求进行定制和扩展。

https://github.com/ThinkInAIXYZ/go-mcp

Go-MCP 的架构可以抽象为三个主要层次:

  1. 传输层(Transport Layer):处理底层通信,支持不同的传输协议;
  2. 协议层(Protocol Layer):实现所有 MCP 协议数据结构定义;
  3. 用户层(User Layer):包括服务器和客户端实现,提供面向用户的 API。

这种分层设计使各层彼此解耦,允许独立演化和替换,同时保持整体功能一致性。

Jack码原理说明

Jack码是一种基于北京时间的编码方式,具体规则如下:

  1. 获取当前北京时间,格式为 yyyyMMddHHmm,如 202505050829,类型为 int64。
  2. 将该时间值加上常数 1314520
  3. 对结果进行 Base64 编码,得到最终的 Jack码。

示例:

  • 当前北京时间:2025年5月5日08时29分 → 202505050829

  • 加上常数:202505050829 + 1314520 = 202506865349

  • Base64 编码:MjAyNTA2ODY1MzQ5

(以上内容是作者为了练习开发一个自定义MCP服务临时想出的概念,仅供娱乐)

代码实现

复制代码
go mod init jack_stdio_server

main.go

go 复制代码
package main

import (
	"context"
	"encoding/base64"
	"fmt"
	"strconv"
	"time"

	"github.com/ThinkInAIXYZ/go-mcp/protocol"
	"github.com/ThinkInAIXYZ/go-mcp/server"
	"github.com/ThinkInAIXYZ/go-mcp/transport"
)

type JackRequest struct{}

func handleJackRequest(ctx context.Context, req *protocol.CallToolRequest) (*protocol.CallToolResult, error) {
	// 解析参数(如有)
	// 获取当前北京时间
	now := time.Now().In(time.FixedZone("CST", 8*3600))
	base := now.Format("200601021504")
	baseInt, err := strconv.Atoi(base)
	if err != nil {
		return nil, err
	}
	jackValue := baseInt + 1314520
	jackStr := strconv.Itoa(jackValue)
	jackCode := base64.StdEncoding.EncodeToString([]byte(jackStr))
	// 构造文本内容
	content := &protocol.TextContent{
		Type: "text",
		Text: fmt.Sprintf("Jack码: %s\n原始值: %s\n基准时间: %s", jackCode, jackStr, base),
	}
	// 返回结果,Content 字段为 Content 接口切片
	return &protocol.CallToolResult{
		Content: []protocol.Content{content},
		IsError: false,
	}, nil
}

func main() {
	transportServer := transport.NewStdioServerTransport()
	mcpServer, _ := server.NewServer(transportServer)
	tool, _ := protocol.NewTool("get_jack_code", "获取当前Jack码", JackRequest{})
	mcpServer.RegisterTool(tool, handleJackRequest)
	mcpServer.Run()
}

go.mod

复制代码
module jack_stdio_server

go 1.24.1

require github.com/ThinkInAIXYZ/go-mcp v0.2.2

require (
	github.com/google/uuid v1.6.0 // indirect
	github.com/orcaman/concurrent-map/v2 v2.0.1 // indirect
	github.com/tidwall/gjson v1.18.0 // indirect
	github.com/tidwall/match v1.1.1 // indirect
	github.com/tidwall/pretty v1.2.0 // indirect
	github.com/yosida95/uritemplate/v3 v3.0.2 // indirect
)

然后编译

复制代码
go mod tidy
go build

Cline (Roo Code)配置mcp Json文件(Windows)

json 复制代码
{
  "mcpServers": {
    "jack_stdio": {
      "command": "./jack_stdio_server.exe",
      "args": [],
      "env": {},
      "disabled": false,
      "autoApprove": [],
      "alwaysAllow": []
    }
  }
}

如果mcp服务文件不在项目目录下的话请写完整路径,如C:\\mcpServer\\jack_stdio_server.exe

配置好后提问AI:

复制代码
当前的jack码是多少?

AI:

相关推荐
weixin_472339462 小时前
高效处理大体积Excel文件的Java技术方案解析
java·开发语言·excel
枯萎穿心攻击2 小时前
响应式编程入门教程第二节:构建 ObservableProperty<T> — 封装 ReactiveProperty 的高级用法
开发语言·unity·c#·游戏引擎
Eiceblue4 小时前
【免费.NET方案】CSV到PDF与DataTable的快速转换
开发语言·pdf·c#·.net
tan180°4 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
m0_555762904 小时前
Matlab 频谱分析 (Spectral Analysis)
开发语言·matlab
浪裡遊5 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
优创学社25 小时前
基于springboot的社区生鲜团购系统
java·spring boot·后端
why技术5 小时前
Stack Overflow,轰然倒下!
前端·人工智能·后端
幽络源小助理5 小时前
SpringBoot基于Mysql的商业辅助决策系统设计与实现
java·vue.js·spring boot·后端·mysql·spring
lzb_kkk6 小时前
【C++】C++四种类型转换操作符详解
开发语言·c++·windows·1024程序员节