标准输入输出stdio和JSON-RPC

stdio的基本概念

标准输入输出stdio是进程间的一种通讯协议,类似于http通讯协议但是stdio只能运行在本地。

stdio主要有三个通道:stdout,stdin,stderr

stderr指的是异常处理

node案例

这里只要用node做示范

下方是一个简单标准输出的

server.js

javascript 复制代码
process.stdout.write("Hellow word!")

我们现在在终端里执行查看进程id的命令,可以看到当前进程的id为14400

bash 复制代码
tasklist | findstr cmd.exe

我们获取一下node服务进程的进程id

js 复制代码
process.stdout.write(process.pid + '\n')

我们可以发现终端窗口的进程和node服务的进程id不一致这是当然的。

那为什么我在node进程里打印或者输出的内容会显示在终端窗口中?

终端和node进程的通讯过程

可以想象的到终端窗口和node服务这两个进程之间肯定产生了联系,上面这段代码的实际含义是:在终端输入node server.js创建了一个node服务进程,然后在node服务中使用process.stdout.write标准输出结果,终端进程会监听子进程的输出结果然后打印在自己的窗口中

当然我们也可以反过来j监听父进程的输入

我们会发现执行下面这段代码后终端不会直接返回结果可以一直输入这是因为进程有监听服务不会里面返回结果

js 复制代码
process.stdin.on('data',(data) => {
    process.stdout.write(data + '\n')
})
node模拟步骤

我们也可以使用node来直接模拟这种情况

1、创建文件我们使用server.js来启用utils.js

可以看到直接执行utils.js进程才能在窗口打印内容

utils.js

js 复制代码
process.stdout.write("utils.js")

server.js

js 复制代码
const { spawn } = require("node:child_process")
spawn("node",["utils.js"])

2、将通过server.js启用的utils.js打印的内容展示在终端中

修改server.js文件的代码设置监听子进程输出内容

js 复制代码
const { spawn } = require("node:child_process")
const childProcess = spawn("node",["utils.js"])
childProcess.stdout.on("data",(data) => {
    process.stdout.write(data)
})

3、通过代码来操作进程的输入和输出

正常用户使用应用时肯定不可能通过终端操作

现在模型一下通过代码控制进程的输入输出

逐步打印数组中内容

server.js

js 复制代码
const { spawn } = require("node:child_process")
const childProcess = spawn("node",["utils.js"])
childProcess.stdout.on("data",(data) => {
    process.stdout.write(data)
})
const _temp = ['ask','me','why']
_temp.forEach((msg,index) => {
    setTimeout(() => {
        childProcess.stdin.write(msg + '\n')
    }, index * 1000);
})
js 复制代码
process.stdin.on("data",(data) => {
    process.stdout.write(data)
})

从这些案例中可以了解进程之间通讯的一些过程和输入、输出的一些方式

JSON-RPC的基本概念

模型上下文协议(MCP)中的传输为客户端和服务器之间的通信提供基础。传输层负责处理消息如何发送和接收的底层机制。

简单来说就是进程之间通讯输入参数和返回值(输出)格式规范

jsonrpc代表版本(2.0)

id:请求编号用来将输入和输出对应起来

method:方法名称

params:请求参数

result:返回结果

error:错误信息

请求

js 复制代码
{
  jsonrpc: "2.0",
  id: number | string,
  method: string,
  params?: object
}

响应

js 复制代码
{
  jsonrpc: "2.0",
  id: number | string,
  result?: object,
  error?: {
    code: number,
    message: string,
    data?: unknown
  }
}

server.js

js 复制代码
const {
    spawn
} = require("node:child_process")


const childProcess = spawn("node", ["utils.js"])
var obj = {
    jsonrpc: "2.0",
    id: 1,
    method: 'sum',
    params: {
        a: 1,
        b: 2
    }
}
process.stdout.write(JSON.stringify(obj))

childProcess.stdout.on("data", (data) => {
    process.stdout.write(data)
})

utils.js

js 复制代码
function sum(a, b) {
    return a + b
}
process.stdin.on("data", (data) => {
    var obj = JSON.parse(data)
    switch (obj.method) {
        case "sum":
            var _temp = {
                jsonrpc: "2.0",
                id: obj.id,
                result: sum(obj.params.a, obj.params.b),
            }
            process.stdout.write(JSON.stringify(_temp))
            break;
    }
})
相关推荐
我命由我123453 小时前
Java 开发 - 粘包处理器 - 基于消息头 + 消息体(魔数验证、长度验证)
java·网络·后端·网络协议·java-ee·intellij-idea·intellij idea
小糖学代码3 小时前
网络:5.应用层协议HTTP
网络·网络协议·http
liu****7 小时前
18.HTTP协议(一)
linux·网络·网络协议·http·udp·1024程序员节
拾忆,想起8 小时前
Dubbo异步调用实战指南:提升微服务并发性能
java·服务器·网络协议·微服务·云原生·架构·dubbo
阿巴~阿巴~14 小时前
基于UDP协议的英汉翻译服务系统:从网络通信到字典查询的完整机制
linux·服务器·网络·网络协议·udp协议·套接字绑定·英汉翻译服务系统
another heaven15 小时前
【计算机网络 HTTP 请求参数规范详解】
网络协议·计算机网络·http
慧慧吖@17 小时前
sse,短轮询,长轮询,webSocket
网络·websocket·网络协议
littlepeanut.top18 小时前
C++中将FlatBuffers序列化为JSON
开发语言·c++·json·flatbuffers
AiXed21 小时前
PC微信协议之nid算法
python·网络协议·算法·微信