摘录于CBE官方文档:https://www.comblockengine.com/docs/1.0/overview/index/

架构图总览:

Switch Fabric:交换机网络,根据网络环境的不同而不同,根据用户自己的情况进行配置,不属于引擎范畴。

运作流程:

1:Client接入我们提供的SDK或API,通过API连接Loginapp。
2:Loginapp处理账号登录的验证,其中数据会从DBMgr中请求获取。(如果挂接了Interfaces, 则可以通过Interfaces将登陆和注册请求转发到第三方服务,并且接收第三方服务的处理结果让引擎执行后续流程 )
3:如果登录验证通过,Loginapp会从BaseappMgr拿到最低负载的Baseapp,并通知Client该Baseapp的连接ip和端口。
4:Client通过API连接该Baseapp,并在Baseapp上生成Proxy代理对象与Client关联(默认的,会使用Account实体与之关联)。
5:根据业务的情况,需要创建一个Space空间内的实体时,如果目标空间不存在,则会向CellappMgr请求一个低负载的Cellapp,并在其上创建该空间。
6:在目标空间上创建Proxy对象(它是一个Entity的子类)的cell部分,使得该Proxy有了base部分以及对应空间内的cell部分。
7:通过Proxy,传递和接收Client、Baseapp上base部分、Cellapp上cell的信息,完成通讯过程。

Account实体是Client接入Baseapp时,第一个生成的实体,相当于账户实体。
其他涉及到的概念会在本文后面进行阐述。

基本概念:

Entity实体的概念

Entity实体被定义为服务端最基本的对象,类似Python的基础对象object。我们的通讯(远程访问)是通过Entity上的方法申明;我们的数据存储(数据库持久化存储)也是通过Entity上的属性进行。我们可以大体的理解为,引擎端的开发是基于Entity实体的。

实体包含哪几部分?

1、base部分:

实体在Baseapp上的对象(或称为实现),这部分叫做base部分。

2、cell部分:

实体在Cellapp上的对象(或称为实现),这部分叫做cell部分。

3、client部分:

实体在客户端上的对象(或称为实现),这部分叫做client部分。一般在客户端上进行实现,不在服务端范围内;

Proxy实体

有一个特殊的Entity实体–Proxy,它是Entity的子类,俗称代理类。它是连接客户端和服务端的通讯通道,但一个客户端只能拥有并控制一个Proxy,通过它可以把客户端的控制、交互传递给该实体的base和cell上。它只有在base上有而cell上没有。详情请查看api手册-Proxy

EntityCall的概念

《运作流程》中的通讯,都是靠EntityCall进行传递的,可以简单的理解为:封装远程交互、通讯等方法的一种对象,是脚本层与实体远程交互的常规手段。详情见《基础概念-EntityCall》。

Space的概念

Space空间是一个抽象概念,它只是存在于cellapp的内存中。由于空间是一个抽象的概念,所以具体是什么,是由用户来定义,它可以是一个场景、副本、房间等等等。

比如,在一个MMORPG中,一张地图或一个副本就是一个Space空间,只有空间内的角色、怪物、NPC可以互相交互。当跳转或传送到另一张地图时,之前的怪物、NPC就不可见了,你也无法对刚才地图里的怪物进行攻击,也无法对刚才地图中的NPC进行交谈。再比如,棋牌游戏中,一般有很多房间,每个房间是一个牌局,玩家在一个房间内进行该局游戏过程,两个房间互相之间不会有交互(聊天等等的系统除外)。

详情请查看Space空间

必要组件的描述:

自上而下依次是:

Client

用户的客户端。我们会给客户端提供支持,Unity3D、UnrealEngine、HTML5、Cocos2d等客户端我们提供专门的SDK,使接入变得非常方便和直接,能快速和服务器端对接。其他的,我们会提供一个lib文件和一套API接口,开发者自行决定输入输出控制、图形渲染等方式。

Loginapp

作用:

登录验证、注册、Client的接入口。

可在多台机器部署多个Loginapp进程来负载,降低单台登录业务的压力。详情见《负载均衡》一文。

Baseapp

