Posted by:
努力记

努力记,通过记录,计划,让自己的努力可以触碰彩虹!

8,747

Pomelo:分布式Node.js框架

  • 2014-09-06
  • 暂无评论
pomelo 是由网易开发的基于node.js开发的高性能、分布式游戏服务器框架, 也可作为高实时web应用框架。

Pomelo的应用范围

pomelo最适合的应用领域是网页游戏、社交游戏、移动游戏的服务端,开发者会发现pomelo可以用如此少的代码达到强大的扩展性和伸缩性。当然还不仅仅是游戏,很多人断言未来的web时代是实时web应用的时代, 我们发现用pomelo开发高实时web应用也如此合适, 而且伸缩性比其它框架好。目前不推荐将pomelo用于大型的MMO rpg游戏开发,尤其是3d游戏, 还是需要象bigworld这样的商用引擎来支撑。

Pomelo的理念

pomelo的第一个理念是让游戏(高实时web应用)服务器的开发变得非常简单, 而不是解决某类算法或系统上的难题。这个设计理念跟rails是很类似的;第二个理念是重视性能和可伸缩性,用户用pomelo开发出来的游戏天生具有很强的伸缩性,扩展也很容易。我们在性能优化上也花了很多功夫,并且会持续进行;第三个理念是让第三方很容易扩展,框架用了很多插件式的设计, 组件component、路由规则、甚至管理控制台都可以完全由第三方扩展。

Pomelo的框架组成

pomelo包括三部分:

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

pomelo特性

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

为什么使用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的设计与开发思路。
以上是官方的说明信息
 
如果不考虑其提供的游戏常用工具库,该框架的应用访问则是高性能的web应用,在高并发的node.js的基础上提供了分布式的框架基础来实现更搞可用性的服务需求
 
pomelo
pomelo的分布式配置方案需要建立在:

所有参与分布式部署的机器:

  • 必须为同类操作系统(建议为完全相同的操作系统).
  • 必须都有一个同名的用户(如:"pomelo"等).
  • Node.js的安装版本必须完全相同, 安装的绝对路径也必须完全相同
  • "lordofpomelo"所放置的绝对路径也必须完全相同
  • 在所有参与分布式部署的机器上配置ssh登录选项. 方法为: 在"~/.ssh"目录下创建一个名为"config"的文件, 文件内容如下:
# 主要是保证主机见ssh访问不会出现异常情况,但也增加了安全风险
# 任何主机访问
Host *
# 是否hash存储已知的访问主机
HashKnownHosts no
# 是否检测访问主机的IP地址
CheckHostIP no
# 是否检测访问主机的密钥
StrictHostKeyChecking no
各个服务器见可以直接通过ssh进行密钥登录,mater服务自动去各个服务器上启动脚本,所以要保证目录的一致性,全局安装pomelo
master的高可用通过pomelo-masterha-plugin和zookeeper配合实现


back up ↑

无觅相关文章插件,快速提升流量