`
GuMuTian
  • 浏览: 14437 次
社区版块
存档分类
最新评论

ArcGIS Server 优化方案及混合应用两种模式的缓存

阅读更多

名词解释及翻译:

Instances (In Use/Running) 实例的使用状态。 In Use 代表正在使用中的实例数。 Running 代表已经创建的实例数。

Minimum number of instances 最小实例个数。

Maximum number of instances 最大实例个数。

The maximum time a client will wait to get a service 客户端等待获取服务的最大时间。

 

首先,简单介绍一下 ArcGIS 池化与非池化服务的原理。 ArcGIS ADF 框架在使用池化服务时,只是在程序需要的时候在实例池中获取一个实例,此时 In Use 1 。使用完毕后立即释放回实例池(注意是释放而不是关闭),等待下一次被再次重用,此时 In Use 1 。这就是为什么池化实例一经创建就不会减少的原因。这中间并没有创建以及关闭实例的过程( Running 的数目不变),因此池化服务相对于非池化服务而言使用效率是很高的。

1

       而在使用非池化服务时,则是在浏览器会话开始时创建一个实例,此时 In Use Running 各加 1 。而在浏览器会话结束后关闭实例,此时 In Use Running 各减 1 。因此,非池化服务在长时间闲置的情况下实例数( Running )会减少,而池化服务只会释放回实例池,而不会真正减少实例数。

2

那么是否池化服务的实例数( Running )就不会增加了呢?当然不是了,只不过在一般情况下你先后打开两次地图是无法增加实例个数的。那么什么时候才会增加呢?答案就是在并发的情况下才会增加实例数。

通常情况下啊,如果我们先后打开两次地图。在第一次打开地图,并获取地图的时候, ADF 会从实例池获取一个实例,此时 In Use 1 ,等到地图在浏览器中显示完成后, ADF 马上释放实例回实例池,此时 In Use 1 。由于池化服务的高性能,从获取实例到释放实例通常只需要 1 秒左右。因此在大多数时候当我们去看池化服务的 In Use 时总是显示为 0 。而非池化服务就不同了,只要在你会话有效期内 In Use 总是不为 0 的。接下来,当我们第二次打开地图的时候,由于之前使用过的实例已经被释放回实例池了,因此在第二次获取实例的时候 ADF 又重用了之前的实例。所以新的实例并不需要被创建( Running 不变),只需要重用即可。

但是在并发的情况下就不同了。如果同时有两个或多个请求打开地图,当实例池中实例数( Running )不够时, ArcGIS 才会创建一个新的实例,此时 In Use Running 各加 1

讲了那么多,现在来讲讲如何优化吧!

1. 针对池化服务实例数只能增加无法减少的情况进行优化

通常在设置池化服务时,都有 Minimum number of instances Maximum number of instances 两个设置项。 ESRI 公司的建议是前者设置为 1 而后者设置为系统的最大并发数。但我不认为只是最好的设置方式。如果最大实例数设置为系统的最大并发数,或许可以解决问题。但是由于池化服务实例数只增不减的特性,一旦某一时刻并发达到最大值,则实例池中的实例数同时也会达到这一个最大值。但是系统的并发量并不总是维持在最大并发量,大多时候都是远远小于最大并发值。因此这会导致大量闲置的实例。同时,由于最小实例数设置为 1 ,则每次当实例不够用时 ArcGIS 都需要反复创建实例,这对性能以及客户体验的影响是很大的。

因此,我的建议是把最小值与最大值设为同样的值,并且该值小于系统最大并发数。至于该值该如何设置需要通过多次测试以达到最佳性能为宜。同时,要适当增大 The maximum time a client will wait to get a service 的值。该值的意思就是当并发数大于最大实例数时,系统等待多久以重用被释放回实例池的实例。

2. 针对非池化服务的实例无法及时关闭的情况进行优化

非池化服务在长时间闲置的情况下会自动关闭。但是这里究竟需要闲置多久才关闭。我没有找到相应的说明。总之默认情况下的结果是我们所不能接受的。这就需要我们自己动手了。具体的做法可以有很多,这里我就讲一下原理:

在地图初始化之后,把实例的相关信息发送到服务器端保存起来。然后在客户端通过 Ajax 每过一定时间就发送一个实例保持的信号,服务器端单独开一个线程来检查信号。由于 Ajax 是客户端代码,依赖于浏览器执行。因此如果一个实例对应的信号在 3 个周期之后仍旧没有发送到服务器端。则认为相应的浏览器页面已经被关闭,此时可手动关闭该实例。

3. 针对一个应用混合多个地图服务的情况进行优化

在项目实际应用中,单一的地图服务通常是不够用的。以下图为例,下图所示系统共使用 4 个地图服务,四个地图服务以如下顺序叠加产生地图:


3

多个地图服务叠加生成地图,这虽然带来一定得灵活性,但这是以牺牲性能为代价换来的,在一般的应用中,性能往往是我们更关注的。那么有没有方法可以鱼和熊掌兼得呢?正规的方法是不行的,那只有用非正规的方法。

在介绍我的方法前,先来了解一下 ArcGIS 的缓存。 ArcGIS 的缓存分两种,一种是融合所有图层的缓存生成方式,我称之为融合模式。另一种是将各图层分离单独生成多个图层缓存的方式,我称之为多层模式。融合模式的好处是速度快,但是缺点也同样明显——无法动态更新图片,因此所有涉及到得添加,删除或者显示 / 隐藏图层都无法在融合模式上表现出来。多层模式可以选择需要制作缓存的图层。在显示地图的时候,通过把各个已生成缓存的图层的图片和动态绘制的未生成缓存的图层的要素相叠加,生成一张图片。此模式在已生成缓存的图层和未生成缓存的图层都不多的情况下,性能较好。反之,则性能很差。

下面就开始介绍我的方法:

1) 首先把图 1 中地图服务 2 和地图服务 4 以融合模式分别生成缓存。

2) 新建一个 MXD 文件,把地图服务 1 所涉及的图层全都加入该 MXD 的图层列表。

3) MXD 中随意加入一个图层到图层列表的最底端,选择图层状态为可视,并且不设置任何显示级别。

4) 把地图服务 3 所涉及的图层全部加入 MXD 图层列表的最低端。

5) 重复步骤 3

6) 以该 MXD 建立地图服务 5 ,并以多层模式生成步骤 3 以及步骤 5 中两个图层的缓存。

7)  找到 ArcGIS 缓存存放目录。该目录下共有三个地图服务所生成的缓存,分别以地图服务 2 、地图服务 4 以及地图服务 5 的名称命名。打开地图服务 5 的缓存目录,找到以步骤 3 中图层名称命名的文件夹,把在步骤 1 中生成的地图服务 2 的缓存拷贝、覆盖到该目录。

8) 同上,找到以步骤 5 中图层名称命名的文件夹,把在步骤 1 中生成的地图服务 4 的缓存拷贝、覆盖到该目录。

至此,混合了融合模式和多层模式的地图缓存就算建立完成了。打开地图查看一下效果是不是和原来的一样!上面的方法从原理上还是多层模式的缓存机制,只不过采用之前生成的融合后的缓存图片替换了单一图层的缓存图片。而 ArcGIS 并不知道图片已经被替换,仍旧会按照预定的方式把缓存叠加到最终生成的地图中去,这正好被我们利用。使用此方法生成的地图服务理论上的性能至少不会差于多个地图服务混合的方式,但究竟性能如何还有待实践证明。

至此,我关于 ArcGIS 的优化方案都介绍完毕了。如果大家还有其他优化方案的话也欢迎提出来大家一起讨论一下。

  • 大小: 4 KB
  • 大小: 4.1 KB
  • 大小: 8.5 KB
1
0
分享到:
评论

相关推荐

    ArcGIS Server切片方案

    ArcGIS Server的切片方案是地理信息系统(GIS)领域中一种高效的数据分发和展示技术,它允许用户快速访问和加载地图数据,特别是对于大规模、高分辨率的地图数据,切片技术能显著提高地图加载速度和用户体验。ArcGIS...

    ArcGIS Server缓存地图服务设计部署及应用

    ### ArcGIS Server缓存地图服务设计部署及应用 #### 地图服务概述 地图服务作为ArcGIS Server的核心组件,扮演着至关重要的角色。它不仅能够高效地发布高质量地图,还能被广泛的应用于各种客户端,包括但不限于...

    ArcGIS Server性能优化

    ArcGIS Server作为一种广泛应用于地理信息管理领域的平台,在面对大规模数据处理和高并发访问时,通过合理的性能优化措施能够显著提升其工作效率和服务质量。通过对系统架构进行调整、检测并定位瓶颈所在、优化资源...

    arcgis server 地图缓存

    3. **缓存类型**:有两种主要的缓存模式——Single Fused Cache和Multi-Layer Cache。Single Fused Cache将所有图层合并为单一的超级切片(super-tiles),适用于不需要单独图层控制的情况。Multi-Layer Cache则为每...

    arcgis server 部署方案

    ArcGIS Server 的部署方式取决于项目的规模和具体需求,主要分为三种模式: - **单机部署** - **单SOM多SOC集群部署** - **多SOM多SOC集群部署** #### 3. 单机部署 单机部署适用于开发、测试环境或用户数量较少的...

    ArcGIS Server 部署及优化策略

    ArcGIS Server 部署及优化策略 ArcGIS Server 简述 ArcGIS Server 性能因子及优化策略 ArcGIS Server 应用系统性能评估 Windows Vs Unix

    ArcGIS Server地图缓存(map cache)案例学习

    ArcGIS Server 地图缓存(map cache)案例学习 本文是关于使用 ArcGIS ...本文是关于使用 ArcGIS Server 实现地图缓存(map cache)的案例学习,旨在帮助读者了解 ArcGIS Server 地图缓存的实现步骤、优点和应用场景。

    ArcGIS Server部署策略与性能优化

    ### ArcGIS Server部署策略与性能优化 #### 一、ArcGIS Server部署策略 **1. ArcGIS Server部署方式** ArcGIS Server提供了多种部署方式,包括集中部署、分布式部署以及群集部署。 - **集中部署**: SOM(Server ...

    ArcGIS Server 10.0-10.5的ecp文件

    每个版本的ecp文件可能包含特定版本的新功能、性能优化或安全更新,因此对于升级和维护ArcGIS Server的环境至关重要。 10.0至10.5版本的ArcGIS Server经历了多次重要升级,带来了诸多新特性: - **ArcGIS Server ...

    ArcGIS Server 10.5 ecp

    在10.5版本中,ArcGIS Server对服务性能进行了优化,包括更快的渲染速度、更高效的缓存管理和并行处理能力,以应对大数据和高并发访问的需求。 9. **持续更新与维护** 需要注意的是,ArcGIS Server 10.5版本的...

    arcgis server 10.5 Crack

    总之,ArcGIS Server 10.5 是一个功能强大的GIS服务器软件,它为企业级GIS应用提供了全面的解决方案,涉及地图服务发布、数据分析、系统集成、数据安全等多个方面。然而,使用未经授权的版本可能会导致数据丢失、...

    ArcGIS Server 10.4.rar

    没有有效的许可文件,ArcGIS Server将无法启动或只能运行在演示模式下,无法执行高级功能。 **2. 许可类型** ArcGIS Server的许可分为几种类型,包括基本版、标准版和高级版。不同版本提供了不同级别的功能,如...

    ArcGIS Server 性能优化与高可用性部署

    ### ArcGIS Server 性能优化与高可用性部署 #### 数据结构与数据源 在ArcGIS Server中,数据结构的选择对于系统的性能至关重要。常见的数据结构包括矢量数据、栅格数据以及地形数据(如TIN和Terrain)。这些数据...

    Arcgis server 10.8.1授权. ECP

    ArcGIS Server的授权系统基于多种模式,包括浮动许可和单机许可。浮动许可允许一定数量的并发用户访问服务器,而单机许可则绑定到特定的硬件。ECP中的“永久授权”意味着用户购买了一次性的、无时间限制的使用权,...

    ArcgisServer10.2.ecp.zip

    `.ecp`文件可能针对其中一种或两种模式。 此外,ArcGIS Server 10.2还支持扩展功能,如GeoAnalytics、3D Analyst和Spatial Analyst等,这些扩展需要额外的许可。如果`.ecp`文件包含了这些扩展的许可,用户便可以在...

    arcgis server 10.2.2许可文件.zip

    《ArcGIS Server 10.2.2 许可文件详解》 ArcGIS Server是Esri公司开发的一款强大的地理信息系统(GIS)服务器软件,它允许用户在互联网、内联网或局域网环境下发布、管理和共享地理空间数据。在这个场景中,我们...

    ArcGIS Server 10.2.2+许可文件

    Esri 通常采用两种许可模式:ArcGIS Server Standard 和 ArcGIS Server Advanced,它们在功能和并发连接数上有所不同。 1. **许可管理器**:Esri 的许可管理器(ArcGIS License Manager)负责分配和管理许可证。...

    解决arcgis server跨域问题

    解决arcgis server跨域问题: 1、停掉ArcGIS Server的服务。 2、 打开<ArcGIS Server> \framework\runtime\tomcat\conf\web.xml,注册跨域bean 3、lib下拷贝 cors-filter-2.5.jar java-property-utils-1.9.1.jar包 4...

Global site tag (gtag.js) - Google Analytics