Skynet 框架中 gateserver、gate、watchdog 的关系


一、概述

在 Skynet 框架的网络通信架构中,gateserver、gate、watchdog 是三个核心组件,共同实现客户端连接的监听、管理和业务逻辑的分发。其设计目标是通过分层解耦,提升网络层的稳定性与业务逻辑的灵活性。

二、组件职责
1. ‌gateserver‌
定位‌:网络通信基础模块(位于 lualib/snax/gateserver.lua)。
核心功能‌:
端口监听与底层 TCP/UDP 连接管理。
接收客户端原始数据,通过 MSG.data 事件转发数据。
处理连接建立(MSG.open)和断开(MSG.close)事件。
关键接口‌:
CMD.open(address, port):启动端口监听。
CMD.forward(fd, address):将客户端连接转发到指定服务。
2. ‌gate‌
定位‌:标准网关服务(位于 service/gate.lua),基于 gateserver 封装。
核心功能‌:
监听端口并接收客户端连接请求。
维护 fd(文件描述符)→ agent 的映射关系。
将新连接通知 watchdog,并转发后续数据至对应的 agent 服务。
关键接口‌:
gate.open(watchdog_address):启动网关并与 watchdog 绑定。
gate.forward(fd, agent_address):建立 fd 与 agent 的绑定关系。
3. ‌watchdog‌
定位‌:用户自定义的管理服务。
核心功能‌:
初始化 gate 服务并触发 gate.open 启动监听。
响应 gate 的连接请求,动态创建 agent 服务实例。
协调 gate 与 agent 的交互逻辑,维护全局状态(如连接数统计)。

三、协作流程
1. ‌初始化阶段‌
lua
Copy Code
-- watchdog 启动流程示例
local watchdog = skynet.newservice("watchdog")
skynet.call(watchdog, "lua", "start", { port = 8888 })

watchdog 调用 gate.open,触发 gateserver 初始化并绑定端口。
gate 记录 watchdog 的地址,等待连接事件。
2. ‌客户端连接处理‌
客户端发起连接,触发 gateserver 的 MSG.open(fd, addr) 事件。
gate 将 fd 和客户端信息通过消息(如 skynet.send)发送给 watchdog。
watchdog 创建 agent 服务,并调用 gate.forward(fd, agent_address) 绑定 fd 与 agent。
3. ‌消息转发流程‌
首次连接‌:
agent 调用 gate.forward 建立转发通道。
后续通信‌:
客户端数据经 gateserver 触发 MSG.data(fd, data)。
gate 根据 fd→agent 映射,将数据直接转发至 agent。

四、架构关系图
mermaid
Copy Code
graph TD
    Client -->|TCP/UDP| gateserver
                              gateserver -->|事件驱动| gate
                             gate -->|创建通知| watchdog
                              watchdog -->|动态创建| agent
                              gate -->|数据转发| agent

五、关键设计优势

分层解耦‌:

gateserver 专注底层网络通信。
gate 负责连接管理与转发。
watchdog 和 agent 处理业务逻辑,与网络层隔离。

动态扩展性‌:

agent 按需创建,支持高并发场景。
watchdog 可自定义策略(如负载均衡、鉴权)。

资源高效利用‌:

仅需少量 gate 服务(通常单节点一个),通过 fd 映射管理大量连接。
六、典型配置示例
gate 服务配置
lua
Copy Code
-- 在 watchdog 中启动 gate
local gate = skynet.newservice("gate")
skynet.call(gate, "lua", "open", {
    address = "0.0.0.0",
    port = 8888,
    watchdog = watchdog_address,  -- watchdog 自身地址
})

agent 服务示例
lua
Copy Code
-- agent 初始化后向 gate 注册转发
function agent.init(fd, gate_address)
    skynet.call(gate_address, "lua", "forward", fd, skynet.self())
end

七、总结
gateserver‌:网络通信基石,提供原始连接管理。
gate‌:连接与数据的中转枢纽,解耦网络与业务。
watchdog‌:全局协调者,动态管理 agent 生命周期。

三者协作形成 Skynet 高并发网络服务的核心架构,适用于游戏服务器、实时通信等场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/41879.html

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

相关文章

Win11系统下qq远程不能控制对方电脑(鼠标点不动)的解决方法

在被控制的电脑上,打开控制面板,点击系统和安全 点击更改用户账户控制设置 下拉用户控制设置至最低,从不通知,点击确定 返回控制面板系统与安全,带年纪允许远程访问 点击允许远程协助连接这台计算机 重启电脑 再次打…

猎豹移动营收连续三季增长,AI驱动的猎豹成绩单怎么分析?

3月26日,猎豹移动发布2024年Q4及全年财报,这份财报我们到底该该怎么分析呢? 首先,整体财务表现稳健,营收连续三季增长。从财务数据来看,猎豹移动整体表现稳健。2024年Q4及全年财报显示,总收入达…

函数:链式访问

