webvm 用浏览器启动的虚拟环境

WebVM是一款基于WebAssembly技术的浏览器虚拟机,可直接在浏览器中运行完整的Linux环境,无需服务器支持

源码:https://github.com/leaningtech/webvm/

github部署

安装介绍:

动手实践:

打开网站:https://github.com/leaningtech/webvm

fork到自己的github账户:

直接点setting:

在setting页面,点击pages:

在Pages展开的右边页面,打开Build and deployment下面的GitHub ACtions,选Deploy from a branch:

可以看到把main映射到根目录了:

然后点Action:

出现Workflows页面,点绿色的大按钮:

出现Actions页面,点左侧的Deploy按钮:

点右侧的Run workflow,然后点绿色按钮:Run workflow

后面就是慢慢等待发布成功:

但是不知道为何,我这边发布是失败的。

本地部署

下载源码

复制代码
git clone https://github.com/leaningtech/webvm.git
cd webvm

下载Debian mini 镜像

复制代码
wget "https://github.com/leaningtech/webvm/releases/download/ext2_image/debian_mini_20230519_5022088024.ext2"

修改配置文件

Edit `config_public_terminal.js` to reference your local disk image:

  • Replace:

    "wss://disks.webvm.io/debian_large_20230522_5044875331.ext2"

    With:

    "/disk-images/debian_mini_20230519_5022088024.ext2"

    (Use an absolute or relative URL pointing to the disk image location.)

  • Replace "cloud" with the correct disk image type: "bytes"

最终修改成这样

复制代码
// The root filesystem location
// export const diskImageUrl = "wss://disks.webvm.io/debian_large_20230522_5044875331_2.ext2";
export const diskImageUrl = "debian_large_20230522_5044875331_2.ext2";
// The root filesystem backend type
// export const diskImageType = "cloud";
export const diskImageType = "bytes";

build

复制代码
npm install
npm run build

实战中我是使用了pnpm

复制代码
pnpm install
pnpm run build

build完成提示:

复制代码
[vite-plugin-static-copy] Copied 6 items.
✓ built in 32.50s

Run npm run preview to preview your production build locally.

> Using @sveltejs/adapter-static
  Wrote site to "build"
  ✔ done

配置nginx

复制代码
mkdir disk-images
mv debian_mini_20230519_5022088024.ext2 disk-images/

修改nginx.conf文件,加入:

复制代码
​
location /disk-images/ {
	root .;
	autoindex on;
}

​

启动nginx

复制代码
sudo nginx -p . -c nginx.conf

出来页面了

尽管只是个黑黑的控制台,也很棒了!

不过后面有报错,没搞定。

调试

pnpm run build报错

> webvm@2.0.0 build

> vite build

vite v5.4.21 building SSR bundle for production...

✓ 31 modules transformed.

x Build failed in 1.06s

error during build:

config_public_terminal.js (2:9): Expected ';', '}' or <eof>

file: config_public_terminal.js:2:9

1: // The root filesystem location

2: # export const diskImageUrl = "wss://disks.webvm.io/debian_large_20230522_5044875331_2.ext2";

^

3: export const diskImageUrl = "debian_large_20230522_5044875331_2.ext2";

4: // The root filesystem backend type

at getRollupError (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/parseAst.js:401:41)

at ParseError.initialise (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/node-entry.js:14469:28)

at convertNode (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/node-entry.js:16352:10)

at convertProgram (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/node-entry.js:15592:12)

at Module.setSource (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/node-entry.js:17352:24)

at async ModuleLoader.addModuleSource (file:///home/skywalk/github/webvm/node_modules/.pnpm/rollup@4.53.3/node_modules/rollup/dist/es/shared/node-entry.js:21377:13)

发现是注释用错了,不应该用#,要用//

复制代码
// The root filesystem location
// export const diskImageUrl = "wss://disks.webvm.io/debian_large_20230522_5044875331_2.ext2";
export const diskImageUrl = "debian_large_20230522_5044875331_2.ext2";
// The root filesystem backend type
// export const diskImageType = "cloud";
export const diskImageType = "bytes";

build完成

这段代码应该放到nginx的哪里?

复制代码
location /disk-images/ {
	root .;
	autoindex on;
}

放到主文件的location / 后面或前面

webvm启动报错

curl --max-time 15 parrot.live # requires networking

WebVM encountered an unexpected error

Check the DevTools console for further information

Please consider reporting a bug!

CheerpX internal error message is:

Initialization failed for 'HttpBytesDevice': Server returned 404

不知道为啥啊!是不是国内网络的锅啊?

找到问题了,原来我把文件位置写错了,应该是

"/disk-images/debian_mini_20230519_5022088024.ext2"

因为把这个文件放置到disk-images目录了!

改过来还是同样的报错,先搁置。

相关推荐
27399202917 小时前
GDB调试(Linux)
linux
凡人叶枫18 小时前
Effective C++ 条款23:宁以 non-member、non-friend 替换 member 函数
linux·开发语言·c++·嵌入式开发
不会C语言的男孩18 小时前
Linux 系统编程 · 第 4 章:文件属性与元数据
linux·c语言·开发语言
小生不才yz18 小时前
Shell脚本精读 · S02-03 | 词拆分、通配符与未加引号的变量
linux
2601_9618454218 小时前
法考真题及答案解析|历年真题|资料已整理
linux·windows·ubuntu·macos·centos·gnu
A_humble_scholar18 小时前
Linux(七)调度器:从硬件矛盾到进程切换的底层逻辑
linux·服务器·网络
AOwhisky19 小时前
Redis 学习笔记(第四期):高可用与集群(哨兵 + Cluster + 容器化)
linux·运维·数据库·redis·笔记·学习·缓存
零陵上将军_xdr19 小时前
Shell脚本入门:从Hello World到变量的灵活运用
linux
C语言小火车20 小时前
嵌入式Linux应用开发技术栈完全指南
linux·运维·服务器
天南散修21 小时前
MT7916驱动中802.11转换为802.3
linux·网络·驱动开发·wifi·802.11