您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

这么多人用Codesandbox,他服务器扛得住么?

时间:2023-09-08 12:30:40  来源:微信公众号  作者:魔术师卡颂

Codesandbox是如何实现的?他会面临leetcode一样的服务器压力么?这个问题的本质其实是问 —— 用户在Codesandbox中写的代码,究竟是在前端还是后端编译成静态资源的?毕竟,如果是在后端完成,会增加服务器压力。

大家好,我卡颂。

codesandbox是前端工程师经常使用的「代码在线运行环境」,页面如下:

他的应用场景很广,比如:

  • 有代码逻辑要分享,分享个codesandbox链接。
  • 有新想法需要验证,又不想本地起个项目,用codesandbox。
  • 技术文档演示Demo,用codesandbox。

作为一个在线运行代码的编辑器,这么多人天天免费用,他服务器扛得住么?

毕竟,同样作为在线代码运行环境(主要是跑算法题)的leetcode[1],如果同时刷题的人多了,提交后都还得排队:

codesandbox是如何实现的?他会面临leetcode一样的服务器压力么?

codesandbox的分类

这个问题的本质其实是问 —— 用户在codesandbox中写的代码,究竟是在前端还是后端编译成静态资源的?毕竟,如果是在后端完成,会增加服务器压力。

比如,对于下面这段React代码:

// mAIn.jsx
import { createRoot } from "react-dom/client";
import { Cpn } from "./Cpn";

function App() {
  return (
    <Cpn />
  );
}
createRoot(document.getElementById("root")).render(<App />);
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

要想在浏览器中运行,涉及几个前置工作:

  • 需要编译JSX语法,比如将<App/>编译为_jsx(App, {})。
  • 需要解析并提前下载所有依赖,比如这里的react-dom、react包。
  • 需要解析模块依赖关系,比如main.jsx导入了Cpn.jsx中的Cpn组件。对于不支持ESM的浏览器,需要将代码打包。对于支持ESM的浏览器,需要处理引入路径。
  • 如果涉及到其他资源,比如图片、文字、html文件,需要有相应的处理。

上述工作,codesandbox是在浏览器还是服务器完成的呢?

在这个例子中,这些工作都能在浏览器完成,比如:

  • 对于所有第三方依赖,可以在浏览器中直接请求CDN。
  • 涉及编译的工作(比如编译JSX、模块依赖分析),本质其实是字符串的解析,可以用浏览器版本的babel实现。

上面的例子是一个纯前端的React项目。但有些依赖服务端环境的项目没法采用上述方式运行,比如:

  • 使用了Docker的项目。
  • 类似Next.js这样的全栈项目。

这种情况就需要一个真实的服务端环境。

两者的区别可以用下图概括:

  • 纯前端项目:编译与执行都能在浏览器完成。
  • 全栈项目:项目编译在服务端进行,浏览器负责项目执行。

他们分别对应codesandbox的两种运行环境:

  • Browser Sandbox:基于浏览器的本地运行环境。
  • Cloud Sandbox:基于MicroVM的云端运行环境。

当我们通过模板创建codesandbox项目时,可以通过「右上角是否有Cloud标记」区分两者:

可以发现:

  • 纯前端项目(比如React项目、纯JS项目)使用Browser Sandbox。
  • 需要服务端运行环境(比如Docker项目、全栈框架项目)使用Cloud Sandbox。

对于Cloud Sandbox,他底层使用亚马逊开发的Firecracker快速启动轻量级的MicroVM,这也是AWS Lambda底层使用的库。

所以,基于Cloud Sandbox启动的项目确实会占用服务端资源。具体来说,每个项目会分配:

  • CPU:2个虚拟 CPU(vCPUs)
  • 内存:2GB
  • 存储:6GB

这块是codesandbox公司的核心业务。毕竟,免费试用满意后,可能就会上付费的Pro版(更多资源分配),或者团队定制版。商业模式与Vercel类似 —— 提供免费基础服务(自担部分资源费用),通过增值的云服务收费。

而前端开发日常使用codesandbox创建的项目,大多数并不是基于Cloud Sandbox,而是基于Browser Sandbox启动的。这些项目并不会给codesandbox带来太多服务端压力。