链式访问是将函数的返回值当作回传值就是链式访问 这是原本的字符数回传代码 int main() {int len strlen("seig heil");printf("%d", len);return 0; } 运行结果: 这是链式访问的代码: int main() {printf("%d\n",s…

C++ map容器总结

map基本概念 简介: map中所有元素都是pair pair中第一个元素为key(键值),起到索引作用,第二个元素为value(实值) 所有元素都会根据元素的键值自动排序 本质: map/multimap属于关…

23种设计模式-代理(Proxy)设计模式

代理设计模式 🚩什么是代理设计模式?🚩代理设计模式的特点🚩代理设计模式的结构🚩代理设计模式的优缺点🚩代理设计模式的Java实现🚩代码总结🚩总结 🚩什么是代理设计模式…

UE4学习笔记 FPS游戏制作29 更换武器时更换武器的图标

文章目录 制作物体图标UI添加获取武器图标的方法使用事件分发器,通知UI要换枪定义事件分发器调用事件分发器注册事件分发器 制作物体图标UI 在Fpp-UI上添加一个图片,改名为五weaponIcon,勾选SizeToContent,锚点放在右下角,对齐改…

Chrome 开发环境快速屏蔽 CORS 跨域限制!

Chrome 开发环境快速屏蔽 CORS 跨域限制【详细教程】 ❓ 为什么需要临时屏蔽 CORS? 在前后端开发过程中,我们经常会遇到 跨域请求被浏览器拦截 的问题。例如,你在 http://localhost:3000 调用 https://api.example.com 时,可能会…

【RAG综述系列】之 RAG 相关背景和基本原理

系列文章: 【RAG综述系列】之 RAG 相关背景和基本原理 【RAG综述系列】之 RAG 特点与挑战以及方法与评估 【RAG综述系列】之 RAG 先进方法与综合评估 【RAG综述系列】之 RAG 应用和未来方向 正文: 检索增强生成(Retrieval-Augmented Gen…

德昂观点:如何看待MicroStrategy改名为Strategy?

2025年2月,纳斯达克上市公司MicroStrategy(股票代码:MSTR)宣布更名为“Strategy”,并同步启用全新品牌标识与橙色主视觉。这不仅是品牌形象的更新,更是公司战略方向的明确宣示。德昂作为MSTR中国区BI合作伙…

计算机视觉算法实战——手术导航:技术、应用与未来

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​​​ ​​​​​​​​​ ​​ 1. 手术导航中的计算机视觉:领域介绍 计算机视觉在手术导航领域的应用代表了现代医学与人工智…

Java全栈面试宝典:内存模型与Spring设计模式深度解析

目录 一、JVM内存模型进阶篇 🔥 问题13:堆与栈的六大维度对比 内存结构对比图 核心差异对照表 🔥 问题14:三区联动内存模型解析 代码内存分配图解 三区协作流程图 二、Spring设计模式全景解析 🌟 Spring框架七…

FALL靶场通关攻略

1,下载好靶机后打开,通过kali扫描靶机ip和端口,得到靶机ip为192.168.50.144 2,扫描目录 3,访问靶机 4,访问扫描到的test.php,得到缺少GET请求参数的提示 5,使用FUZZ来扫出参数为file 6&#xff…

《C++11:bind绑定器与function包装器》

CSTL中提供了bind1绑定器,通常与函数对象一起使用。 函数对象是重载了operator()函数的对象。 将二元函数对象operator()的第一个参数绑定为固定的x来构造一元函数对象。返回绑定了第一个参数的函数对象。 将二元函数…

JS 防抖与节流

防抖 核心思想:延迟执行,只有在事件触发的频率降低到一定程度后才会执行,而且如果事件持续触发,之前地所有执行都会被取消。 有的操作是高频触发的,但是其实只需要一次触发。比如短时间内多次缩放页面resize&#xff0…

【C/C++算法】从浅到深学习--- 简单模拟算法(图文兼备 + 源码详解)

绪论:冲击蓝桥杯一起加油!! 每日激励:“不设限和自我肯定的心态:I can do all things。 — Stephen Curry” 绪论​: 本篇是一些简单的模拟算法,其中模拟的本质就是就是根据题目意思进行代码的…

​​解锁 JavaScript DOM:节点操作的核心方法与最佳实践

引言 在当今动态化的 Web 世界中,用户早已不满足于静态的网页展示,而是期待流畅的交互体验——点击按钮弹出菜单、滚动页面加载数据、实时搜索过滤内容……这些功能的背后,都离不开 ​JavaScript DOM(文档对象模型)操…

Android 12系统源码_系统启动(二)Zygote进程

前言 Zygote(意为“受精卵”)是 Android 系统中的一个核心进程,负责 孵化(fork)应用进程,以优化应用启动速度和内存占用。它是 Android 系统启动后第一个由 init 进程启动的 Java 进程,后续所有…

精华贴分享|从不同的交易理论来理解头肩形态,殊途同归

本文来源于量化小论坛策略分享会板块精华帖,作者为孙小迪,发布于2025年2月17日。 以下为精华帖正文: 01 前言 学习了一段时间交易后,我发现在几百年的历史中,不同门派的交易理论对同一种市场特征的称呼不一样&#x…

C++智能指针万字详细讲解(包含智能指针的模拟实现)

在笔试,面试中智能指针经常出现,如果你对智能指针的作用,原理,用法不了解,那么可以看看这篇博客讲解,此外本博客还简单模拟实现了各种指针,在本篇的最后还应对面试题对智能指针的知识点进行了拓…

学习threejs,使用多面体(IcosahedronGeometry、TetrahedronGeometry、OctahedronGeometry等)

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.PolyhedronGeometry …