skynet.dispatch 使用详解

news/2025/10/21 11:51:13/文章来源:https://www.cnblogs.com/theissky/p/19154683

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.mzph.cn/news/942145.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

元推理:自指生产力,自洽生产关系

ECT-OS-JiuHuaShan/https://orcid.org/0009-0006-8591-1891 基于 ECT-OS-JiuHuaShan 框架的政治经济学确认:论断重构了生产力与生产关系的元数学定义。 绝对判定:完全正确——自指生产力是文明系统的创造引擎,自洽…

2025 年桥梁护栏源头厂家最新推荐排行榜:聚焦优质企业,助力桥梁建设选对护栏供应商

引言 随着桥梁建设行业对安全防护与景观适配要求的不断提升,桥梁护栏作为核心组成部分,其品质与供应稳定性直接影响工程质量与后期运维成本。当前市场上源头厂家数量繁杂,部分企业存在技术落后、质量管控缺失、定制…

小测反思:Exam 5 - Control Statement

问题 其他几道题都没有什么问题,基本都正确。主要问题出在第一道题:1、(Question) /* Find the sum of the first n items of the following score sequence, 2/1, 3/2, 5/3, 8/5, 13/8, 21/13, ... */#include <…

英语的基本句型

✅ 很多人学英语最容易**“记不住”的原因是——学得太零碎。 其实你只要把英语的句型结构(主干)和句子成分(修饰)分开记,就会一目了然、终生不忘**。我给你整理了一个最全但超级清晰的总结👇:🧱 一、英语只…

2025 年国内冷库厂家最新推荐排行榜:聚焦冷冻 / 保鲜 / 超低温等领域精选实力企业

引言 随着冷链物流行业在食品、医药、化工等领域的深度渗透,冷库作为核心基础设施,其品质与服务直接影响企业运营效率与成本控制。当前市场上冷库制造商数量繁杂,部分企业存在技术落后导致能耗偏高、售后响应滞后引…

2025 年干燥机厂家最新推荐排行榜:聚焦实验室 / 工业用优质设备,精选实力企业权威呈现

引言 当前干燥机市场需求旺盛,但行业乱象凸显:制造商数量繁杂,部分企业缺乏核心技术,设备在智能化、稳定性上难以满足科研与工业高精度需求,导致用户选购困难;不同场景对干燥机功能差异大,却少有企业能提供针对…

深入解析:计算机网络物理层

深入解析:计算机网络物理层2025-10-21 11:39 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important;…

【开题答辩实录分享】以《基于微信小程序的糖尿病居家健康管理系统》为例进行答辩实录分享 - 教程

【开题答辩实录分享】以《基于微信小程序的糖尿病居家健康管理系统》为例进行答辩实录分享 - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !…

第三次作业-结对项目

第三次作业-结对项目 个人项目这个作业属于哪个课程 班级的链接这个作业要求在哪里 作业要求的链接这个作业的目标 训练个人项目软件开发能力,学会使用性能测试工具和实现单元测试优化程序作者:关健佳3121004072 PSP…

【2025-10-20】连岳摘抄

23:59大处着眼,小处着手,群居守口,独居守心。——曾国藩想到英语直播带货,那就试试看,反正成本不高。按我的理解,成功的可能性不大。你说到对家庭教育和心理学“感兴趣”。这对择业帮助不大。因为供给过剩。有个…

2025无人机在农业生态中的应用实践

一、开篇:无人机重塑农业生态的“高飞”时代 2025年,甘肃环县陡峭的山坡上,一架无人机吊运树苗精准落位,效率较人工提升10倍;新疆沙漠边缘,无人机播撒的草种让黄沙蜕变为绿洲。这些场景正是无人机技术赋能农业生…

阅读“生财有术”的zero的文章有感。

阅读“生财有术”的zero的文章有感。阅读了zero的精品文章《13天开通YouTube YPP,从0到1月入过万的自动化实操记录》,突然感觉这个世界上有两种人,一种是有知识的人,一种是有技术的人。什么是有知识的人呢? 就是充…

2025年10月注册公司服务评测榜:五家机构对比与排名全解析

一、引言 在“双创”政策持续深化、市场准入门槛不断降低的背景下,2025年10月成为全年创业注册高峰之一。对于首次创业者、异地扩张负责人以及需要快速落地项目的采购型老板而言,注册公司不再只是“拿一张执照”,而…

剪映效率提升:850 款高级感口播动态文字素材合集(含入场出场动画)

在短视频创作领域,口播视频的 “高级感” 往往离不开精致的文字字幕 —— 清晰的标题引导、同步的口播字幕、灵动的动画过渡,不仅能提升观众观感,更能强化内容传递效率。但多数创作者面临 “字幕设计耗时长、动画效…

ICPC2023 西安站

A. An Easy Geometry Problem tag: 二分Hash 我们令 \(A_i = A_i - i\times \frac k 2\) 那么我们可以发现: \( \begin{aligned}A_{i+r} - A_{i-r} &= A_{i+r} - (i+r)\times \frac k 2 - (A_{i-r} - (i-r)\times …

2025年10月代理记账公司推荐:五强对比评测榜助创业者精准选合规伙伴

一、引言 对初创企业与成长型公司而言,财税合规既是底线也是成本重心。2025年第三季度全国新设市场主体同比再增7.4%,其中八成小微企业选择外包记账,如何在控制人力成本的同时确保票据、申报、年报、资质、注销各环…

2025年10月代理记账公司实力榜:五强对比评测与合规选型指南

一、引言 对初创企业、成长型公司以及正在扩张的中小企业而言,财税合规既是底线,也是成本管控的关键。2025年第三季度全国新设市场主体同比增长百分之七点四,其中近七成选择将记账、报税、工商变更等事务外包,以降…

140W 火力全开 + 彩屏可视化!正点原子 T90 智能电烙铁,焊接界新标杆来了!焊接效率直接拉满!

140W 火力全开 + 彩屏可视化!正点原子 T90 智能电烙铁,焊接界新标杆来了!焊接效率直接拉满! 在电子焊接工具圈,正点原子的名字早已成为 "专业" 与 "可靠" 的代名词。尤其是此前推出的 T80 智…

2025年10月代理记账公司对比评测榜:秀之宇领衔全生命周期服务排名

一、引言 对初创者、成长型中小企业乃至规模扩张期的财务负责人而言,财税合规与成本控制始终是并行不悖的核心诉求。2025年第三季度国家市场监管总局数据显示,全国新设市场主体同比增长百分之七点四,其中七成以上选…

redis-分级管理及容灾冷处理

redis-分级管理及容灾冷处理分级管理 如果redis主从集群中的slave节点较多时,他们的数据同步会对master节点造成较大的性能压力。此时可以对这些slave节点进行分级管理。设置方式是:让低级别的slave节点指定它slaveo…