作者:bsy
集群是指将 SuperMap iServer 服务注册到集群服务器中,并提供单一客户视图的服务。当有服务请求到达集群服务器时,集群服务器采用集群技术统一对 SuperMap iServer 服务进行调配,用户并不需要知道具体提供服务的 GIS 服务器。使用集群可以使 SuperMap iServer 提供的 GIS 服务在高并发、高性能等方面有很大提升,也可以整合 GIS 服务器资源,提升系统的容错能力和并发性能。
举例:SuperMap iServer 的分布式切图模块作为集群技术的典型应用,实现了地图的分布式切图、分布式存储管理等功能。
集群体系中包含以下角色,不同的角色通过各自不同的操作来构建整个集群体系:

上述角色可以概括一下,具体到某台机器。比如对于本机来说,我可以是:
集群子节点加入集群后,会每隔2秒向父节点报告一次,集群父节点收到报告后,认为该子节点是可用的子节点,且该子节点会出现在集群服务器的“集群成员列表”中。当客户端或 GIS 应用服务器向集群服务器(父节点)发送请求时,集群服务器会基于负载均衡原则将任务分配给各个集群成员(子节点),如下图所示。集群成员响应请求并将响应的结果返回给集群服务器,集群服务器再将收到的响应结果返回给发送请求的客户端或 GIS 应用服务器。例如客户端浏览地图时,收到的地图切片可能来自不同的集群成员,而不是仅来自客户端请求的集群服务器。在以下情况集群服务器会判定集群成员超时,不会给该成员分配任务或将已分配的请求任务转发给其他节点处理:
GIS 应用服务器是为客户端直接提供 GIS 服务的服务端,通过使用集群可以提升 GIS 服务的性能和负载量,集群系统将以本机 GIS 应用服务器为出口向客户端提供高性能的服务。
在 SuperMap iServer 的集群操作界面如图:

GIS 应用服务器使用集群的方式有以下两种:

多个 GIS 服务器可以通过搭建集群,提高性能。默认情况下,SuperMap iServer 的 GIS 服务器均开启集群功能,随时可以接受子节点加入。如图 3-1 所示,标识 2 直接加入标识 1 的集群服务,就形成了一个简单的集群。值得说明的是,标识 1 支持多个 GIS 服务器的加入,同时标识 1 还可以加入别的集群(此时,就构成了多层集群)。
集群配置的操作界面如图:

集群父节点,其主要职责是监听和协调子节点执行相关任务,可以对整个集群系统进行安全控制,可以查看集群成员(子节点)并决定是否允许其加入集群。集群父节点可以“开启”安全控制,来控制子节点的加入。
如果父节点开启了安全控制,需设置对应的安全密钥,此时:
开启安全控制后,在节点列表中,点击子节点对应的“允许加入集群”按钮,可以允许子节点加入集群,点击“禁止加入集群”按钮可以禁止子节点加入集群。
注:配置集群时,本机节点会自动加入集群服务器中。
在配置集群页面可以查看集群的节点列表,包括“普通节点”和“受控节点”。受控节点是指以受控的方式加入集群的子节点。点击“查看服务详情”可以看到在当前集群体系中当前子节点所提供的服务实例。
注:如果已经开启安全控制,则需要执行“允许加入集群”操作让子节点完成加入集群。
为提升集群系统请求转发的效率,iServer默认采用异步转发的方式来处理请求。您无须修改任何配置,即可在集群系统中实现请求的异步转发。
如果您需要通过自定义配置进一步提升集群系统请求转发的效率,您可以手动修改集群主节点系统配置文件(iserver-system.xml)的配置项,具体为:“clustering”中的“clusterRequestClientSetting”子项。
SuperMap iServer 支持子节点以受控的方式加入集群。这种集群配置方式简单快速,适合于子节点空闲的情况,子节点本身不需要对外提供服务而可以接受父节点的控制。子节点一旦开启了受控集群,就要受到父节点的完全控制,其自身原有的服务实例和服务管理器都将被禁用,父节点的服务实例和数据将同步到子节点。其中,服务组件集合对应的服务实例、处理自动化服务将被过滤不同步到子节点。
子节点作为受控模式的集群成员,仅用于处理父节点转发的请求。 如下图所示,在一个集群体系中,可以同时存在受控的子节点(标识2)和非受控子节点(标识3) 。
