docs(pages): 在 CF Workers 上运行 Discord 机器人

This commit is contained in:
Ad-closeNN
2025-09-06 21:39:07 +08:00
parent 18735a39a9
commit 4a5e6b5cc5
12 changed files with 157 additions and 0 deletions
Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 265 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 509 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 346 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 64 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 130 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 64 KiB

+157
View File
@@ -0,0 +1,157 @@
---
title: 在 CF Workers 上运行 Discord 机器人
published: 2025-09-06
tags: ["机器人", "CF Workers"]
description: 通过 Cloudflare Workers,你甚至可以运行一个 Discord 机器人,而且完全免费!
image: ../assets/images/discord-bot-cln-bot-profile.png
customcover: ../assets/images/discord-bot-cln-bot-profile-wide.png
showcover: false
category: 教程
---
:::tip[提示]
~~赛博菩萨~~ Cloudflare Workers 不仅能运行 Discord 机器人,还能运行 Telegram 机器人。
:::
# 前言
众所周知,我们运行一个 Discord 机器人,可以通过 Python 第三方库 [discord.py](https://pypi.org/project/discord.py/) 来运行 Discord Bot。
这听起来需要一个能一直运行的 Linux/Windows 服务器。但其实我们还能利用 Cloudflare Workers 来运行自己的机器人,而且还**大概率**不会被 Cloudflare 封号,因为 Discord 官方自己都放了[样例](https://github.com/discord/cloudflare-sample-app)
::github{repo=discord/cloudflare-sample-app}
# 需求
1. 一个 [Cloudflare](https://dash.cloudflare.com) 账号
2. 一个 [Discord](https://discord.com) 账号
- (非必须)一个 [GitHub](https://github.com) 账号
# 创建 Discord 机器人
登录好 Discord 账号后,打开 https://discord.com/developers/applications ,点击右上角的 **New Application**,写下你 Bot 的名称,然后勾选协议,再点击蓝色按钮 **Create** ![discord-create-an-application](../assets/images/discord-create-an-application.png)
如果你[是人类](/posts/captcha/),那么应该会顺利过完人机验证,创建一个新的 Discord Bot。在 **General Information** 页中,你可以添加 Bot 的头像、横幅、介绍、昵称等信息。
# 获取 Discord 机器人相关信息
:::caution[警告]
请务必将以下信息放置于安全的地方,且不要泄露 Token。
:::
## DISCORD_APPLICATION_ID
在默认页面 **General Information** 中,找到 `Application ID`,点击 **Copy** 按钮,粘贴到安全的地方。
## DISCORD_PUBLIC_KEY
在默认页面 **General Information** 中,找到 `Public Key`,点击 **Copy** 按钮,粘贴到安全的地方。
## DISCORD_TOKEN
在左侧选择 **Bot**,在页面内点击 **Reset Token** 按钮,将 Token 粘贴到安全的地方: ![discord-reset-token](../assets/images/discord-reset-token.png)
# 配置 Discord 机器人设置
:::warning[注意]
这个方案会让**所有人**都可以把你的机器人安装到他们的服务器。前提是你的服务器内要有别人。
:::
在左侧选择 **Installation**,在下方 Guild Install 配置成如图所示的权限: ![discord-bot-installation-guild-install](../assets/images/discord-bot-installation-guild-install.png)
配置完毕后点击上方 Install Link 中,右侧的 **Copy** 按钮,在浏览器内访问。
在接下来的页面中选择 **添加至服务器**,然后选中一个服务器,点击 **继续**,点击 **授权** ![discord-invite-bot](../assets/images/discord-invite-bot.png)
当你的机器人出现在你所选的服务器中,那么代表你成功了。
# 配置 Cloudflare Worker
:::note[笔记]
这里以 [Cloudflare Wrangler](https://developers.cloudflare.com/workers/get-started/guide/) 操作 Worker 文件。如果需要上传到 GitHub,并用 Actions 提交 Worker 文件,请参考 [Deployment - Hosting a Reddit API Discord app on Cloudflare Workers](https://discord.com/developers/docs/tutorials/hosting-on-cloudflare-workers#deployment) 。
:::
点击链接下载最新的官方样例代码库: [https://github.com/discord/cloudflare-sample-app/archive/refs/heads/main.zip](https://github.com/discord/cloudflare-sample-app/archive/refs/heads/main.zip)
解压这个 `.zip` 压缩包到一个地方,然后安装依赖:
```shell title=pnpm
pnpm install
```
如果能用 `npx wrangler`,那就说明安装成功了: ![windows-terminal-pnpm-install-discord-bot-successful](../assets/images/windows-terminal-pnpm-install-discord-bot-successful.png)
在文件夹根目录下有一个文件 `wrangler.toml`,打开它可以编辑你的 Worker 名字:
```toml title=wrangler.toml
name = "awwbot" <- 更改这个即可更改 Worker 的名字(不是更改 Discord 机器人的名字)
main = "./src/server.js"
compatibility_date="2023-05-18"
# [secrets]
# DISCORD_TOKEN
# DISCORD_PUBLIC_KEY
# DISCORD_APPLICATION_ID
```
接下来,我们需要将 Bot 的机密信息上传到 Cloudflare。
依次执行以下三个命令,值为之前在 [#获取 Discord 机器人相关信息](#获取-discord-机器人相关信息) 获取的三个信息:
```shell title=wrangler
npx wrangler secret put DISCORD_APPLICATION_ID
npx wrangler secret put DISCORD_PUBLIC_KEY
npx wrangler secret put DISCORD_TOKEN
```
如果你没有创建这个 Worker,Wrangler 会让你选择**是否创建名为xxx的 Worker**,这时输入y即可。
当三个密钥上传成功后,Worker 设置应该是如图所示的: ![cloudflare-worker-discord-bot-vars-and-secrets](../assets/images/cloudflare-worker-discord-bot-vars-and-secrets.png)
不过,目前只上传了机密,并没有上传 Worker 主文件。所以会显示 "**There is nothing here yet**"。
在终端输入以下命令可将本地 Worker 文件上传到 Cloudflare Workers
```shell title=pnpm
pnpm run publish
```
正确的结果应为如下**类似**输出,`WARNING` 可以不用理:
```shell title="pnpm run publish"
⛅️ wrangler 4.34.0
───────────────────
Total Upload: 23.34 KiB / gzip: 6.27 KiB
Worker Startup Time: 2 ms
Uploaded awwbot-testerererer (7.46 sec)
▲ [WARNING] Worker has workers.dev disabled, but 'workers_dev' is not in the config.
Using fallback value 'workers_dev = true'.
Deployed awwbot-testerererer triggers (5.40 sec)
https://awwbot-testerererer.1709301095.workers.dev
Current Version ID: bbc5f582-58a9-4e30-94e1-d2a14952efa0
```
此时再访问 Worker,会出现类似 `👋 1413847154543427594` 的输出。这就说明 **Worker 配置成功了**。
# 其他配置
除此之外,还需要配置 Discord 的 Endpoint URL,将 Discord 和 Cloudflare Worker 打通:
1. 回到 Discord Developer,选择你的机器人。
2. 在 **General Information** 中,找到 **Interactions Endpoint URL**。
3. 将**你部署的 Cloudflare Worker 的链接**填进去,如图所示(实际请替换为自己的): ![discord-interactions-endpoint-url](../assets/images/discord-interactions-endpoint-url.png)
4. 点击 **Save Changes** 按钮,保存更改。
还有还有,你还需要向 Discord 注册机器人的命令。
1. 回到文件夹根目录,把 `example.dev.vars` 重命名为 `.dev.vars`。
2. 打开这个文件,填入之前获取的三个信息。
```ini title=.dev.vars
DISCORD_APPLICATION_ID: ".."
DISCORD_PUBLIC_KEY: ".."
DISCORD_TOKEN: ".. <- 记得补上这个缺失的引号!这是 Discord 官方漏的
```
https://github.com/discord/cloudflare-sample-app/blob/main/example.dev.vars#L3
:::caution[警告:别怪我没提醒你]
这个文件 `.dev.vars` 请勿上传至 GitHub 的**公开**存储库,否则会面临 TOKEN 泄露的风险!
:::
3. 保存那个文件,然后在终端输入:
```shell title=pnpm
pnpm run register
```
4. 当出现 `Registered all commands` 时代表注册命令成功。
回到 Discord,乱点一下你的机器人,比如添加 APP 然后添加到自己什么的,或者发送一条消息给它,总之触发了 **{/}** 这个代表成功了:![discord-bot-supports-commands](../assets/images/discord-bot-supports-commands.png)
可能会显示离线,但是如果命令能用就代表能用了。 ![discord-bot-channel-cln-bot-test](../assets/images/discord-bot-channel-cln-bot-test.png)
# 关于今后...
关于配置更多的命令,`.src/`中的 `commands.js` `register.js` `server.js` 是重要的,不会配置的问 AI 就好了。这就纯纯复制粘贴和 AI。