Qexed
Qexed 是基于 Rust 所开发的一个我的世界Java版本服务端
当前对应的MC版本:1.21.8,每次只适配一个版本

项目介绍
Qexed one 单机版本
服务列表
qexed_tcp_connect - TCP连接入口模块文档
文档信息
- 配置版本:0
- 最后更新:2025年12月15日 11:00
功能
- 玩家进服的唯一权威入口
- 处理握手阶段、配置节点、登录阶段的网络数据包
- 转发配置阶段、游戏阶段的网络数据包
- 实现登录认证
服务关系图
graph TD
A[MC客户端] --> B[qexed_tcp_connect_app]
B --> C{选择阶段}
C -->|Status阶段| D[Status阶段:查询服务]
C -->|Login阶段| E[Login阶段]
D --> F[qexed_server_status]
F --> G[qexed_game_logic]
subgraph E [Login阶段]
H[Login:黑名单查询] --> I[qexed_blacklist]
J[Login:白名单查询] --> K[qexed_whitelist]
L[Login:反作弊检查] --> M[qexed_guard]
N[Login:封禁查询] --> O[qexed_varden]
end
I --> G
K --> G
M --> G
O --> G
配置文件
请阅读配置
运维提示:修改监听地址(
ip)重启此服务时,玩家会掉线。
命令
请阅读命令
常见问题
无
配置
文档信息
- 配置版本:0
- 最后更新:2025年12月15日
📍 服务器监听设置
| 配置项 | 默认值 | 说明与建议 |
|---|---|---|
服务器地址 (ip) | 0.0.0.0:25565 | 服务器监听的主机和端口。0.0.0.0 表示接受来自任何网络接口(如公网、局域网)的连接。如果您只想在本地电脑运行服务器供自己测试,可以改为 127.0.0.1:25565。 |
🔐 玩家登录验证
| 配置项 | 默认值 | 说明与建议 |
|---|---|---|
正版验证 (online_mode) | true (开启) | 这是最重要的安全设置之一。 |
• 开启 (true):玩家必须拥有正版《我的世界》账户才能进入。这是官方服务器的标准,最安全。 | ||
• 关闭 (false):允许任何玩家使用任意用户名进入(离线模式)。警告:如果您将服务器公开到互联网,请务必了解关闭此选项带来的安全风险。 |
🔄 网络性能与代理
| 配置项 | 默认值 | 说明与建议 |
|---|---|---|
网络压缩阈值 (network_compression_threshold) | 256 | 当服务器发送的数据包大于此值(单位:字节)时,会先压缩再发送,以节省网络带宽。如果您的服务器和玩家网络都很好,可以尝试调高(如 512)或设为 -1 来完全禁用压缩,以降低CPU消耗。 |
启用代理支持 (proxy) | false (关闭) | 只有当您的 Qexed 服务器前方部署了 BungeeCord、Velocity 等“群组服”代理时才需要开启。 开启后,服务器才能正确接收来自代理的真实玩家IP信息。 |
如果您开启了代理 (proxy: true)
您还需要设置以下两项:
| 配置项 | 默认值 | 说明与建议 |
|---|---|---|
代理协议类型 (proxy_protocol) | qtunnel | 必须与您前方使用的代理软件保持一致,否则玩家无法连接! |
• bungeecord:对应最常用的 BungeeCord。 | ||
• victory:对应 Velocity 代理。 | ||
• qtunnel:项目自定义协议。 | ||
• none:不使用任何代理协议(仅调试用)。 | ||
代理通信密钥 (proxy_token) | (随机字符串) | 一个用于在服务器和代理之间进行安全验证的密码。您必须将它复制到代理端(如BungeeCord)的配置文件中,确保两边完全一致,否则连接会被拒绝。 |
🛡️ 连接安全防护
为了防止恶意攻击和刷连接,服务器内置了基础防护。
| 配置项 | 默认值 | 说明与建议 |
|---|---|---|
频率限制-时间窗 (rate_limit_window_secs) | 60 秒 | 统计连接频率的时间范围。 |
频率限制-最大次数 (rate_limit_max_attempts) | 6 次 | 在上述时间窗口内,允许同一个IP地址尝试连接的次数。超过次数的IP会被临时封禁。如果您遇到误封,可以适当调高这个数值。 |
状态查询超时 (status_timeout_secs) | 5 秒 | 玩家在服务器列表里“ping”您的服务器时,服务器响应的最长时间。如果网络较差导致列表刷不出,可以略微调大此值。 |
⚙️ 配置文件示例
一份典型的、用于公开正版服的配置可能如下所示:
ip: "0.0.0.0:25565"
online_mode: true
network_compression_threshold: 256
proxy: false
# 当 proxy 为 false 时,以下 proxy_ 开头的设置无需理会
rate_limit_window_secs: 60
rate_limit_max_attempts: 10 # 稍微放宽了一点限制
status_timeout_secs: 5
一份用于在 BungeeCord 后方的子服务器配置可能如下:
ip: "0.0.0.0:25566" # 注意端口不能与BungeeCord或其他子服冲突
online_mode: false # BungeeCord 已统一验证,子服关闭验证
proxy: true # 关键:必须开启
proxy_protocol: bungeecord # 关键:必须匹配
proxy_token: "MySecureSharedToken123" # 关键:必须与BungeeCord配置一致
rate_limit_window_secs: 30
rate_limit_max_attempts: 30 # 因代理转发,限制可大幅放宽
📁 配置文件位置
此模块的配置文件通常位于服务器根目录的 ./config/qexed_player_list/ 文件夹中,名称可能为 config.yaml、config.toml 或 config.json,具体取决于项目设定的格式。
总结:对于大多数想开一个简单服务器的用户,您主要需要关注 ip(端口) 和 online_mode(是否正版) 这两个设置。只有当您需要搭建复杂群组服时,才需要深入了解代理相关的配置。
在 qexed-one中,为 [tcp_connect_app]
命令
文档信息
- 配置版本:0
- 最后更新:2025年12月15日
本模块暂时不涉及命令
qexed_player_list 玩家列表
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 14:00
功能
- 统计玩家列表
- 统计玩家数
服务关系图
graph TD
A[qexed_server_status] -->|玩家数查询请求| B[qexed_player_list]
C[qexed_game_logic] -->|玩家进退服事件| B[qexed_player_list]
配置文件
version = 0
max_player = 20
auto_update = false
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| version | i32 | 配置文件版本 |
| max_player | i32 | 最大玩家数 |
| auto_update | bool | 玩家数动态扩充,此数值根据集群运行情况自动扩缩容(该参数暂时不生效) |
命令
玩家列表的命令相对简单,只有查询功能而已
/list 玩家列表
描述: 查询玩家列表
权限组要求: qexed.list
另名:list、玩家列表
参数:page
指令说明:
玩家列表指令相对原版mc服务端来说,增加了页码信息,页码信息类似 help,
此外每页10个玩家,如下:
/list [页码:int]
游戏内执行效果:

