当前位置: 首页 > news >正文

skynet.dispatch 使用详解

skynet.dispatch 是 Skynet 框架中用于注册消息处理函数的核心 API。它的作用是为特定类型的消息绑定处理逻辑,当服务收到该类型的消息时,自动调用对应的处理函数。以下是其详细解析:


1. 函数定义与参数

skynet.dispatch(type, func)
  • type:消息类型(字符串或数字)。
    • 常见类型:
      • "lua":默认的 Lua 消息协议(对应 skynet.PTYPE_LUA)。
      • "socket":网络消息(对应 skynet.PTYPE_SOCKET)。
      • 自定义类型:通过 skynet.register_protocol 注册的协议类型。
  • func:消息处理函数,格式为 function(session, source, ...)
    • session:会话 ID,用于响应消息(如 skynet.ret)。
    • source:发送方服务的地址(skynet.address 格式)。
    • ...:消息内容(由协议定义的解包逻辑生成)。

2. 消息处理流程

当服务收到一条消息时,Skynet 会执行以下步骤:

  1. 协议匹配:根据消息类型(如 "lua")找到对应的解包函数。
  2. 消息解包:调用协议注册的 unpack 函数,将二进制数据解析为 Lua 值。
  3. 分发处理:调用 skynet.dispatch 注册的处理函数,传入 sessionsource 和解包后的数据。
  4. 协程调度:处理函数在一个独立的协程中执行,避免阻塞其他消息处理。

3. 使用示例

示例 1:处理 Lua 协议消息

local skynet = require "skynet"-- 注册 Lua 类型消息的处理函数
skynet.dispatch("lua", function(session, source, cmd, ...)if cmd == "add" thenlocal a, b = ...skynet.ret(skynet.pack(a + b))elseif cmd == "ping" thenskynet.ret(skynet.pack("pong"))end
end)skynet.start(function()-- 服务初始化代码
end)
  • 说明
    • 当收到 "lua" 类型的消息时,解析出命令 cmd 和参数。
    • 根据 cmd 执行逻辑,并通过 skynet.ret 返回结果。

示例 2:处理自定义协议消息

local skynet = require "skynet"-- 注册自定义协议
skynet.register_protocol {name = "myproto",id = 100,  -- 自定义协议 ID(需唯一)unpack = function(msg, sz)-- 自定义解包逻辑(如 sproto 解析)return myproto.decode(msg, sz)end
}-- 处理自定义协议消息
skynet.dispatch("myproto", function(session, source, data)print("Received:", data)skynet.ret()  -- 无返回值
end)skynet.start(function()-- 服务初始化代码
end)
  • 说明
    • 自定义协议需要先通过 skynet.register_protocol 注册。
    • 收到类型为 "myproto" 的消息时,调用自定义解包函数,并处理数据。

4. 关键机制

(1) 协程与阻塞操作

  • 协程调度:每条消息的处理在独立协程中执行,互不阻塞。
  • 阻塞 API:若处理函数中调用 skynet.callskynet.sleep 等阻塞 API,当前协程会被挂起,直到操作完成。
    skynet.dispatch("lua", function(session, source, cmd)if cmd == "slow_task" thenskynet.sleep(100)  -- 挂起协程 1 秒skynet.ret("Done")end
    end)

(2) 消息响应

  • skynet.ret:用于向发送方返回响应。
    • 若消息是请求(skynet.call),必须调用 skynet.ret
    • 若消息是通知(skynet.send),无需返回。
      skynet.dispatch("lua", function(session, source, cmd)if session ~= 0 then  -- 需要响应skynet.ret(skynet.pack("Response"))end
      end)
       

