Project Icon

winterjs

基于WinterCG规范的高性能JavaScript服务器

WinterJS是一款性能卓越的JavaScript服务器,采用SpiderMonkey、Spiderfire和hyper技术。符合WinterCG规范,单机处理能力可达10万请求/秒。支持Service Workers和众多Web API,如fetch、URL等。可选择Wasmer运行或本地安装,灵活适应不同开发需求。

WinterJS 是一个极速的 JavaScript 服务器,能够根据 Winter 社区组规范 运行 Service Workers 脚本。

WinterJS 在单台笔记本电脑上能够处理高达每秒 100,000 个请求(参见基准测试)。


注意:尽管名称中都包含"Winter",但 WinterJS 并未得到 WinterCG 的官方认可。有许多支持 WinterCG 的运行时,WinterJS 只是其中之一。

使用 Wasmer 运行 WinterJS

WinterJS 服务器在 Wasmer 上以 wasmer/winterjs 的名称发布。

你可以通过以下命令在本地运行 HTTP 服务器:

wasmer run wasmer/winterjs --net --mapdir=tests:tests tests/simple.js

其中 simple.js 的内容为:

addEventListener('fetch', (req) => {
  req.respondWith(new Response('hello'));
});

从源代码构建

WinterJS 需要在其构建过程中从源代码构建 SpiderMonkey。请按照此处概述的步骤操作,以确保你已准备好构建 SpiderMonkey:https://github.com/wasmerio/mozjs/blob/master/README.md。

在使用 cargo install 安装 WinterJS(从源代码构建而不是下载预构建的二进制文件)之前,你也需要完成这些步骤。

此外,在调试模式下构建 WinterJS 时,你需要安装 NodeJS 和 npm,并预先运行 npm install。这是因为 WinterJS 的调试版本还会构建 src/builtins/internal_js_modules 中的 TypeScript 代码。发布版本使用该目录中现有的预编译 *.js 源文件。这样做是为了简化使用 cargo install 安装 WinterJS 的过程。如果你更新了 TypeScript 源文件,请确保至少在调试模式下构建一次,并提交更新后的 *.js 文件。

一旦你能够构建 SpiderMonkey,只需像往常一样运行 cargo build 来构建 WinterJS 本身。

原生运行 WinterJS

你可以通过以下命令原生安装 WinterJS:

cargo install --git https://github.com/wasmerio/winterjs winterjs

安装完 WinterJS 后,你可以简单地执行:

winterjs tests/simple.js

然后通过 https://localhost:8080/ 访问服务器。

WinterJS 的工作原理

WinterJS 由 SpiderMonkeySpiderfirehyper 提供支持,为你的 Javascript 应用带来全新水平的卓越性能。

WinterJS 使用 WASIX 标准编译为 WebAssembly。请注意,目前编译为 WASIX 是一个复杂的过程。我们建议使用 wasmer/winterjs 中的预编译版本,但如果你需要在本地编译为 WASIX,请开启一个问题。

局限性

WinterJS 完全符合 WinterCG 规范,尽管运行时本身仍在开发中。有关更多信息,请参阅下面的 API 兼容性部分。

WinterCG API 兼容性

随着 API 的添加/修复,本节将会更新。如果某个 API 在本节中未提及,则表示它尚未实现。

你可以在这里查看更详细的列表:https://runtime-compat.unjs.io/

以下词语用于描述 API 的状态:

  • ✅ 稳定 - API 已实现并完全符合规范。这不包括原生代码中潜在的未发现的实现错误。
  • 🔶 部分 - API 已实现但未完全符合规范和/或存在已知限制。
  • ❌ 待定 - API 尚未实现。
API状态备注
console✅ 稳定
fetch✅ 稳定
URL✅ 稳定
URLSearchParams✅ 稳定
Request✅ 稳定
Headers✅ 稳定
Response✅ 稳定
Blob✅ 稳定
File✅ 稳定
FormData✅ 稳定
TextDecoder✅ 稳定
TextDecoderStream✅ 稳定
TextEncoder✅ 稳定
TextEncoderStream✅ 稳定
ReadableStream 及相关类型✅ 稳定
WritableStream 及相关类型✅ 稳定
TransformStream 及相关类型🔶 部分未实现背压
atob✅ 稳定
btoa✅ 稳定
performance.now()✅ 稳定
performance.timeOrigin✅ 稳定
crypto✅ 稳定
crypto.subtle🔶 部分仅支持 HMAC、MD5 和 SHA 算法

其他支持的 API

以下(非 WinterCG)API 在 WinterJS 中已实现并可访问:

API状态备注
Service Workers Caches API✅ 稳定可通过 caches 访问。caches.default(类似于 Cloudflare workers)也可用。
当前实现基于内存,缓存的响应在多次运行 WinterJS 之间不会持久保存。
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号