写点什么

网易开源基于 Node.js 的游戏服务器框架 pomelo

  • 2012-11-24
  • 本文字数:2552 字

    阅读完需:约 8 分钟

最近,网易在 Github 上开源了基于 Node.js 的游戏服务器框架—— pomelo 。它包括基础的开发框架和相关的扩展组件(库和工具包),可以帮助开发人员省去游戏开发枯燥中的重复劳动和底层逻辑的开发。 pomelo 不但适用于游戏服务器开发, 也可用于开发高实时 Web 应用。

pomelo 框架包括三部分:

  • 框架, pomelo 的核心, 与以往单进程的游戏框架不同, 它是高性能、分布式的游戏服务器框架,并且使用很简单。
  • 库, 包括了开发游戏的常用工具库, 如人工智能 (ai)、寻路、aoi 等。
  • 工具包, 包括管理控制台、 命令行工具、压力测试工具等。

pomelo 的主要特性:

  • 快速、易上手的游戏开发模型和 API。
  • 高可伸缩的多进程架构, 支持 MMO 的场景分区和其它各类分区策略。
  • 方便的服务器扩展机制,可快速扩展服务器类型和数量。
  • 方便的请求、响应、广播、服务器通讯机制, 无需任何配置。
  • 注重性能,在性能、可伸缩性上做了大量的测试、优化。
  • 提供了较多扩展组件,包括游戏开发常用的库和工具包。
  • 提供了完整的 MMO demo 代码 (客户端 html5),可以作为很好的开发参考。
  • 基于 socket.io 开发,支持 socket.io 支持的多种语言客户端。

网易 pomelo 开发团队在项目主页上列举了推荐 pomelo 的理由:

高并发、高实时的游戏服务器的开发是很复杂的工作。跟 Web 应用一样,一个好的开源容器或开发框架可以大大减少游戏开发的复杂性,让开发变得更加容易。遗憾的是目前在游戏服务器开发领域一直没有太好的开源解决方案。 pomelo 将填补这个空白, 打造一款完全开源的高性能(并发)游戏服务器框架。

pomelo 的优势有以下几点:

  • 架构的可伸缩性好。 采用多进程单线程的运行架构,扩展服务器非常方便, Node.js 的网络 IO 优势提供了高可伸缩性。
  • 使用非常容易, 开发模型与 Web 应用的开发类似,基于 convention over configuration 的理念, 几乎零配置, API 的设计也很精简, 很容易上手。
  • 框架的松耦合和可扩展性好, 遵循 Node.js 微模块的原则, framework 本身只有很少的代码,所有 component、库、工具都可以用 npm module 的形式扩展进来。任何第三方都可以根据自己的需要开发自定义 module。
  • 提供完整的开源 MMO 游戏 demo 参考 (基于 HTML 5)。 一个超过 1 万行代码的游戏 demo,使开发者可以随时借鉴 demo 的设计与开发思路。

pomelo 为什么采用 Node.js 开发?

Node.js 自身特点与游戏服务器的特性惊人的吻合。 在 Node.js 的官方定义中, fast、scalable、realtime、network 这几个特性都非常符合游戏服务器的要求。游戏服务器是个网络密集型的应用,对实时性要求极高,而 Node.js 在网络 io 上的优势也完全可以满足这点。使用 Node.js 开发游戏服务器的优势总结:

  • io 与可伸缩性的优势。io 密集型的应用采用 Node.js 是最合适的, 可达到最好的可伸缩性。
  • 多进程单线程的应用架构。Node.js 天生采用单线程, 使它在处理复杂逻辑的时候无需考虑线程同步、锁、死锁等一系列问题, 减少了很多逻辑错误。 由多进程 Node.js 组成的服务器群是最理想的应用架构。
  • 语言优势。使用 javascript 开发可以实现快速迭代,如果客户端使用 HTML 5,更可实现代码共用。

网易 pomelo 开发团队介绍了游戏服务器的运行架构:

一个真正高可扩展的游戏运行架构必须是多进程的。Google 的 gritsgame ,、Mozilla 的 browserquest 都采用了 Node.js 作为游戏服务器开发语言, 但它们都采用了单进程的 Node.js 服务器,缺乏扩展性,这使它们可以支撑的在线用户数量是很有限的(这两个游戏主要是作为 HTML5 游戏的 demo)。而多进程的架构可以很好的实现游戏服务器的的扩展性,达到支撑较多在线用户、降低服务器压力等要求。

该游戏运行架构表面上看与 web 应用运行架构很类似,connector 类似于 web 应用的 apache/nginx 等 web 服务器,后端的服务器群类似于 web 应用中的应用服务器(如 tomcat),但实际上存在着很大的差别:

  • 长连接与短连接。web 应用使用基于 http 的短连接以达到最大的可扩展性,游戏应用采用基于 socket(websocket) 的长连接,以达到最大的实时性。
  • 分区策略不同。web 应用的分区可以根据负载均衡自由决定, 而游戏则是基于场景 (area) 的分区模式, 这使同场景的玩家跑在一个进程内,以达到最少的跨进程调用。
  • 有状态和无状态。web 应用是无状态的, 可以达到无限的扩展。 而游戏应用则是有状态的, 由于基于场景的分区策略,它的请求必须路由到指定的服务器, 这也使游戏达不到 web 应用同样的可扩展性。
  • 广播模式和 request/response 模式。web 应用采用了基于 request/response 的请求响应模式。而游戏应用则更频繁地使用广播,由于玩家在游戏里的行动要实时地通知场景中的其它玩家, 必须通过广播的模式实时发送。这也使游戏在网络通信上的要求高于 web 应用。

