独立部署GeoWebCache
在进行GIS项目开发中,常使用Geoserver作为开源的地图服务器,Geoserver是一个JavaEE项目,常通过Tomcat进行部署。而GeoWebCache是一个采用Java实现用于缓存WMS-Tile(瓦片)的开源项目。当客户端请求一张新地图和Tile时,GeoWebCache将拦截这些调用然后返回缓存过的Tiles。 本文主要讲述独立部署GeoWebCache,并且复用已经切好的瓦片缓存。
在实际项目中,需要对比较大数据量的地图切缓存,例如全国地图,并且移植复用,进行私有云部署。那么如果用GeoWebCache直接发布已经切好的缓存呢?
一、下载安装GeoWebCache(GWC)
不知为何,GeoWebCache官网竟然无法访问,这里直接给出下载地址:geowebcache-1.14.1-war.zip
这里是各个版本的列表:https://sourceforge.net/projects/geowebcache/files/geowebcache
注意:安装GWC前提还是要安装java jre(或者jdk),安装Tomcat,这里就不赘述了,不明白可以看之前的文章:基于Tomcat安装Geoserver
将geowebcache的war包拷贝到tomcat的webapps目录下即可,启动tomcat,输入http://localhost:8080/geowebcache,显示如下界面说明安装成功。
点击“A list of all the layers and automatic demos”链接即可进入缓存图层列表,默认有三个图层:
二、修改缓存目录
GWC默认的数据缓存目录在%temp%\geowebcache中,我们将其修改至D:\GISData\gwccache
进入tomcat目录,在\webapps\geowebcache\WEB-INF中修改web.xml文件,加入如下内容:
1 | <context-param> |
注意: 一个“context-param”节点只能有一个键值对。
重启tomcat,发现D:\GISData\gwccache目录多了一些文件:
三、复用瓦片缓存文件,发布wms图层
1.将之前缓存好的瓦片拷贝到D:\GISData\gwccache目录下:
缓存文件夹名称即为要发布的图层名称,打开后层级目录如下,以gridset名称和zoom等级命名:
2.打开D:\GISData\gwccache\geowebcache.xml文件,在Layers节点下加入如下代码:
1 | <wmsLayer> |
3.重启tomcat服务器,会发现图层列表中多了一个图层:
4.以png方式浏览,缓存地图加载成功:
四、问题解决
通过openlayers访问时会出现烦人的400错误,通过查看客户端代码发现,extent为[-180,-90,180,90]
我们只需改为地图实际的extent即可: