ForeverVM

ForeverVM

无会话代码解释器。 在永久运行的有状态沙箱中安全地运行 AI 生成的代码。

Category
访问服务器

README

foreverVM

GitHub Repo stars Chat on Discord

repo version
cli npm
sdk npm

foreverVM 提供了一个 API,用于安全地运行任意的、有状态的 Python 代码。

foreverVM 的核心概念是 机器 (machines)指令 (instructions)

机器 代表一个有状态的 Python 进程。您通过在机器上运行 指令 (Python 语句和表达式) 并接收结果来与机器交互。一个机器一次处理一条指令。

入门指南

您需要一个 API token (如果您需要一个,请联系 paul@jamsocket.com)。

尝试 foreverVM 最简单的方法是使用 CLI。 首先,您需要登录:

npx forevervm login

登录后,您可以使用新机器打开 REPL 界面:

npx forevervm repl

当 foreverVM 启动您的机器时,它会给它一个 ID,您以后可以使用该 ID 重新连接到它。 您可以像这样重新连接到一台机器:

npx forevervm repl [machine_name]

您可以像这样列出您的机器(按创建的相反顺序):

npx forevervm machine list

您不需要终止机器 -- 当机器空闲时,foreverVM 会自动将它们从内存交换到磁盘,然后在需要时自动将它们交换回来。 这就是 foreverVM 能够“永久”运行 repls 的原因。

使用 API

import { ForeverVM } from '@forevervm/sdk'

const token = process.env.FOREVERVM_TOKEN
if (!token) {
  throw new Error('FOREVERVM_TOKEN is not set')
}

// 初始化 foreverVM
const fvm = new ForeverVM({ token })

// 连接到一台新机器。
const repl = fvm.repl()

// 执行一些代码
let execResult = repl.exec('4 + 4')

// 获取结果
console.log('result:', await execResult.result)

// 我们也可以打印 stdout 和 stderr
execResult = repl.exec('for i in range(10):\n  print(i)')

for await (const output of execResult.output) {
  console.log(output.stream, output.data)
}

process.exit(0)

使用标签

您可以创建带有标签的机器,并按标签过滤机器:

import { ForeverVM } from '@forevervm/sdk'

const fvm = new ForeverVM({ token: process.env.FOREVERVM_TOKEN })

// 创建一个带有标签的机器
const machineResponse = await fvm.createMachine({
  tags: { 
    env: 'production', 
    owner: 'user123',
    project: 'demo'
  }
})

// 列出按标签过滤的机器
const productionMachines = await fvm.listMachines({
  tags: { env: 'production' }
})

内存限制

您可以通过指定内存大小(以 MB 为单位)来创建具有内存限制的机器:

// 创建一个具有 512MB 内存限制的机器
const machineResponse = await fvm.createMachine({
  memory_mb: 512,
})

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选