位置: 编程技术 - 正文

浅谈Node Inspector 代理实现(浅谈幼儿良好行为的培养论文)

编辑:rootadmin

推荐整理分享浅谈Node Inspector 代理实现(浅谈幼儿良好行为的培养论文),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:浅谈一下新冠的好处,浅谈特殊儿童的融合教育论文,浅谈如何培养孩子的注意力,浅谈双减背景下的高效课堂,浅谈建筑地基基础加固施工技术亲,浅谈特殊儿童的融合教育论文,浅谈建筑地基基础加固施工技术亲,浅谈如何培养孩子的注意力,内容如对您有帮助,希望把文章链接给更多的朋友!

背景

平时做 node 开发的时候,通过 node inspector 来进行断点调试是一个很常用的 debug 方式。但是有几个问题会导致我们的调试效率降低。

问题一:当使用 vscode 进行断点调试时,如果应用是通过 cluster 启动的 inspector,那么每次当 worker 挂了重启后,inspector 的端口都会自增。虽然在 node8.x 版本中可以指定 inspectPort 固定调试端口,但是在 node6.x 中是不支持的。这样会导致每次 worker 重启了就得在 vscode 中重新指定调试端口。

问题二:当使用 devtools 调试的时候,每次调试都需要拷贝 devtools 链接到 chrome 上调试,而上面说的端口变更问题则会导致 devtools 的链接变更,除此之外,每次重新启动 inspector 也会导致 devtools 的链接变更,因为 websocket id 变了。

而把上面的两个问题简化一下就是:

在 vscode 中调试,在 inspector 端口变更或者 websocket id 变更后能够重连。 在 devtools 中调试,在 inspector 端口变更或者 websocket id 变更后能够重连。

解决方案

目前业界已经有解决方案就是 chrome 插件 Node Inspector Manager(Nim) ,不过这个只能解决在同个 inspector 端口下的应用重启后链接更改的问题,却无法解决 cluster 启动导致的端口自增问题,除非在 Nim 中提前指定好多个端口,再者 Nim 是 chrome 上的插件,对于在 vscode 中的调试却无能为力了。

所以最佳的解决方案自然是使用 node 来做 inspector 代理,解决方案如下:

对于第一个问题,在 vscode 上,它是会自己去调用 /json 接口获取最新的 websocket id,然后使用新的 websocket id 连接到 node inspector 服务上。因此解决方法就是实现一个 tcp 代理功能做数据转发即可。

对于第二个问题,由于 devtools 是不会自动去获取新的 websocket id 的,所以我们需要做动态替换,所以解决方案就是代理服务去 /json 获取 websocket id,然后在 websocket 握手的时候将 websocket id 进行动态替换到请求头上。

画了一张流程图:

实现步骤

一、Tcp 代理

首先,先实现一个 tcp 代理的功能,其实很简单,就是通过 node 的 net 模块创建一个代理端口的 Tcp Server,然后当有连接过来的时候,再创建一个连接到目标端口即可,然后就可以进行数据的转发了。

简易的实现如下:

浅谈Node Inspector 代理实现(浅谈幼儿良好行为的培养论文)

上面实现了比较简单的一个代理服务,通过 pipe 方法将两个服务的数据连通起来。client 有数据的时候会被转发到 server 中,server 有数据的时候也会转发到 client 中。

当完成这个 Tcp 代理功能之后,就已经可以实现 vscode 的调试需求了,在 vscode 中项目下 launch.json 中指定端口为代理端口,在 configurations 中添加配置

那么当应用重启,或者更换 inspect 的端口,vscode 都能自动重新通过代理端口 attach 到你的应用。

二、获取 websocketId

这一步开始,就是为了解决 devtools 链接不变的情况下能够重新 attach 的问题了,在启动 node inspector server 的时候,inspector 服务还提供了一个 /json 的 http 接口用来获取 websocket id。

这个就相当简单了,直接发个 http 请求到目标端口的 /json,就可以获取到数据了:

上面数据中的 id 字段,就是我们需要的 websocket id 了。

三、Inspector 代理

拿到了 websocket id 后,就可以在 tcp 代理中做 websocket id 的动态替换了,首先我们需要固定链接,因此先定一个代理链接,比如我的代理服务端口是 ,那么 chrome devtools 的代理链接就是:

chrome- ws=.0.0.1:/__ws_proxy__ 其他都是固定的,而最后这个也一眼就可以看出来是 websocket 的链接。其中 __ws_proxy__则是用来占位的,用于在 chrome devtools 向这个代理链接发起 websocket 握手请求的时候,将 __ws_proxy__ 替换成 websocket id 然后转发到 node 的 inspector 服务上。

