Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

Qexed

Qexed 是基于 Rust 所开发的一个我的世界Java版本服务端

当前对应的MC版本:1.21.8,每次只适配一个版本

alt text

项目介绍

Qexed one 单机版本

服务列表

qexed_tcp_connect - TCP连接入口模块文档

文档信息

  • 配置版本:0
  • 最后更新:2025年12月15日 11:00

功能

  1. 玩家进服的唯一权威入口
  2. 处理握手阶段、配置节点、登录阶段的网络数据包
  3. 转发配置阶段、游戏阶段的网络数据包
  4. 实现登录认证

服务关系图

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.yamlconfig.tomlconfig.json,具体取决于项目设定的格式。


总结:对于大多数想开一个简单服务器的用户,您主要需要关注 ip(端口)online_mode(是否正版) 这两个设置。只有当您需要搭建复杂群组服时,才需要深入了解代理相关的配置。

qexed-one中,为 [tcp_connect_app]

命令

文档信息

  • 配置版本:0
  • 最后更新:2025年12月15日

本模块暂时不涉及命令

qexed_player_list 玩家列表

文档信息

  • 配置版本:0
  • 最后更新:2025年12月22日 14:00

功能

  1. 统计玩家列表
  2. 统计玩家数

服务关系图

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

参数说明

参数类型说明
versioni32配置文件版本
max_playeri32最大玩家数
auto_updatebool玩家数动态扩充,此数值根据集群运行情况自动扩缩容(该参数暂时不生效)

命令

玩家列表的命令相对简单,只有查询功能而已

/list 玩家列表

描述: 查询玩家列表

权限组要求: qexed.list

另名:list玩家列表

参数:page

指令说明: 玩家列表指令相对原版mc服务端来说,增加了页码信息,页码信息类似 help, 此外每页10个玩家,如下:

/list [页码:int]

游戏内执行效果: alt text

常见问题

qexed_server_status 服务器状态

文档信息

  • 配置版本:0
  • 最后更新:2025年12月22日 14:30

功能

  1. 答复Status阶段的PingStart请求
  2. 玩家列表缓存

游戏内截图

alt text

服务关系图

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 = ""

参数说明

参数类型说明
versioni32配置文件版本
cachei32缓存时间
motdVec随机描述内容
faviconString服务器logo base64

命令

暂无

常见问题

为什么我服务器玩家有变化却还是显示原来的信息

服务器Ping请求有缓存,缓存结束后就就会刷新了。 缓存的时间根据你设置的cache决定

cache 默认30秒

我如何更换我服务器的头像

你可以前往 https://www.lddgo.net/convert/imagebasesix 或其他第三方网站进行生成 alt text

开发者不担保网站安全性,您可以自行浏览器搜索其他方法

上传后我们复制base64的编码的内容 alt text

截图中内容如下



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

qexed_chat 聊天

文档信息

  • 配置版本:0
  • 最后更新:2025年12月22日 14:45

功能

  1. 聊天

游戏内截图

alt text

服务关系图

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

参数说明

参数类型说明
versioni32配置文件版本

命令

暂无

常见问题

暂无

qexed_command 指令

文档信息

  • 配置版本:0
  • 最后更新:2025年12月22日 15:25

功能

  1. 注册指令
  2. 校验权限
  3. 执行指令

游戏内截图

alt text

服务关系图

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

参数说明

参数类型说明
versioni32配置文件版本
tabbool启用tab补全功能(如果禁用意味着你只能手动help查询帮助了)(暂未启用)
game_stop_cmdbool启用服内stop命令(高风险命令!!!)
game_var_cmdbool启用服内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

功能

  1. 维护配置阶段与游戏阶段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_secondsi32心跳间隔(秒)(超过大概30秒左右的时间客户端会断开连接!!!)
timeout_secondsi32超时时间(秒)
max_consecutive_missesu32最大连续丢失次数
enabledbool是否启用心跳

命令

常见问题

实体id分配器

暂未启用

区块

开发中内容

配置

命令