两种sandbox的区别

有个很直观的方式区分两种Sandbox —— 当我们新建一个codesandbox项目,在预览区域可以看到项目临时url:

新开页面,访问这个url,如果请求的资源包括:

  • 项目运行所需的静态资源

webpack热更新相关代码

那代表这是个Cloud Sandbox项目。Cloud Sandbox在云端启动后端服务与当前页面通信,就类似我们本地开发时起的后端服务一样。

如果请求的资源包括:

  • 项目运行所需的静态资源。
  • sandbox初始化相关代码。

那代表这是个Browser Sandbox项目。

「sandbox初始化相关代码」是一个简化版的webpack,他会在浏览器执行,下载依赖、编译代码,打包并执行代码。

我们平时使用codesandbox时看到的如下初始化画面就代表Browser Sandbox在浏览器执行相关操作。

比如,下图是在通过CDN安装依赖(@babel/core):

当依赖安装完成后,下面是编译代码:

Browser Sandbox实现原理

Browser Sandbox相关代码都是开源的,让我们按照抽象程度从上往下介绍他。

首先是封装最完整的库 —— @codesandbox/sandpack-react。这个React库提供了很多开箱即用的codesandbox模块。

比如:

  • SandPackCodeEditor:codesandbox左侧的代码编辑区域,底层采用的是codemirror[2]这个代码编辑器。
  • SandpackConsole:codesandbox中的控制台。
  • SandackPreview:codesandbox右侧的预览区域,会渲染一个iframe,iframe的地址对应了Browser Sandbox的执行环境。

各个组件通过postMessage与SandackPreview渲染的iframe交互。

我们会发现,codesandbox的核心实际上包含三部分内容:

  • 各种编辑器相关模块的实现(比如代码编辑部分、控制台、预览)。
  • Browser Sandpack运行环境,是一个独立的网页,在预览模块(SandackPreview)中通过iframe渲染。
  • 1与2之间通信的协议(即页面与iframe之间的通信协议)。

@codesandbox/sandpack-react实现了1,他依赖的@codesandbox/sandpack-client[3]实现了3。

2相关的源代码在codesandbox-client/packages/app[4]中。将这个包的代码部署上线后,就能获得一个Browser Sandpack运行环境。

上面已经简单介绍了Browser Sandpack的工作原理,再将他(2)与1、3结合起来的工作原理如下:

比如,用户选择React作为项目模版:

编辑项目代码后,项目代码与preset(类似webpack中的preset选项项,不同模版对应不同preset)会通过通信协议传递给Browser Sandpack页面。

Browser Sandpack页面通过内置的mini webpack与其他工具(比如babel),编译并执行代码。

代码编译、执行的信息也会通过通信协议传递回各个需要的模块。比如,控制台模块可以根据type为console的信息打印消息。

总结

codesandbox有两种代码运行环境:

  • Browser Sandpack:针对「编译与执行都能在浏览器完成」的纯前端项目。
  • Cloud Sandpack:针对需要服务端运行环境的项目。

这两种环境会体现为一个独立网站,这个网站会作为iframe嵌入在codesandbox编辑器的预览模块中。

预览模块通过定义好的通信协议与其他模块(比如代码编辑模块、控制台模块)通信。

对于Cloud Sandpack,会占用一定服务端资源。对于Browser Sandpack,则不会占用什么服务端资源,因为他大部分逻辑都是在前端执行的。

参考资料

[1]leetcode:https://leetcode.cn/problems/two-sum/。

[2]codemirror:https://codemirror.NET/。

[3]@codesandbox/sandpack-client:https://www.npmjs.com/package/@codesandbox/sandpack-client。

[4]codesandbox-client/packages/app:https://Github.com/codesandbox/codesandbox-client/tree/master/packages/app。