常见问题
无
qexed_server_status 服务器状态
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 14:30
功能
- 答复Status阶段的PingStart请求
- 玩家列表缓存
游戏内截图

服务关系图
graph TD
A[qexed_tcp_connect_app] -->|玩家数据包构建请求| B[qexed_server_status]
B[qexed_server_status] --> |查询玩家数| C[qexed_player_list]
配置文件
version = 0
cache = 30
motd = [
"欢迎使用量子叠加态",
"桶木跑路了",
]
favicon = ""
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| version | i32 | 配置文件版本 |
| cache | i32 | 缓存时间 |
| motd | Vec | 随机描述内容 |
| favicon | String | 服务器logo base64 |
命令
暂无
常见问题
为什么我服务器玩家有变化却还是显示原来的信息
服务器Ping请求有缓存,缓存结束后就就会刷新了。
缓存的时间根据你设置的cache决定
cache 默认30秒
我如何更换我服务器的头像
你可以前往 https://www.lddgo.net/convert/imagebasesix 或其他第三方网站进行生成

开发者不担保网站安全性,您可以自行浏览器搜索其他方法
上传后我们复制base64的编码的内容

截图中内容如下

随后打开配置文件替换数据(favicon 字段)即可

qexed_chat 聊天
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 14:45
功能
- 聊天
游戏内截图

服务关系图
graph TD
subgraph "游戏逻辑层"
F[qexed_game_logic]
end
subgraph "聊天管理层"
C[qexed_chat:manage]
end
subgraph "聊天任务层"
B[qexed_chat:task]
D[qexed_chat:task]
E[qexed_chat:task]
end
subgraph "数据包处理层"
A[qexed_packet_split]
end
F -->|1.获取聊天管理器| C
C -->|2.创建聊天服务| B
B -->|3.返回聊天服务句柄| F
F -->|4.移交聊天管道| A
A -->|5.分发聊天数据包| B
B -->|6.广播聊天事件| C
C -->|7.分发给所有客户端| B
C -->|7.分发给所有客户端| D
C -->|7.分发给所有客户端| E
配置文件
version = 0
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| version | i32 | 配置文件版本 |
命令
暂无
常见问题
暂无
qexed_command 指令
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 15:25
功能
- 注册指令
- 校验权限
- 执行指令
游戏内截图

