顾及访问热度的网络空间信息服务高性能内存缓存方法

文档序号:10555673阅读:214来源:国知局
顾及访问热度的网络空间信息服务高性能内存缓存方法
【专利摘要】本发明公开了一种顾及访问热度的网络空间信息服务高性能内存缓存方法,包括以下步骤:服务器端接收客户端发送的空间数据请求,获得请求的访问地址;将地址作为关键字在全局内存缓存中检索缓存对象,如果检索没命中,则将客户端请求地址作为关键字从临时缓存中检索对应的临时缓存对象,若检索命中,根据临时缓存对象的访问次数决定是否加入全局内存缓存中,若未命中,则将当前请求信息加入到临时缓存。本发明方法能够控制缓存模块仅将访问热度达到一定阈值的空间数据缓存到有限的服务器内存中,减少内存缓存的置换次数,避免过多地对内存缓存数据进行淘汰处理,提高服务器端的内存缓存性能和网络空间信息服务的并发访问性能。
【专利说明】
顾及访问热度的网络空间信息服务高性能内存缓存方法
技术领域
[0001]本发明涉及网络地理信息系统技术,尤其是一种顾及访问热度的网络空间信息服务高性能内存缓存方法。
【背景技术】
[0002]网络空间信息服务高性能内存缓存是网络地理信息系统(WebGIS)中需要解决的重要问题之一,利用服务器内存的高性能并发读写性能,将网络空间信息服务请求数据缓存到服务器的高速内存中,能够提高客户端请求的并发响应效率,但服务器的内存资源是有限的,对于大规模的海量空间数据,只能缓存部分数据到服务器的内存中,当大用户量密集并发访问时,由于大量临时访问数据被加入到有限的内存缓存中,会导致频繁地对内存缓存中的数据进行淘汰处理,降低了内存缓存的效率和缓存命中率。

【发明内容】

