采用开源软件搭建WebGIS系统(5)性能!性能!
[本文版权由xiaotie@vip.sina.com所有,转载需得到作者同意。]
问题开始出现……
性能测试发现,当前架构方案的性能比较底下。
测试环境:PC机 CPU Inter PentiumIII 主频797MHz
主存储器:384MB
操作系统:Windows server 2003
Web服务器:IIS6.0
GIS服务器:Geoserver
当前Web GIS方案在处理低于20MB的地理数据(shape file格式数据)时,性能在接受的范围之内,打开页面时间5s左右,javaw.exe的内存占有量在50MB左右。但是当Web GIS在处理大于100MB甚至更大的地理数据时性能急剧下降,而且占用内存量急剧增大,当处理800MB的Shape File文件时javaw.exe的内存占有量达320-330MB,处理时间长达5-10分钟。
性能底下的原因可能是没有采用缓存和索引机制,也可能是java自身效率问题。为了定位问题所在,采用C++的开源GIS QGIS打开同一个数据集进行对比测试,所耗时间和GeoTools差不多,说明性能底下的原因不在于语言,可以通过索引机制和缓存机制来提高性能。还好JTS和PostGIS都提供有空间索引支持。至于缓存,可以在服务器端解决。
QGIS测试发现了另外一个预想不到的问题,就是内存占用。打开相同的数据集,QGIS的内存占用只为GeoTools的1/10。java 虚拟机的内存限制,可能导致加载的数据集不能太大,好在内存便宜,具有上G的大数据集的Web GIS应用也不是很多,必要时可以采用Cluster实现。
版权所有,欢迎转载
分类:
[22]代码阅读
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义