服务关系图
graph TD
%% 输入层
subgraph "输入层"
B[qexed_cli<br/>终端命令行]
A[qexed_one<br/>统一入口]
F[qexed_packet_split<br/>数据包处理]
end
subgraph "游戏逻辑层"
G[qexed_game_logic<br/>游戏主逻辑]
end
%% 指令管理层
subgraph "指令管理层"
H[qexed_command:manage<br/>指令管理器]
end
%% 指令执行层
subgraph "指令执行层"
C[qexed_command:task<br/>指令任务]
D[qexed_permission<br/>权限验证]
N[qexed_command:command<br/>指令执行器]
end
%% 网络层
subgraph "网络层"
E[qexed_tcp_connect_app<br/>TCP连接应用]
end
%% 条件判断节点
I{是否已注册?}
J{是否具备权限?}
L{检测调用者类型}
M{指令是否执行成功?}
%% 流程连接
%% 1. 终端指令流程
B -->|终端命令行| A
A -->|传递终端指令| H
H -->|解析指令| I
%% 2. 游戏内指令流程
G -->|创建玩家指令任务| C
C -->|转让任务所有权| F
F -->|传递玩家指令| C
C -->|解析指令| I
%% 3. 权限验证流程
I -->|请求权限检查| D
D -->|验证结果| J
%% 4. 权限分支
J -->|有权限| N
J -->|无权限| L
%% 5. 调用者检测分支
L -->|玩家调用| C
L -->|终端调用| H
%% 6. 指令执行流程
N -->|执行指令| M
M -->|执行成功| E
M -->|执行失败| L
%% 7. 结果发送
N -->|构建数据包并发送| E
%% 样式定义
classDef input fill:#2d5f91,stroke:#1e3a5f,color:#fff
classDef logic fill:#4a148c,stroke:#1e3a5f,color:#fff
classDef management fill:#0d47a1,stroke:#1e3a5f,color:#fff
classDef execution fill:#006064,stroke:#1e3a5f,color:#fff
classDef network fill:#1b5e20,stroke:#1e3a5f,color:#fff
classDef condition fill:#bf360c,stroke:#1e3a5f,color:#fff
%% 应用样式
class B,F input
class G logic
class A,H management
class C,D,N execution
class E network
class I,J,L,M condition
%% 添加图例
subgraph "图例"
LR1[输入层]:::input
LR2[游戏逻辑层]:::logic
LR3[指令管理层]:::management
LR4[指令执行层]:::execution
LR5[网络层]:::network
LR6[条件判断]:::condition
end
配置文件
version = 0
tab = true
game_stop_cmd = false
game_var_cmd = true
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| version | i32 | 配置文件版本 |
| tab | bool | 启用tab补全功能(如果禁用意味着你只能手动help查询帮助了)(暂未启用) |
| game_stop_cmd | bool | 启用服内stop命令(高风险命令!!!) |
| game_var_cmd | bool | 启用服内version命令(查看服务器信息)(暂未启用) |
命令
玩家列表的命令相对简单,只有查询功能而已
/help 帮助指令
描述: 查询已注册且有权限的指令
权限组要求: exed.help
另名:帮助、?、helpme
参数:page_or_command
指令说明: 每页10个指令,如下:
/list [页码:int]
/list [指令:String]
常见问题
暂无
游戏逻辑
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 15:25
描述
正在编写,后续编写文档(这功能是全Qexed最复杂的一部分了)
Ping服务
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 15:25
描述
当前版本未启用
qexed_heartbeat 心跳服务
文档信息
- 配置版本:0
- 最后更新:2025年12月22日 15:35
功能
- 维护配置阶段与游戏阶段tcp连接心跳
服务关系图
graph TD
%% 定义节点样式
A[qexed_heartbeat<br/>心跳模块]:::mainNode
B[qexed_packet_split<br/>数据包分割]:::processNode
C[qexed_game_logic<br/>游戏逻辑]:::processNode
%% 主样式定义
classDef mainNode fill:#4CAF50,stroke:#388E3C,stroke-width:2px,color:white,font-weight:bold
classDef processNode fill:#2196F3,stroke:#1976D2,stroke-width:2px,color:white
classDef gameFlow fill:none,stroke:#4CAF50,stroke-width:2px,color:#4CAF50,font-weight:bold
classDef configFlow fill:none,stroke:#FF9800,stroke-width:2px,color:#FF9800,font-weight:bold
%% 游戏阶段心跳流
subgraph "游戏阶段心跳"
direction LR
A -- "发送游戏阶段心跳" --> B
B -. "游戏阶段心跳返回结果" .-> A
end
%% 配置阶段心跳流
subgraph "配置阶段心跳"
direction LR
A == "发送配置阶段心跳" ==> C
C -. "配置阶段心跳返回结果" .-> A
end
%% 应用样式到连线
linkStyle 0 stroke:#4CAF50,stroke-width:2px
linkStyle 1 stroke:#4CAF50,stroke-width:2px,stroke-dasharray:5
linkStyle 2 stroke:#FF9800,stroke-width:2px
linkStyle 3 stroke:#FF9800,stroke-width:2px,stroke-dasharray:5
%% 图例
subgraph "图例"
Legend1[实线箭头: 请求]:::legend
Legend2[虚线箭头: 响应]:::legend
Legend3[绿色: 游戏阶段]:::legend
Legend4[橙色: 配置阶段]:::legend
end
classDef legend fill:#f9f9f9,stroke:#ddd,stroke-width:1px,color:#333
配置文件
interval_seconds = 5
timeout_seconds = 30
max_consecutive_misses = 3
enabled = true
参数说明
| 参数 | 类型 | 说明 |
|---|---|---|
| interval_seconds | i32 | 心跳间隔(秒)(超过大概30秒左右的时间客户端会断开连接!!!) |
| timeout_seconds | i32 | 超时时间(秒) |
| max_consecutive_misses | u32 | 最大连续丢失次数 |
| enabled | bool | 是否启用心跳 |
命令
无
常见问题
无
实体id分配器
暂未启用
区块
开发中内容