要素服务在访问要素源中的数据之前,除了需要必须创建一个到要素源的FDO连接,还经常需要描述要素源的模式和空间上下文(Spatail Context),获取要素类及其属性的定义信息,这些操作都会花掉一定的时间,特别是描述要素源的模式,所以MapGuide服务器将这些信息缓存下来以提高MapGuide服务器的性能。
当要素服务需要某个要素源的模式、要素类定义、属性定义、空间上下文时,首先会在要素服务缓存中查找此项目,如果找到了就直接使用此缓存项目,否则执行FDO命令得到此项目,然后将其保存至要素服务缓存中。在将其保存到要素服务缓存中时,如果缓存中的项目数小于可以缓存的最大项目数,则直接将其放入项目中,否则删除掉缓存中最后被使用的项目,然后将新的项目加入缓存。当某个缓存项的空闲时间(即当前时间和连接最后使用时间的时间差)超过设定的值时,会将其从缓存中删除。
通过修改MapGuide服务器配置文件serverconfig.ini可以配置要素服务缓存中可以缓存的最大项目数、缓冲项的超时时间、超时检测时间间隔,这些参数的具体含义请参考表1-1,如下的参数值设置可以缓存的最大项目数为100,缓冲项目的超时时间为60个小时(86400秒),超时检测时间间隔为1小时(28800秒)。
[FeatureServiceProperties] CacheSize = 100 CacheTimeLimit = 86400 CacheTimerInterval = 3600 |
任何缓存技术都必须解决数据更新的问题,如果被缓存的数据发生了变化,如何通知并更新缓存中对应的项目。目前,MapGuide并没有为此提供任何解决方案,因为MapGuide并没有提供任何方法修改要素源的模式、要素类定义、属性定义和空间上下文。所以,除非用户使用外部应用程序修改了要素源的这些信息,否则不会产生任何问题。
属性名称 | 描述 |
CacheSize | 用于指定要素缓存中可以缓存的最大项目数,它可以为大于0小于等于5000的任何整数。 |
CacheTimeLimit | 用于指定单位为秒的缓冲项目超时时间。 |
CacheTimerInterval | 用于指定单位为秒的检测缓冲项目是否超时的时间间隔。 |