5. 与 skynet.register_protocol 的协作

  • 协议注册:定义如何解析和打包消息。
    skynet.register_protocol {name = "binary",id = skynet.PTYPE_USER,  -- 自定义 IDunpack = function(msg, sz) return msg, sz end,  -- 不解包,直接传递原始数据pack = skynet.pack  -- 默认打包函数
    }
  • 消息分发:通过 skynet.dispatch 绑定处理逻辑。
    skynet.dispatch("binary", function(session, source, msg, sz)-- 处理二进制数据
    end)
     

6. 注意事项

  1. 避免阻塞主线程
    若处理函数中有耗时操作(如大量计算、同步 IO),应使用 skynet.fork 创建新协程。

    skynet.dispatch("lua", function(session, source, cmd)if cmd == "heavy_task" thenskynet.fork(function()-- 在子协程中执行耗时操作local result = heavy_compute()skynet.ret(skynet.pack(result))end)end
    end)
  2. 协程生命周期
    确保每个协程最终退出,避免内存泄漏(如通过 pcall 捕获异常)。

  3. 线程安全
    Skynet 服务是单线程的,但协程间共享 Lua 虚拟机状态,需谨慎处理共享数据(推荐使用 skynet.sharedata)。


7. 典型应用场景

  • RPC 调用:处理远程服务请求并返回结果。
  • 网络消息:解析 TCP/UDP 数据包,如游戏协议、HTTP 请求。
  • 定时任务:通过 skynet.timeout 触发延时逻辑。
http://www.hskmm.com/?act=detail&tid=35651

相关文章:

  • 深入解析:开源项目net-radio-archive常见问题解决方案
  • 元推理:自指生产力,自洽生产关系
  • 2025 年桥梁护栏源头厂家最新推荐排行榜:聚焦优质企业,助力桥梁建设选对护栏供应商
  • skynet.start 的作用详细解析
  • 2025 年干燥机厂家最新推荐排行榜:聚焦实验室 / 工业用优质设备,精选实力企业权威呈现
  • 英语的基本句型
  • MySQL学习笔记
  • 第三次作业-结对项目
  • 【2025-10-20】连岳摘抄
  • 2025无人机在农业生态中的应用实践
  • 【2025-10-19】连岳摘抄
  • 中国企业DevOps工具链选型新趋势:场景适配与生态协同成关键考量
  • 2025年10月注册公司服务评测榜:五家机构对比与排名全解析
  • 剪映效率提升:850 款高级感口播动态文字素材合集(含入场出场动画)
  • ICPC2023 西安站
  • 2025年10月代理记账公司推荐:五强对比评测榜助创业者精准选合规伙伴
  • 2025年10月代理记账公司实力榜:五强对比评测与合规选型指南
  • 140W 火力全开 + 彩屏可视化!正点原子 T90 智能电烙铁,焊接界新标杆来了!焊接效率直接拉满!
  • 2025 年水泥管源头厂家最新推荐榜单:国标 / 二级 / 钢筋混凝土 / 大口径 / 平口等多类型产品实力企业全方位剖析
  • Redis常用命令指南
  • 2025 年塑胶跑道厂家最新推荐排行榜:聚焦优质企业核心优势,助力采购决策
  • 2025年10月益生菌厂家评价榜:五强排名与场景化选购建议
  • 【2025-10-18】连岳摘抄
  • 什么?就是工业视觉检测里的 “柔性”
  • 2025 年灌胶机厂家最新推荐排行榜:真空 / 全自动 / AB 双液等类型设备企业精选指南
  • 吴恩达深度学习课程一:神经网络和深度学习 第三周:浅层神经网络 课后作业和代码实践
  • 2025 年豆腐机厂家最新推荐榜权威发布:豆腐豆皮 / 豆干 / 成型机企业深度解析,附选型指南
  • TCP 和 UDP 协议的通信解析
  • office2024免费永久激活下载安装教程Office 2024 专业增强版下载安装教程(附激活步骤 + 快捷键)
  • 易基因:华农王应祥/杨存义ChIP-seq等揭示大豆开花时间调控及区域适应性的表观分子机制|NC(IF15.7)