对上面的 tcp 代理中的 pipe 逻辑的代码做一些小修改即可。

通过 through2 创建一个 transform 流来对传输的数据进行一下更改。

简单判断一下 chunk 的头三个字节是否为GET,如果是 GET 说明这可能是个 http 请求,也就可能是 websocket 的协议升级请求。把请求头打印出来就是这个样子的:

然后将其中的路径/__ws_proxy替换成对应的 websocketId,然后转发到 node 的 inspector server 上,即可完成 websocket 的握手,接下来的 websocket 通信就不需要对数据做处理,直接转发即可。

接下来就算各种重启应用,或者更换 inspector 的端口,都不需要更换 debug 链接,只需要再 inspector server 重启的时候,在下图的弹窗中

点击一下 Reconnect DevTools 即可恢复 debug。

最后

上面的详细代码可以在下面的 git 中找到:

Tcp 代理: Inspector 代理:

标签: 浅谈幼儿良好行为的培养论文

本文链接地址:https://www.jiuchutong.com/biancheng/379468.html 转载请保留说明!

上一篇:Node做中转服务器转发接口(node转go)

下一篇:pm2 部署 node的三种方法示例(pm2启动nodejs)

  • 报完增值税就要清卡吗
  • 消防维保技术服务承诺书
  • 缴纳房产税怎么记账
  • 发票税率开错了怎么办
  • 二手房缴纳个税是买方缴还是卖方缴?
  • 开具技术服务费发票需要注意什么
  • 宣传费属于什么税目
  • 公司注销公司帐户剩的钱怎么办
  • 小规模纳税检查怎么做
  • 商业保险可以抵扣增值税吗
  • 进口设备贴息政策2019
  • 原材料出现贷方余额
  • 付给供应商远期延期支票怎么做账?
  • 事业单位经营结余为负数的原因
  • 出售全资子公司合并报表怎么做
  • 应交税金明细账余额怎么算
  • 什么情况下发票不能冲红
  • 增值税普票丢失发票联能重开吗
  • 公司名下的车怎么报废
  • 建筑工程安装合同
  • 滴滴出行客运服务费 事业单位 报销
  • 离线开票时间超限怎么办 发票都已经报送
  • 预估材料入账后冲回的步骤
  • 应向客户收取的出租包装物租金
  • 收到上月发票怎么写分录
  • 装修公司什么要自己买
  • 新版edge浏览器历史记录
  • 公司暂估成本过高,如何处理
  • 为什么盈余公积补亏不会影响留存收益
  • 税会差异分为哪几类
  • P2PNetworking3.exe - P2PNetworking3是什么进程 有什么用
  • yii实现使用CUploadedFile上传文件的方法
  • php xml
  • 怎么用云服务
  • php实现分页显示
  • 收到外汇货款
  • 采购材料尚未入库款未付的记账凭证
  • 小程序从入门到精通
  • 增值税专用发票有几联?
  • 浅谈一下新冠的好处
  • CV攻城狮入门VIT(vision transformer)之旅——VIT原理详解篇
  • 补提企业所得税财务报表应该如何调整
  • 帝国cms生成app
  • MicrosoftSQLserver2014
  • 企业进出口贸易
  • 无形资产减值准备是什么科目
  • 承兑汇票是属于什么科目
  • 暂存的凭证是怎么做的
  • 增值税是否计入在建工程
  • 小微企业免税销售额和其他免税销售额的区别
  • 农村信用社可计算利息吗
  • 年底做账流程
  • 开具信用证的费用能开专票吗
  • 计提折旧,生成折旧分摊凭证步骤
  • 当月管理费用为负数
  • 如何制作u盘系统win7
  • 由于这台计算机没有远程客户端访问许可证
  • 优盘安装xp
  • 怎么检测软件有没有毒
  • 用户请愿地址曝露怎么办
  • win7如何设置电脑输入法
  • win7电脑连不上wifi怎么解决
  • mac通知中心设置方法
  • centos7ftp
  • windows 7中,执行应用程序的方法有哪几种?
  • win10时间不见了怎么办
  • win8开机直接进入传统桌面
  • 第四章之BootStrap表单与图片
  • 通过制作日晷我们可以探索发现一天之中
  • nodejs vue
  • android中启动service的方法有
  • dom的操作
  • unity3drpg游戏
  • jquery导入
  • 安卓的生命周期方法
  • 电子发票怎么汇总清卡
  • 个人所得税app怎么更改手机号码
  • 宁波税务总局官网
  • 农业方面有哪些专业
  • 国家重大水利工程建设基金征收标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设