作用:

  1. 通过Loginapp分配过来的Client会与Baseapp保持连接,完成客户端与服务端的交互。
  2. 定时把Entity的数据保存进数据库。
  3. Baseapp之间会进行互相备份,保证数据的安全。
  4. 灾难恢复-当Baseapp发生问题(崩溃、断开连接等)时,会自动进行恢复。

常见用法:

Baseapp上不涉及与空间或位置相关的逻辑,所以脚本层通常会选择在baseapp上实现如:社交系统、广播聊天、排行、游戏大厅等等逻辑系统。

可在多台机器部署多个baseapp进程来负载,降低单台baseapp的连接带宽压力和计算压力。详情见《负载均衡》一文。

Cellapp

作用:

  1. 处理游戏、空间或位置有关的逻辑
  2. 空间数据管理,如增加几何映射(KBEngine.addSpaceGeometryMapping)、设置空间数据(KBEngine.setSpaceData
  3. 抽象概念-Space空间的创建和摧毁。

常见用法:

  1. Navigate导航
  2. AI逻辑
  3. 战斗系统
  4. View视图的控制
  5. 可以增加一个副本或者房间

可在多台机器部署多个cellapp进程来负载,降低单台cellapp的压力。详情见《负载均衡》一文。

BaseappMgr

作用:

  1. 协调所有Baseapp的工作,包括Baseapp负载均衡处理等。

一个KBE架构中,只会出现一个BaseappMgr。

CellappMgr

作用:

  1. 负责协调所有Cellapp的工作,包括负载均衡处理等。

一个KBE架构中,只会出现一个CellappMgr。

DBMgr

数据库管理器,管理与底层数据库的通讯。可以连接Mysql、Redis等多种数据库,并且能连接多台数据库进行负载均衡。

DBMgr最多可以挂65535个数据库,这些数据库可以在不同硬件上也可以在相同的机器上,api使用时,通过Entity.writeToDB等接口和一定的算法,指定存储到某个地方,这样就可以平均分配到不同的数据库上了。同时,Mysql等数据库都有自己的分库分表机制,可以共同协助完成这项工作。

作用:

  1. 对数据库的访问。
  2. 高性能多线程的数据存取。

默认使用Mysql作为数据库。同时,一个KBE架构中,只会出现一个DBMgr。

Machine

抽象出来的一个服务端硬件节点(一台硬件服务器只能存在一个这样的进程)。

作用:

  1. 接收远程指令,处理本机上的组件启动与关闭;
  2. 通知服务器群组各个进程的存活状态;
  3. 提供本机上运行组件的接入口;
  4. 收集当前机器上的一些信息,如:CPU、内存、带宽等。

服务端工具组件的描述:

Interfaces

作用:

  1. 快速接入第三方计费、第三方账号、第三方数据
  2. 快速与运营系统耦合

多台机器下可以共同一个Interfaces。

Logger

日志服务器。

作用:

  1. 收集和备份各个组件的运行日志。

CBE引擎概览的更多相关文章

  1. InnoDB存储引擎概览

    InnoDB存储引擎概览   InnoDB存储引擎以其平衡了高可靠性和高性能性而闻名遐迩,在MySQL 8.0版本中,InnoDB存储引擎是默认的存储引擎.(历史追溯从MySQL 5.5.5版本开始, ...

  2. 转:Irrlicht 0.1引擎源码分析与研究(一)

    目录(?)[-] 主要技术特性 引擎概览 Irrlicht的窗口管理   Irrlicht引擎主要是由一个名叫Nikolaus Gebhardt奥地利人所设计,是sourceforge上的一个开源项目 ...

  3. 3d引擎列表

    免费引擎 Agar - 一个高级图形应用程序框架,用于2D和3D游戏. Allegro library - 基于 C/C++ 的游戏引擎,支持图形,声音,输入,游戏时钟,浮点,压缩文件以及GUI. A ...

  4. Google V8 引擎 原理详解

    V8 引擎概览 V8 引擎简介 Google V8 引擎使用 C++ 代码编写,实现了 ECMAScript 规范的第五版,可以运行在所有的主流 操作系统中,甚至可以运行在移动终端 ( 基于 ARM ...

  5. HiEngine:可媲美本地的云原生内存数据库引擎

    摘要:HiEngine与华为GaussDB (for MySQL)集成,将内存数据库引擎的优势带到云端,并与基于磁盘的引擎共存.HiEngine的性能比传统的以存储为中心的解决方案高出7.5倍. 本文 ...

  6. Unigine 基础入门

    1. 首先要搭建好开发环境: 1)Visual Stodio 已经安装了. 2). Microsoft Windows SDK 7.1 (for Windows 7): https://www.mic ...

  7. Chrome V8引擎系列随笔 (1):Math.Random()函数概览

    先让大家来看一幅图,这幅图是V8引擎4.7版本和4.9版本Math.Random()函数的值的分布图,我可以这么理解 .从下图中,也许你会认为这是个二维码?其实这幅图告诉我们一个道理,第二张图的点的分 ...

  8. 深入理解PHP内核(二)概览-PHP生命周期与Zend引擎

    本文参考自<深入理解PHP内核>,地址:https://github.com/reeze/tipi 本文链接:http://www.orlion.ml/232/ 1.SAPI接口 SAPI ...

  9. 【分布式计算】30分钟概览Spark分布式计算引擎

    本文主要帮助初学者快速了解Spark,不会面面俱到,但核心一定点到. Spark是继Hadoop之后的下一代分布式内存计算引擎,于2009年诞生于加州大学伯克利分校AMPLab实验室,现在主要由Dat ...

随机推荐

  1. PP: Unsupervised deep embedding for clustering analysis

    Problem: unsupervised clustering represent data in feature space; learn a non-linear mapping from da ...

  2. Uva1639(概率期望/对数处理避免丢失精度)

    Uva1639 题意: 有两个盒子各有n个糖果(n<=200000),每天随机选择一个:选第一个盒子的概率是p(0 ≤ p ≤ 1),第二个盒子的概率为1-p,然后吃掉其中的一颗.直到有一天,随 ...

  3. Api跨域设置

    跨域设置:(服务端) webconfig文件中,system.webServer节点下添加 <!--跨域请求:三个配置信息--> <httpProtocol> <cust ...

  4. Java数列循环左移

    描述 有n个整数组成一个数组(数列).现使数列中各数顺序依次向左移动k个位置,移出的数再从尾部移入.输出移动后的数列元素. 题目没有告诉你n的范围,要求不要提前定义数组的大小. 另外要求定义并使用函数 ...

  5. Django---Django返回用户输入数据

    前面写了关于HTML和Django结合的文章,通过视图与HTML结合,然后加上urls渲染返回给用户浏览器.很明显我们都能看到这些仅仅是静态HTML,那如何通过Django创建动态的HTML呢? 动态 ...

  6. Bubble Sort HDU - 5775 树状数组

    //每个数字只会被它后面的比它小的数字影响,且会向右移动相应个数的位置 //比如:6 4 3 5 2 1 .4后面比它小的有 三个,因此它的最右边位置就是当前位置 +3,即5 //如果该数字本身在标准 ...

  7. 题解 P5718 【【深基4.例2】找最小值】

    题目传送门 思路 介绍一种新方法--sort排序,它的格式是这样的sort(a+1,a+n+1,cmp);,我们只需要把a数组排好序,然后输出第\(1\)个元素即可. 定义a数组与变量\(n\)并输入 ...

  8. 学Python必须背的42个常见单词,看看你都会吗?

    这42个单词是学习Python必须背会的单词,也是代码中常见的单词.希望你能都背下来! ! 1. adult  [ˈædʌlt]  成年人 2. authentication [ɔːˌθentɪˈke ...

  9. NPOI 生成Excel

    private void btnSave_Click(object sender, EventArgs e) { ) != ".xls") { MessageBox.Show(&q ...

  10. 【Python可视化】超详细Pyecharts 1.x教程,让你的图表动起来~

    前言 pyecharts 是一个用于生成 Echarts 图表的Python库.Echarts是百度开源的一个数据可视化 JS 库,可以生成一些非常酷炫的图表. Pyecharts在1.x版本之后迎来 ...