自托管
WARNING
请注意,你必须将你的实例与官方网站 (fmhy.net) 区分开来,以避免混淆。具体步骤如下。
本指南将帮助你在本地设置和运行自己的 FMHY 实例。
Docker (实验性)
要运行本地实例,你需要安装 Docker 和 Docker Compose。
安装完成后,运行以下命令:
git clone https://github.com/fmhy/edit.git
cd edit
sudo docker compose up --build构建镜像并启动容器可能需要几分钟时间,运行在 4173 端口。
Nix Flake
你可以使用 nix 来设置开发环境,我们有一个 flake 可以设置 nodejs 和 pnpm。
- Fork 仓库并将其克隆到本地机器:
git clone https://github.com/fmhy/edit.git。 - 运行
nix flake update更新 flake 锁文件。 - 运行
nix develop进入开发环境。 - 进行更改。
- 运行
exit退出开发环境。
手动安装
你需要安装以下内容:
- Git
- Node.js - 安装 25.2.1 版本
- pnpm 9.12.2+
第一步:克隆仓库
git clone https://github.com/fmhy/edit.git
cd edit第二步:安装依赖
使用 pnpm 安装项目依赖:
pnpm install第三步:开发模式
以开发模式运行项目:
# 以开发模式启动文档站点
pnpm docs:dev
# 以开发模式启动 API(如果需要)
pnpm api:dev开发服务器默认将在 http://localhost:5173 启动。
第四步:构建生产版本
你需要更新以下内容:
meta: 位于docs/.vitepress/constants.ts中的常量name: 你的实例名称hostname: 你的域名description: 你的实例描述tags: Opengraph 标签build: 构建选项(可以通过 环境变量 配置)
docs/index.mdtitledescriptionhero.namehero.tagline
构建生产版本:
# 构建文档站点
pnpm docs:build
# 使用 Node.js 预设构建 API(如果需要)
NITRO_PRESET=node pnpm api:build第五步:预览生产构建
在本地预览生产构建:
# 预览文档站点
pnpm docs:preview
# 预览 API(如果需要)
pnpm api:preview第六步:部署
查看 VitePress 部署指南 了解更多信息。
API 部署
如果你想部署 API 组件(反馈系统),你需要设置 Cloudflare Workers 和 KV 存储。
先决条件
- 一个 Cloudflare 账户
- 全局安装 Wrangler CLI
第一步:配置 Wrangler
使用你的 Cloudflare 账户信息更新 wrangler.toml:
- 从 Cloudflare 仪表板获取你的账户 ID(位于右侧边栏)
- 将
wrangler.toml中的account_id值替换为你的账户 ID - 如果你使用自定义域名,保持
workers_dev = false并更新routes部分 - 如果你部署到
*.workers.dev,设置workers_dev = true并删除routes部分
第二步:创建 KV 命名空间
创建一个 KV 命名空间用于数据存储:
npx wrangler kv:namespace create STORAGE此命令将返回一个命名空间 ID。复制此 ID 并替换 wrangler.toml 中 [[kv_namespaces]] 部分(第 14 行)的 id 值。
注意: 如果你想在不本地运行 Wrangler 的情况下部署(例如在 CI/CD 中),你需要:
- 在 Cloudflare 仪表板中手动创建 KV 命名空间
- 在你的 fork 中的
wrangler.toml更新account_id和id值
第三步:构建和部署
构建并部署 API:
# 构建 API
pnpm api:build
# 部署到 Cloudflare Workers
pnpm api:deployAPI 将部署到你配置的域名或 *.workers.dev 子域名。
速率限制(可选)
速率限制绑定需要通过 Cloudflare 仪表板设置。对于基本部署,你可以跳过此步骤,或稍后通过 Workers 仪表板下的 "Rate limiting" 部分进行配置。
环境变量
构建时变量(用于文档)
这些变量控制构建文档站点时包含的内容:
FMHY_BUILD_NSFW- 启用 NSFW 侧边栏条目(实验性)FMHY_BUILD_API- 启用反馈系统的 API 组件
运行时变量(用于 API Worker)
这些变量由部署的 Cloudflare Worker API 使用:
WEBHOOK_URL- 用于发布反馈消息的 Discord webhook URL(API 反馈功能必需)
故障排除
- 如果遇到 Node.js 版本问题,请确保使用 Node.js 21+
- 对于 pnpm 相关问题,请确保使用 pnpm 9+
- 如果遇到构建问题,尝试清除缓存:bash
# Linux rm -rf docs/.vitepress/cache # PowerShell rm -r -fo docs/.vitepress/cache
反向代理
你应该能够在此 vitepress 网站上使用任何反向代理,但可以在 此处仓库中 找到 nginx 服务器的合理配置。