当前位置: 首页 > news >正文

golang使用stdio与子进程进行通信

在使用Cline调用本地MCP Server的时候,使用的是STDIO模式,也就是Cline启动一个子进程来运行MCP Server,然后通过STDIO来进行通信。这种方式即高效又安全。

import ("bufio""fmt""io""os/exec""time"
)func Run() {// 定义要执行的命令(例如:运行一个 Python 脚本)cmd := exec.Command("python", "-u", "-c", `user_input = input(); print("child get message: " + user_input)`)// 获取子进程的标准输入、输出和错误流stdin, err := cmd.StdinPipe()if err != nil {fmt.Println("Error creating stdin pipe:", err)return}defer stdin.Close()stdout, err := cmd.StdoutPipe()if err != nil {fmt.Println("Error creating stdout pipe:", err)return}// 启动子进程,异步的方式执行命令if err := cmd.Start(); err != nil {fmt.Println("Error starting command:", err)return}// 使用 bufio 读取子进程的输出go func() {reader := bufio.NewReader(stdout)for {line, err := reader.ReadString('\n')if err != nil && err != io.EOF {fmt.Println("Error reading from stdout:", err)break}if line != "" {fmt.Print(line)}if err == io.EOF {break}}}()// 向子进程的标准输入写入数据input := "Hello from Go!\n"fmt.Fprintf(stdin, input)// 等待子进程结束if err := cmd.Wait(); err != nil {fmt.Println("Error waiting for command:", err)}time.Sleep(3 * time.Second)
}

运行程序输出:child get message: Hello from Go!

相关文章:

  • Nyquist frequency Nyquist rate
  • 相机内参标定
  • TDengine 与其他时序数据库对比:InfluxDB/TimescaleDB 选型指南(二)
  • 道可云人工智能每日资讯|首届世界人工智能电影节在法国尼斯举行
  • 《直线编码器:精密制造的“隐形导航者”》
  • 笔试练习day17
  • C# 经纬度坐标的精度及WGS84(谷歌)、GCJ02(高德)、BD09(百度)坐标相互转换(含高精度转换)
  • Java 如何处理UnresolvedAddressException异常
  • 虚拟机中安装欧拉系统(EulerOS)后如何正确设置IP地址
  • Android studio配置Flutter遇到的问题总结
  • 数据结构入门:线性表(Day 1)——从原理到代码实战
  • STL c++ 详解——stack与queue模拟实现与deque的介绍
  • 【Sequelize】
  • 地理人工智能中位置编码的综述:方法与应用
  • VMware下Ubuntu空间扩容
  • 开展东南亚货运专线业务,有哪家系统提高管理效率?
  • flutter json解析增强
  • Android 9.0系统源码定制:实现开机启动特定App的全面指南
  • 《分布式软总线:不同频段Wi-Fi环境下设备发现兼容性难题》
  • leetcode面试经典算法题——2
  • IPO周报|节后首批3只新股本周申购,色谱设备龙头来了
  • 观察|“离境退税”撬动上海“五一”假期入境消费
  • 长三角铁路持续迎五一出行高峰:今日预计发送旅客418万人次
  • 空调+零食助顶级赛马备战,上海环球马术冠军赛将焕新登场
  • 摩天大楼天津117大厦复工背后:停工近十年,未知挑战和压力仍在
  • 浪尖计划再出发:万亿之城2030课题组赴九城调研万亿产业