pomelo framework 的组成架构如图所示:

图片来源: Github 网易 pomelo 项目介绍

  • server management, pomelo 是个真正多进程、分布式的游戏服务器。因此各游戏 server(进程) 的管理是 pomelo 很重要的部分,框架通过抽象使服务器的管理非常容易。
  • network, 请求、响应、广播、RPC、session 管理等构成了整个游戏框架的脉络,所有游戏流程都构建在这个脉络上。
  • application, 应用的定义、component 管理,上下文配置, 这些使 pomelo framework 的对外接口很简单,并且具有松耦合、可插拔架构。

pomelo 的架构设计目标:

  • 服务器(进程)的抽象与扩展:在 web 应用中, 每个服务器是无状态、对等的, 开发者无需通过框架或容器来管理服务器。但游戏应用不同, 游戏可能需要包含多种不同类型的服务器,每类服务器在数量上也可能有不同的需求。这就需要框架对服务器进行抽象和解耦,支持服务器类型和数量上的扩展。
  • 客户端的请求、响应、广播:客户端的请求、响应与 web 应用是类似的, 但框架是基于长连接的, 实现模式与 http 请求有一定差别。广播是游戏服务器最频繁的操作, 需要方便的 API, 并且在性能上达到极致。
  • 服务器间的通讯、调用:尽管框架尽量避免跨进程调用,但进程间的通讯是不可避免的, 因此需要一个方便好用的 RPC 框架来支撑。
  • 松耦合、可插拔的应用架构:应用的扩展性很重要, pomelo framework 支持以 component 的形式插入任何第三方组件, 也支持加入自定义的路由规则、 自定义的 filter 等。

感兴趣的读者可以访问 Github 网易 pomelo 项目主页了解更多详情。

2012-11-24 02:4016102
用户头像

发布了 501 篇内容, 共 283.6 次阅读, 收获喜欢 64 次。

关注

评论

发布
暂无评论
发现更多内容

Springboot之如何纯文本转成.csv格式文件?|超级详细,建议收藏

bug菌

Spring Boot 2 spring-boot 三周年连更

Spring Boot 整合 Redis 基于 Stream 消息队列 实现异步秒杀下单

从源码全面解析LinkedBlockingQueue的来龙去脉

Linux常用命令

追赶者

进程 SSH Liunx 端口占用

大连理工大学OpenHarmony技术俱乐部正式揭牌成立

极客天地

sqlserver锁表产生的原因

linux大本营

数据库· SQL sever 表锁

强强联手:机器学习与运筹学

鼎道智联

算法

合合信息新推出反光消除技术,助力手写文字识别更精准

合合技术团队

人工智能 文字识别 扫描全能王 反光去除

机器学习分布式框架Ray

AIWeker

Python 分布式 python小知识 三周年连更

使用了Spring的事件机制真香!

Java spring

第二届广州·琶洲算法大赛启动,百度飞桨助力广州打造中国算法新高地

飞桨PaddlePaddle

算法 百度飞桨 文心大模型

读书笔记丨远程服务调用和RESTful,如何分析和抉择?

华为云开发者联盟

开发 华为云 华为云开发者联盟 企业号 4 月 PK 榜 远程服务调用

麻了,不要再动不动就BeanUtil.copyProperties!

awk常量和标识符

linux大本营

脚本 awk

用c++写一段快速排序算法

linux大本营

排序算法 数据结构与算法 C++

和面试官聊1小时Java并发,多亏GitHub上这份笔记

Java 并发编程

那些关于DIP器件不得不说的坑

华秋PCB

插件 DIP 元器件 PCB PCB设计

阿里新一代微服务,内部大佬手抄的笔记+脑图不容错过,全是精华

Java 架构 微服务 Spring Cloud Aliababa

【微信小程序管理】第三方软件的优势有哪些

没有用户名丶

在毫秒量级上做到“更快”!DataTester助力飞书提升页面秒开率

字节跳动数据平台

大数据 AB testing实战 用户体验 企业号 4 月 PK 榜 秒开率

【FAQ】关于JavaScript版本的华为地图服务Map的点击事件与Marker的点击事件存在冲突的解决方案

HarmonyOS SDK

HMS Core

ChatGPT 会在三年内终结编程吗?| 社区征文

神木鼎

三周年征文

Apifox WebSocket 调试功能你会用了吗?

Apifox

程序员 接口 websocket API API 调试

c++实现一个tcp高性能网络服务器

linux大本营

TCP 多线程 异步IO epoll 高性能服务器

一个解决tcp粘包问题的c++代码

linux大本营

TCP 网络协议 C++ TCP 粘包

ByteHouse云数仓版查询性能优化和MySQL生态完善

NineData

数据库 架构 字节跳动 Clickhouse bytehouse

Gradio入门到进阶全网最详细教程[二]:快速搭建AI算法可视化部署演示(侧重参数详解和案例实践)

汀丶人工智能

人工智能 机器学习 深度学习 Gradio AI可视化

Apache Flink ML 2.2.0 发布公告

阿里云大数据AI技术

大数据 算法 企业号 4 月 PK 榜

eBPF的发展演进---从石器时代到成为神(二)

统信软件

Linux Kenel 内核 Linux内核

华为开发者大赛中国区正式启动 携手探索ICT无限可能

极客天地

蚂蚁安全科技 Nydus 镜像加速实践

SOFAStack

开源 镜像 镜像安全 OCI Nydus

网易开源基于Node.js的游戏服务器框架pomelo_Web框架_崔康_InfoQ精选文章