0

0

如何正确实现 Discord.py 机器人状态轮播以避免网关限流

花韻仙語

花韻仙語

发布时间:2026-01-14 18:27:09

|

817人浏览过

|

来源于php中文网

原创

如何正确实现 Discord.py 机器人状态轮播以避免网关限流

discord.py 机器人因频繁调用 `change_presence()` 触发 websocket 网关限流(429 错误),核心原因是未使用 `await asyncio.sleep()` 导致异步循环“空转”,实际请求间隔远小于预期。本文提供合规、鲁棒的状态轮播实现方案。

在 Discord API 中,change_presence() 属于网关(Gateway)操作,受严格的速率限制约束:同一 shard 每 5 秒最多允许 1 次状态更新(即 0.2 次/秒)。你原代码中虽写 asyncio.sleep(300),但缺少 await 关键字,导致该语句仅创建协程对象而未真正挂起执行——循环瞬间重复运行,短时间内发起大量请求,最终触发 Discord 的限流机制,并打印类似 WebSocket in shard ID None is ratelimited, waiting 57 seconds 的警告。

✅ 正确做法是使用 await asyncio.sleep(300),确保每次状态变更后完整等待 5 分钟,让事件循环有机会处理其他任务并遵守限流窗口。

以下是优化后的完整实现:

PaperFake
PaperFake

AI写论文

下载
import asyncio
import random
import discord
from discord.ext import commands

actaray = ["PcktWtchr's Videos", "Cams", "and Listening Always", "or Listening or Both"]

@bot.event
async def on_ready():
    print(f'Logged in as {bot.user}')
    while True:
        try:
            activity = discord.Activity(
                type=discord.ActivityType.watching,
                name=random.choice(actaray)
            )
            await bot.change_presence(activity=activity)
            await asyncio.sleep(300)  # ✅ 正确:await 确保真实休眠
        except discord.HTTPException as e:
            if e.status == 429:  # 遇到限流响应
                retry_after = int(e.response.headers.get("Retry-After", "5"))
                print(f"Rate limited! Retrying after {retry_after} seconds...")
                await asyncio.sleep(retry_after + 1)  # 加 1 秒缓冲,避免边界重试
            else:
                print(f"HTTP error during presence update: {e}")
                await asyncio.sleep(60)  # 其他 HTTP 错误降频重试
        except Exception as e:
            print(f"Unexpected error in presence loop: {e}")
            await asyncio.sleep(60)

# 可选:添加优雅关闭支持(如需热重载或清理)
@bot.event
async def on_disconnect():
    print("Bot disconnected — presence loop paused.")

? 关键注意事项:

  • 永远不要在 while True 循环中遗漏 await:asyncio.sleep() 是协程,不加 await 不会暂停,等同于无限轮询;
  • 异常捕获必须覆盖 discord.HTTPException:Discord 在限流时返回 HTTP 429 响应,Retry-After 头部指明精确等待秒数,应优先遵循;
  • 避免全局 on_error 泛化处理:原答案中 on_error 事件无法捕获 change_presence() 抛出的异常(它不在此事件链路中),因此应将错误处理内聚在轮播逻辑内部;
  • 推荐最小间隔 ≥ 300 秒(5 分钟):虽然 Discord 文档未公开确切阈值,但实测低于 240 秒易触发限流,5 分钟是稳定安全的实践值;
  • 若需更高频更新(如实时计数器),应改用 Rich Presence + activity.timestamps 或前端轮询,而非反复调用 change_presence()。

通过以上修正,你的机器人将严格遵循 Discord 网关速率策略,彻底消除 ratelimited 警告,同时保持状态轮播功能稳定可靠。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
504 gateway timeout怎么解决
504 gateway timeout怎么解决

504 gateway timeout的解决办法:1、检查服务器负载;2、优化查询和代码;3、增加超时限制;4、检查代理服务器;5、检查网络连接;6、使用负载均衡;7、监控和日志;8、故障排除;9、增加缓存;10、分析请求。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

608

2023.11.27

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

236

2023.12.07

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.25

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

496

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

452

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

3597

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2916

2024.08.16

Golang WebSocket与实时通信开发
Golang WebSocket与实时通信开发

本专题系统讲解 Golang 在 WebSocket 开发中的应用,涵盖 WebSocket 协议、连接管理、消息推送、心跳机制、群聊功能与广播系统的实现。通过构建实际的聊天应用或实时数据推送系统,帮助开发者掌握 如何使用 Golang 构建高效、可靠的实时通信系统,提高并发处理与系统的可扩展性。

30

2025.12.22

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 7.1万人学习

Vue 教程
Vue 教程

共42课时 | 9.5万人学习

React 教程
React 教程

共58课时 | 6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号