[0003]本发明要解决的技术问题在于针对现有技术中的缺陷,提供一种顾及访问热度的网络空间信息服务高性能内存缓存方法,降低服务器上内存缓存的淘汰频率,提高网络空间信息服务内存缓存性能。
[0004]本发明解决其技术问题所采用的技术方案是:一种顾及访问热度的网络空间信息服务高性能内存缓存方法,其包括以下步骤:
步骤1:设置服务器端的空间数据请求次数缓存阈值(ACT),全局内存缓存对象最大个数(GCT),临时缓存对象最大个数(TCT)。
[0005]步骤2:服务器端接收客户端发送的空间数据请求,获得请求的访问地址。
[0006]步骤3:将地址作为关键字从全局内存缓存中去检索缓存对象,如果全局缓存命中,转步骤4;如果全局内存缓存没命中,转步骤6。
[0007]步骤4:更新命中的全局内存缓存对象的最后访问时间属性。
[0008]步骤5:将命中的缓存对象中存储的结果数据直接返回给客户端,结束。
[0009]步骤6:从空间数据库中检索客户端请求的数据。
[0010]步骤7:将结果数据返回给客户端。
[0011 ]步骤8:将客户端请求地址作为关键字从临时缓存中检索对应的临时缓存对象,如果临时缓存命中,转步骤9;如果临时缓存未命中,转步骤15。
[0012]步骤9:获取临时缓存对象的访问次数(RAC)。如果RAOACT,转步骤10;反之则转步骤14 0
[0013]步骤10:将当前请求得到的结果数据增加到全局内存缓存中。
[0014]步骤11:删除当前请求的临时缓存对象,
步骤12:获取全局内存缓存中的缓存个数(GCC),如果GCOGCT,转步骤13,如果GCC〈GCT,结束。
[0015]步骤13:删除全局内存缓存中最久未被访问的一个缓存对象,结束。
[0016]步骤14:将临时缓存对象的访问次数(RAC)加I,并更新临时缓存对象的最后访问时间,结束。
[0017]步骤15:将当前请求的临时缓存对象的访问次数初始为1,并将其增加到临时缓存中。
[0018]步骤16:获取临时缓存中的缓存对象个数(TCC),如果TCOTCT,转步骤17;如果TCC〈TCT,结束。
[0019]步骤17:删除临时缓存中最久未被访问的一个缓存对象,结束。
[0020]按上述方案,所述步骤I)中临时缓存和全局缓存都采用键值对的形式存储,其中,键均为请求的地址,值分别为临时缓存对象和全局缓存对象。
[0021]按上述方案,所述每个临时缓存对象的值中包括其键对应的请求地址的最后访问时间和对该地址的访问次数;所述每个全局缓存对象的值中包括其键对应的请求地址的最后访问时间和该请求对应的结果数据。
[0022]按上述方案,所述步骤9)中,仅当请求地址的访问次数超过阈值时才将请求地址对应的结果数据缓存到全局缓存中。
[0023]本发明的有益效果是能够根据网络空间信息服务访问请求的访问热度来判断是否将请求数据缓存到服务器的内存缓存中,以避免将一些临时访问次数较少的数据存储到服务器的内存缓存中,减少服务器内存缓存的转换次数,提高服务器端内存缓存效率和缓存命中率,提高网络空间信息服务的大用户量并发请求处理性能。
[0024]
【附图说明】
[0025]下面将结合附图及实施例对本发明作进一步说明,附图中:
图1是本发明的方法流程图。
【具体实施方式】
[0026]为了使本发明的目的、技术方案及优点更加清楚明白,以下结合实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
[0027]如图1所示,图1是本发明提供的顾及访问热度的网络空间信息服务高性能内存缓存方法流程图,所述方法包括以下步骤:
步骤1:设置服务器端的空间数据请求次数缓存阈值(ACT),全局内存缓存对象最大个数(GCT),临时缓存对象最大个数(TCT)。
[0028]步骤2:服务器端接收客户端发送的空间数据请求,获得请求访问的HTTP地址。
[0029]步骤3:将地址作为关键字从全局内存缓存中去检索缓存对象,如果全局缓存命中,转步骤4;如果全局内存缓存没命中,转步骤6。
[0030]全局缓存对象使用键值对的形式存储,请求访问的HTTP地址作为键,值为一个全局缓存对象类(GlobalCacheItem),其包含请求的结果数据(data)和请求的最后访问时间(IastAccessTime)。全局缓存对象类定义如下:
Public class GlobalCacheItem {
Public byte[] data;
Public DateTime IastAccessTime;
}
步骤4:获取命中的全局内存缓存对象(globalCacheOb j ),更新globalCacheOb j的最后访问时间(IastAccessTime)属性,将其更新为当前时间。
[0031]步骤5:将命中的缓存对象中存储的结果数据(globalCacheObj.data)直接返回给客户端,结束。
[0032]步骤6:从空间数据库中检索客户端请求的数据。
[0033]步骤7:将结果数据返回给客户端。
[0034]步骤8:将客户端请求地址作为关键字从临时缓存中检索对应的临时缓存对象,如果临时缓存命中,转步骤9;如果临时缓存未命中,转步骤15。
[0035]临时缓存对象使用键值对的形式存储,请求访问的HTTP地址作为键,值为一个临时缓存对象类(TempCacheItem),其包含请求的访问次数(RAC)和请求的最后访问时间(IastAccessTime)。临时缓存对象类定义如下:
Public class TempCacheItem
{
Public int RAC;
Public DateTime IastAccessTime;
}
步骤9:获取命中的临时缓存对象(tempCacheOb j ),获取临时缓存对象的访问次数(tempCacheOb j.RAC)。如果tempCacheOb j.RAOACT,转步骤10;反之则转步骤14。
[0036]步骤10:将步骤6中得到的当前请求的结果数据增加到全局内存缓存中。
[0037]步骤11:删除当前请求的临时缓存对象(tempCacheObj),
步骤12:获取全局内存缓存中的缓存个数(GCC),如果GCOGCT,转步骤13,如果GCC〈GCT,结束。
[0038]步骤I3:根据全局内存缓存中各个缓存对象的最后访问时间属性(IastAccessTime),删除全局内存缓存中最久未被访问的一个缓存对象,结束。
[0039]步骤14:将临时缓存对象的访问次数(tempCacheObj.RAC)加I,并更新临时缓存对象的最后访问时间(tempCacheObj.1astAccessTime),结束。
[0040]步骤15:为当前请求新建一个临时缓存对象,将当前请求的临时缓存对象的访问次数(RAC)初始为1,最后访问时间(lastAccessTime)初始为当前时间,并将其增加到临时缓存中。
[0041 ] 步骤16:获取临时缓存中的缓存对象个数(TCC),如果TCOTCT,转步骤17;如果TCC〈TCT,结束。
[0042]步骤17:根据临时缓存中各个缓存对象的最后访问时间属性(IastAccessTime),删除临时缓存中最久未被访问的一个缓存对象,结束。
[0043]本发明最明显的不同在于增加了临时缓存模块,当服务器接收到大用户量并发访问请求时,不直接将新的请求的结果数据增加到全局内存缓存中,而仅将请求的访问次数和最后访问时间存储到临时缓存中,当访问次数超过预设的阈值时才将请求的结果数据缓存到全局内存缓存中。此方法能够避免临时访问次数较少的数据被存储到全局内存缓存中,减少全局内存缓存的置换频率,提高全局内存缓存效率和命中率,提高网络空间信息服务的并发处理性能,尤其是在服务器内存资源较少时,该方法的优势更加明显。
[0044]实施例一:
为了更清晰的说明本发明的思想,下面对顾及访问热度的网络空间信息服务高性能内存缓存方法进行进一步的说明,以网络空间信息服务中的OGC WMS服务的GetCapabiIities请求为例,空间数据请求次数缓存阈值设置为10,全局内存缓存对象最大个数设置为10000,临时缓存对象最大个数设置为100。具体步骤如下:
步骤1:设置服务器端的空间数据请求次数缓存阈值(ACT=10),全局内存缓存对象最大个数(GCt=1000),临时缓存对象最大个数(TCT=10)。
[0045]步骤2:服务器端接收客户端发送的WMS服务的GetCapabi I ities请求,获得GetCapabi I ities请求访问的HTTP地址,请求地址格式如下:
h11P://domain/wms?REQUEST=GetCapabiIities&VERS1N=1.1.1&SERVICE=WMS步骤3:将步骤2中获得的地址作为关键字从全局内存缓存中去检索缓存对象,如果全局缓存命中,转步骤4;如果全局内存缓存没命中,转步骤6。
[0046]步骤4:获取命中的全局内存缓存对象(globalCacheOb j),更新globalCacheOb j的最后访问时间(IastAccessTime)属性,将其更新为当前时间。
[0047]步骤5:将命中的缓存对象中存储的结果数据(globalCacheObj.data)直接返回给客户端,结束。
[0048]步骤6:从空间数据库中检索客户端请求的数据,按照WMS服务的接口规范生成符合GetCapabi I ities服务接口要求的结果数据。
[0049]步骤7:将结果数据返回给客户端。
[0050]步骤8:将客户端请求地址作为关键字从临时缓存中检索对应的临时缓存对象,如果临时缓存命中,转步骤9;如果临时缓存未命中,转步骤15。
[0051 ]步骤9:获取命中的临时缓存对象(tempCacheObj),获取临时缓存对象的访问次数(tempCacheObj.RAC)。如果tempCacheOb j.RAOlO,转步骤 10;反之则转步骤 14。
[0052]步骤I O:使用步骤2中获得的客户端请求地址作为键,创建一个新的GlobalCacheItem类的实例对象(globalItem),设置其lastAccessTime属性为当前时间,并设置为data属性为步骤6中得到的当前请求的结果数据,然后将该请求的全局缓存对象globalltem增加到全局内存缓存中。
[°°53] 步骤11:删除当前请求的临时缓存对象(tempCacheObj),
步骤12:获取全局内存缓存中的缓存个数(GCC),如果GCC> 10000,转步骤13,如果GCC〈10000,结束。
[0054]步骤I3:根据全局内存缓存中各个缓存对象的最后访问时间属性(IastAccessTime),删除全局内存缓存中最久未被访问的一个缓存对象,结束。
[0055]步骤14:将临时缓存对象的访问次数(tempCacheObj.RAC)加I,并更新临时缓存对象的最后访问时间(tempCacheObj.lastAccessTime)为当前时间,结束。
[0056]步骤15:为当前请求新建一个TempCacheItem类的实例对象(tempItem),将其访问次数(RAC)初始为I,最后访问时间(lastAccessTime)初始为当前时间,使用步骤2中获得的客户端请求地址作为键,将该请求的临时缓存对象templtem增加到临时缓存中。
[0057 ]步骤16:获取临时缓存中的缓存对象个数(TCC ),如果TCC> 100,转步骤17;如果TCC〈100,结束。
[0058]步骤17:根据临时缓存中各个缓存对象的最后访问时间属性(lastAccessTime),删除临时缓存中最久未被访问的一个缓存对象,结束。
[0059]采用本发明设计的顾及访问热度的网络空间信息服务高性能内存缓存方法,在服务器端接收大用户量的并发访问请求时,能够避免临时访问的请求数据过多地加入到全局内存缓存中,有效地减少全局内存缓存的置换次数,有助于提高全局内存缓存的效率和命中率,提升大用户量密集并发访问时网络空间信息服务的并发处理性能。
[0060]应当理解的是,对本领域普通技术人员来说,可以根据上述说明加以改进或变换,而所有这些改进和变换都应属于本发明所附权利要求的保护范围。
【主权项】
1.一种顾及访问热度的网络空间信息服务高性能内存缓存方法,其特征在于,其包括以下步骤: 步骤I)设置服务器端的空间数据请求次数缓存阈值ACT,全局内存缓存对象最大个数GCT,临时缓存对象最大个数TCT; 步骤2)服务器端接收客户端发送的空间数据请求,获得请求的访问地址; 步骤3)将地址作为关键字在全局内存缓存中检索缓存对象,如果检索命中,转步骤4)如果检索没命中,转步骤6); 步骤4)更新命中的全局内存缓存对象的最后访问时间属性为当前时间; 步骤5)将命中的缓存对象中存储的结果数据直接返回给客户端,结束; 步骤6)从空间数据库中检索客户端请求的数据; 步骤7)将结果数据返回给客户端; 步骤8)将客户端请求地址作为关键字从临时缓存中检索对应的临时缓存对象,如果临时缓存命中对象,转步骤9);如果临时缓存未命中对象,转步骤15); 步骤9)获取临时缓存对象的访问次数RAC;如果RAOACT,转步骤10);反之则转步骤14); 步骤10)将当前请求得到的结果数据增加到全局内存缓存中; 步骤11)删除当前请求的临时缓存对象; 步骤12)获取全局内存缓存中的缓存个数GCC,如果GCOGCT,转步骤13,如果GCCXGCT,结束; 步骤13:删除全局内存缓存中最久未被访问的一个全局缓存对象,结束; 步骤14)将临时缓存对象的访问次数RAC加I,并更新临时缓存对象的最后访问时间,结束; 步骤15)将当前请求的对象增加到临时缓存中作为临时缓存对象,并将该临时缓存对象的访问次数初始为I; 步骤16)获取临时缓存中的缓存对象个数TCC,如果TCOTCT,转步骤17 ;如果TCCXTCT,结束; 步骤17)删除临时缓存中最久未被访问的一个临时缓存对象,结束。2.根据权利要求1所述的顾及访问热度的网络空间信息服务高性能内存缓存方法,其特征在于,所述步骤I)中临时缓存和全局缓存都采用键值对的形式存储,其中,键均为请求的地址,值分别为临时缓存对象和全局缓存对象。3.根据权利要求2所述的顾及访问热度的网络空间信息服务高性能内存缓存方法,其特征在于,所述每个临时缓存对象的值中包括其键对应的请求地址的最后访问时间和对该地址的访问次数;所述每个全局缓存对象的值中包括其键对应的请求地址的最后访问时间和该请求对应的结果数据。4.根据权利要求1所述的顾及访问热度的网络空间信息服务高性能内存缓存方法,其特征在于,所述步骤9)中,仅当请求地址的访问次数超过阈值时才将请求地址对应的结果数据缓存到全局缓存中。
【文档编号】H04L29/08GK105915619SQ201610283274
【公开日】2016年8月31日
【申请日】2016年4月29日
【发明人】郭明强, 黄颖, 谢忠, 吴亮, 罗显刚
【申请人】中国地质大学(武汉)
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1