当前位置:首页 > 科技  > 软件

如何实现并部署自己的Npm解析服务

来源: 责编: 时间:2023-10-08 10:00:03 438观看
导读大家好,我卡颂。你是否好奇 —— codesandbox是如何在线运行代码的?要回答这个问题,我们先看看前端项目是如何在本地跑起来的。简单来说分为3步:执行npm install安装依赖。使用打包工具(比如webpack)打包、编译代码(如果使用

jT128资讯网——每日最新资讯28at.com

大家好,我卡颂。jT128资讯网——每日最新资讯28at.com

你是否好奇 —— codesandbox是如何在线运行代码的?jT128资讯网——每日最新资讯28at.com

要回答这个问题,我们先看看前端项目是如何在本地跑起来的。简单来说分为3步:jT128资讯网——每日最新资讯28at.com

  • 执行npm install安装依赖。
  • 使用打包工具(比如webpack)打包、编译代码(如果使用Vite会省去打包的步骤,但会执行「预构建」)。
  • 将步骤2的产物通过script标签注入页面。

codesandbox能在线运行代码,显然他也实现了上述步骤,具体来说,codesandbox内置了2个在线服务:jT128资讯网——每日最新资讯28at.com

  • npm解析服务 —— 用于实现上述步骤1。
  • 在线打包服务 —— 用于实现上述步骤2、3。

本文我们来聊聊如何实现并部署自己的npm解析服务。jT128资讯网——每日最新资讯28at.com

codesandbox简要工作原理

下面是一个常见的codesandbox界面,包含两部分:jT128资讯网——每日最新资讯28at.com

  • 左边的文件系统、代码编辑器。
  • 右边的效果预览区域。

jT128资讯网——每日最新资讯28at.com

其中「效果预览区域」是一个iframe,对于上图中的例子,iframe的地址是https://pjdp86.csb.app/。如果你打开这个地址,会发现他就是代码的预览效果:jT128资讯网——每日最新资讯28at.com

jT128资讯网——每日最新资讯28at.com

但这并不意味着codesandbox帮我们部署了项目。实际上,这个地址中前端代码是在页面打开后再编译、打包的。jT128资讯网——每日最新资讯28at.com

打开codesandbox项目时经常看到的下述界面,就是前端编译代码的画面:jT128资讯网——每日最新资讯28at.com

jT128资讯网——每日最新资讯28at.com

具体来说,当我们打开一个codesandbox项目,iframe对应地址初始化时,会执行如下操作:jT128资讯网——每日最新资讯28at.com

  • 下载项目代码(即编辑器中显示的代码)。
  • 根据项目package.json中指明的依赖,从「npm解析服务」下载项目依赖的代码。
  • 下载在线打包器(一个mini webpack)、编译器(babel)相关代码。
  • 在线打包、编译。
  • 运行打包后的代码。

正是有了在线打包、编译的流程,codesandbox才能在线运行:jT128资讯网——每日最新资讯28at.com

  • React项目(需要编译JSX)。
  • TS项目(需要编译TS语法)。
  • Vue项目(需要编译SFC文件)。

回到本文的主题 —— 「npm解析服务」。当我们从项目package.json中获取到依赖库的名称后,完全可以从CDN直接请求依赖库对应的代码,为什么还需要一个独立的「npm解析服务」呢?jT128资讯网——每日最新资讯28at.com

npm解析服务的作用

之所以需要独立的「npm解析服务」,主要是因为 —— npm包本身可能还依赖别的npm包,如果每次初始化iframe时依次下载:jT128资讯网——每日最新资讯28at.com

  • package.json中指定的依赖
  • 依赖的依赖
  • 依赖的依赖的依赖
  • ...

那会极大拖慢项目初始化的时间。同时,这样做也可能会下载大量实际不会使用的代码。jT128资讯网——每日最新资讯28at.com

所以,需要一个「npm解析服务」,当第一个用户第一次请求某个库时,依次完成:jT128资讯网——每日最新资讯28at.com

  • 从库的入口代码解析AST,分析其中的require语句,递归的解析这个库的依赖。
  • 下载依赖代码,将所有依赖的代码汇总到一个JSON文件。
  • 将步骤2的JSON文件保存在对象存储中。
  • 返回步骤2的JSON文件。

那么,后续所有用户在请求这个库时,都能直接从对象存储中直接获取解析好的JSON文件,这能极大提高在线安装依赖的速度。jT128资讯网——每日最新资讯28at.com

比如,react@18.2.0经由「npm解析服务」解析后会返回如下JSON:jT128资讯网——每日最新资讯28at.com

{  "contents": {    "/node_modules/react/index.js": {      // 库的代码      "content": "...省略",      "isModule": false,      // 依赖的其他模块      "requires": [        "./cjs/react.production.min.js",        "./cjs/react.development.js"      ]    },    "/node_modules/react/cjs/react.production.min.js": {/*省略*/},    "/node_modules/react/cjs/react.development.js": {/*省略*/},    "/node_modules/js-tokens/package.json": {/*省略*/},    "/node_modules/loose-envify/package.json": {/*省略*/},    "/node_modules/react/package.json": {/*省略*/}  },  // 库的版本信息  "dependency": {    "name": "react",    "version": "18.2.0"  },  "peerDependencies": {},  // 依赖的依赖  "dependencyDependencies": {    "loose-envify": {/*省略*/},    "js-tokens": {/*省略*/}  },  "dependencyAliases": {}}

上述JSON中,入口代码在/node_modules/react/index.js,通过递归分析他的AST,发现他依赖了:jT128资讯网——每日最新资讯28at.com

  • "./cjs/react.production.min.js"
  • "./cjs/react.development.js"

于是,这2个文件对应代码也包含在JSON中。jT128资讯网——每日最新资讯28at.com

当下一个用户加载的项目依赖react@18.2.0,就能直接从对象存储中获取上述JSON。jT128资讯网——每日最新资讯28at.com

npm解析服务的实现

codesandbox在线打包相关的代码都是开源的,比如:jT128资讯网——每日最新资讯28at.com

  • 编辑器的部分对应sandpack-react[1]
  • npm解析服务对应dependency-packager[2]
  • 在线打包服务对应codesandbox-client[3]

所以,我们可以基于dependency-packager部署自己的「npm解析服务」。jT128资讯网——每日最新资讯28at.com

dependency-packager是一个serverless服务,通过AWS Lambda部署。由于采用的是开源的serverless框架,所以我们可以很方便的将项目中AWS Lambda的部分替换成其他serverless服务商(比如阿里云函数计算)。jT128资讯网——每日最新资讯28at.com

整个dependency-packager包含两个serverless函数:jT128资讯网——每日最新资讯28at.com

  • api:实际对外提供的服务
  • packager:根据包名和版本号生成JSON的服务

他们的关系如下:jT128资讯网——每日最新资讯28at.com

jT128资讯网——每日最新资讯28at.com

其中,生成的JSON保存在AWS S3中。同样,这里也可以替换成其他云服务厂家的存储方案。jT128资讯网——每日最新资讯28at.com

packager服务的工作流程如下:jT128资讯网——每日最新资讯28at.com

jT128资讯网——每日最新资讯28at.com

其中,「验证依赖的入口文件」会尝试下面这些文件后缀:jT128资讯网——每日最新资讯28at.com

const found = [  path.join(basedir, pkg.module),  path.join(basedir, pkg.module + ".js"),  path.join(basedir, pkg.module + ".cjs"),  path.join(basedir, pkg.module + ".mjs"),  path.join(basedir, pkg.module, "index.js"),  path.join(basedir, pkg.module, "index.mjs"),].find((p) => {  try {    const l = fs.statSync(p);    return l.isFile();  } catch (e) {    return false;  }});

验证完成后,会以package.json中的module或main字段作为入口文件,将代码转换为AST,分析AST中的require语句(cjs语法中引入模块的语法),找到依赖的模块。最终将这些模块汇总在JSON中。jT128资讯网——每日最新资讯28at.com

总结

codesandbox在线打包相关的代码都是开源的,包括:jT128资讯网——每日最新资讯28at.com

  • 编辑器
  • npm解析服务
  • 在线打包服务

其中,npm解析服务作为一个serverless服务包括两部分:jT128资讯网——每日最新资讯28at.com

  • api服务
  • packager服务

packager服务代码量不多,如果想尝试部署自己的serverless服务,是个不错的选择。jT128资讯网——每日最新资讯28at.com

参考资料

[1]sandpack-react:https://github.com/codesandbox/sandpack/tree/main/sandpack-react。jT128资讯网——每日最新资讯28at.com

[2]dependency-packager:https://github.com/codesandbox/dependency-packager。jT128资讯网——每日最新资讯28at.com

[3]codesandbox-client:https://github.com/codesandbox/codesandbox-client。jT128资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12437-0.html如何实现并部署自己的Npm解析服务

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 一个 println 竟然比 volatile 还好使?

下一篇: SQL中的各种连接的区别总结

标签:
  • 热门焦点
  • 石头自清洁扫拖机器人G10S评测:多年黑科技集大成之作 懒人终极福音

    科技圈经常能看到一个词叫“缝合怪”,用来形容那些把好多功能或者外观结合在一起的产品,通常这样的词是贬义词,但如果真的是产品缝合的好、缝合的实用的话,那它就成了中性词,今
  • 印度登月最关键一步!月船三号今晚进入环月轨道

    8月5日消息,据印度官方消息,月船三号将于北京时间今晚21时30分左右开始近月制动进入环月轨道。这是该探测器能够成功的最关键步骤之一,如果成功将开始围
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • Automa-通过连接块来自动化你的浏览器

    1、前言通过浏览器插件可实现自动化脚本的录制与编写,具有代表性的工具就是:Selenium IDE、Katalon Recorder,对于简单的业务来说可快速实现自动化的上手工作。Selenium IDEKat
  • 把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 自律,给不了Keep自由!

    来源 | 互联网品牌官作者 | 李大为编排 | 又耳 审核 | 谷晓辉自律能不能给用户自由暂时不好说,但大概率不能给Keep自由。近日,全球最大的在线健身平台Keep正式登陆港交所,努力
  • 质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
  • 三翼鸟智能家居亮相电博会,让用户体验更真实

    2021电博会在青岛国际会展中心开幕中,三翼鸟直接把“家”搬到了现场,成为了展会的一大看点。这也是三翼鸟继9月9日发布了行业首个一站式定制智慧家平台后的
Top