Tags:Codesandbox   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
这么多人用Codesandbox,他服务器扛得住么?
Codesandbox是如何实现的?他会面临leetcode一样的服务器压力么?这个问题的本质其实是问 &mdash;&mdash; 用户在Codesandbox中写的代码,究竟是在前端还是后端编译成静态资源的?...【详细内容】
2023-09-08  Search: Codesandbox  点击:(331)  评论:(0)  加入收藏
▌简易百科推荐
为什么Nginx被称为“反向”代理呢?
Nginx(发音为"engine-x")是一款高性能、轻量级的开源Web服务器软件,也可用作反向代理服务器、负载均衡器和HTTP缓存。Nginx之所以有被称为“反向”代理,是因为它充当客户端设备...【详细内容】
2024-02-01  coderidea  微信公众号  Tags:Nginx   点击:(59)  评论:(0)  加入收藏
哪种服务器操作系统更好呢?
在当今的IT世界中,服务器操作系统扮演着至关重要的角色。它们是确保服务器能够高效、安全地运行的关键因素。然而,对于许多人来说,服务器操作系统的种类和特点可能是一个复杂的...【详细内容】
2024-01-30    简易百科  Tags:操作系统   点击:(76)  评论:(0)  加入收藏
什么是VPS服务器
VPS服务器是一种虚拟化技术,它将一台物理服务器划分为多个虚拟的独立服务器,每个虚拟服务器都可以拥有自己的操作系统、运行环境、应用程序等。这种技术使得每个虚拟服务器可...【详细内容】
2024-01-30    简易百科  Tags:VPS服务器   点击:(67)  评论:(0)  加入收藏
VPS服务器下载速度慢?这五招帮你提速
VPS服务器下载速度慢可能会让用户感到沮丧,尤其是对于需要大量下载和上传数据的用户。幸运的是,有一些方法可以帮助您提高VPS服务器的下载速度,使您的在线体验更加顺畅。在本文...【详细内容】
2024-01-30  IDC行业观察者    Tags:VPS服务器   点击:(57)  评论:(0)  加入收藏
美国VPS和英国VPS:地理位置对服务器性能的影响
在今天的数字时代,VPS已成为在线业务和网站托管的关键组成部分。然而,选择合适的VPS主机服务时,地理位置通常被忽视,尽管它对服务器性能有着重要的影响。本文将探讨美国VPS和英...【详细内容】
2024-01-26  IDC行业观察者    Tags:服务器   点击:(52)  评论:(0)  加入收藏
如何判断服务器所需带宽:基于业务需求和流量模式的关键考量
在选择服务器时,带宽是一个重要的考虑因素。带宽的大小直接影响到网站的加载速度和用户的访问体验。那么,如何判断服务器需要多大的带宽呢?本文将为你揭示这一关键问题的答案...【详细内容】
2024-01-26  源库科技    Tags:服务器   点击:(74)  评论:(0)  加入收藏
服务器内存空间及IO操作原理解析
服务器的内存空间分为内核空间和用户空间,而我们编写的程序通常在用户空间中运行。在进行读写操作时,我们直接操作的是用户缓冲区,而用户缓冲区的内容来自于内核缓冲区。这种内...【详细内容】
2024-01-23  王建立    Tags:服务器   点击:(42)  评论:(0)  加入收藏
如何在Java环境中安装Nginx?
1. 下载Nginx:首先,前往Nginx官方网站(https://nginx.org/en/download.html)下载新版本的Nginx。选择适合您操作系统的版本,通常有Windows、Linux和Mac等不同操作系统的版本可供...【详细内容】
2024-01-22  敲代码的小动    Tags:Nginx   点击:(59)  评论:(0)  加入收藏
服务器证书和SSL证书有啥区别?
在互联网经济时代,随着越来越多的信息以及合作都是从企业官网开始的,因此绝大多数企业都会为自己的网站配置SSL证书,以提高安全性。在接触SSL证书时,也有很多人称之为服务器证书...【详细内容】
2024-01-10  安信SSL证书    Tags:服务器证书   点击:(65)  评论:(0)  加入收藏
宝塔面板怎样部署java项目?
宝塔面板怎样部署java项目?在使用宝塔面板部署Java项目之前,需要确保已经安装了Java Development Kit (JDK)。接下来,将介绍如何使用宝塔面板来部署Java项目的步骤。步骤一:安装...【详细内容】
2024-01-09  西部数码    Tags:宝塔面板   点击:(105)  评论:(0)  加入收藏
相关文章
    无相关信息
站内最新
站内热门
站内头条