GeoWebCache的使用和配置

作者: d1ab10 | 来源:发表于2016-12-27 17:42 被阅读169次

    1.首先下载war包,在tomcat中解压后,会在WEB-INF目录下找到一系列配置文件,先找到web.xml,然后在web-app根元素下添加:

    <context-param>
        <param-name>GEOWEBCACHE_CACHE_DIR</param-name>
        <param-value>D:/data/cache</param-value>
    </context-param>
    

    注意,Param-value元素就是要存放GeoWebCache瓦片的位置,可自定义。

    2.更改完成后,重启Tomcat,之后在D:/data/cache下会生成一些文件。其中包含geowebcache.xml,这个文件是geowebcache的配置的关键所在,在最后会贴上参考配置文件信息。

    3.之后可以进入:http://localhost:8080/geowebcache/demo,点击Reload Configuration

    Paste_Image.png

    第一次点击该按钮是会出现登录窗口,配置文件是在WEB-INF下的user.property。

    Paste_Image.png

    Geowebcache是用户名,secured是密码,均可自定义。

    点击seed this layer。

    Paste_Image.png

    设置完毕就开始切图。

    可以点开相应的切片地图文件夹进行查看。

    Paste_Image.png
    Paste_Image.png

    如果要将GeoServer上的WMS服务整合进GeoWebCache中,要执行以下步骤:
    打开缓存图片路径下的配置文件geowebcache.xml。在<layers>下添加<wmsLayer>。

    Paste_Image.png Paste_Image.png

    附:
    参考geowebcache.xml文件

    <?xml version="1.0" encoding="utf-8"?>
    <gwcConfiguration xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                      xsi:noNamespaceSchemaLocation="http://geowebcache.org/schema/1.2.2/geowebcache.xsd"
                      xmlns="http://geowebcache.org/schema/1.2.2">
    
      <!-- ============================== 全局设置 ======================================== -->
    
      <!-- 以下控制包含了自动更新,当你手动更新这些配置的时候,更新以上这些和命名空间 -->
      <version>1.2.1</version>
      <!-- 可选:这是对HTTP协议连接到WMS后端的全局超时设置。它由连接和传输这两方面决定,因此如果数据传回很慢的话,实际的超时发生的阀值可能比它更长一些 -->
      <backendTimeout>120</backendTimeout>
      <!-- 可选:如果设置为true,你可以添加cache=false来请求,那么他们可以使用无缓存的代理 -->
      <cacheBypassAllowed>false</cacheBypassAllowed>
      <!-- 可选:缺省情况下GWC显示简单的运行时统计数据在首页上 -->
      <runtimeStats>true</runtimeStats>
      <!-- 可选:使用一个HTTP用户名来请求,由于HTT客户端的设计包含了<a href="http://lib.csdn.net/base/javase" class='replace_word' title="Java SE知识库" target='_blank' style='color:#df3434; font-weight:bold;'>Java</a>,这个设置时全局的-->
      <httpUsername></httpUsername>
      <!-- 可选:以上用户名的密码 -->
      <httpPassword></httpPassword>
    
      <!-- ============================== 全局格式修改器================================ -->
    
      <!-- 可选:格式修改器,这些也可以通过对各个图层单独定义 -->
      <formatModifiers>
        <!-- 能够有一个和多个这样的元素 -->
        <formatModifier>
          <!-- 必要:应用于JPEG -->
          <responseFormat>image/jpeg</responseFormat>
          <!-- 可选:从后端的PNG请求时,阻止双重压缩 -->
          <requestFormat>image/png</requestFormat>
          <!-- 可选:透明度支持 -->
          <transparent>false</transparent>
          <!-- 可选:背景颜色 -->
          <bgColor>0x0066DD</bgColor>
          <!-- 可选WMS服务器使用的调色板 -->
          <palette>somepalette</palette>
          <!-- 可选:调节压缩等级,1.0是最佳质量 -->
          <compressionQuality>0.9</compressionQuality>
        </formatModifier>
      </formatModifiers>
    
      <!-- ============================ 网格设置(GRID SETS)============================= -->
    
      <!-- 可选:网格集合。如果这里没有任何设置,唯一可用的将是全球的EPSG:4326和EPSG:900913,另外,他将应用于所有为GetCapabilities配置而自动生成 -->
      <gridSets>
        <!-- 可以有一个或多个这样的元素 -->
        <gridSet>
          <!--必要:name,extent,SRS -->
          <name>The Entire World</name>
          <!-- 必要:SRS用于WMS请求,对所有那些没有指定grid set的服务,退回寻找的方法。目前,只接受EPSG代码,指定相应的数据 -->
          <srs><number>4326</number</srs>
          <!-- 必要:grid set的bounding box,可以设置为在给定可用SRS中最大值,然后在后面用gridSubset元素来限制它 -->
          <extent>
            <coords>
              <double>-180.0</double>
              <double>-90.0</double>
              <double>180.0</double>
              <double>90.0</double>
            </coords>
          </extent>
          <!-- 可选:选择网格是否使用左上角为起始点,缺省情况下是左下角为起始点 -->
          <alignTopLeft>false</alignTopLeft>
          <!-- 可选:缺省情况下,GWC将尝试匹配extent到一个瓦片,然后为每个子后继缩放等级四等分这个瓦片。除此之外,你可以指定特定的分辨率(resolutions)来组织。resolution的计算式按照每像素(pixel)的地图的(map degrees)度,那么180degrees/256pixel=0.703125 -->
          <resolutions>
               <double>0.703125</double>
               <double>0.3515625</double>
               <double>0.17578125</double>
          </resolutions>
          <!-- 可选:作为选择,可以使用比例尺(scale)作为分母的方式,OGC流行声明一个像素(pixel)=0.28mm,按此种方式计算。数值的顺序必须是降序(因为是分母 -->
          <scaleDenominators>
               <double>25000000</double>
               <double>2500000</double>
               <double>250000</double>
               <double>50000</double>
          </scaleDenominators>
          <!-- 可选:如果四分法足够好,但是你想限制缩放的等级,可以设置等级总数 -->
          <levels>20</levels>
          <!-- 可选:一个地图图元(1 map unit)的值在真实世界中的单位,用于大概的比例尺计算以及常常不是很精确。对于经纬度(lat/lon)应该使用地球周长(earth circumference)/360.0度(degrees)=111226.31。对于英尺(feet)应该用0.3048 -->
          <metersPerUnit>111226.31</metersPerUnit>
          <!-- 可选:单个像素表示一米的大小,OGC标准中WMS1.3.0和WMTS声明为0.28mm/pixel,相当于90.71428571428572DPI -->
          <pixelSize>0.00028</pixelSize>
          <!-- 可选:如WMTS之类的协议,支持命名的比例尺。如果要自定义名称,要确保和所定义的比例尺(scale)或分辨率(resolution)一致的顺序。 -->
          <scaleNames>
            <string>Low Resolution</string>
            <string>Medium Resolution</string>
            <string>High Resolution</string>
          </scaleNames>
          <!-- 可选:瓦片尺寸,以像素为单位 -->
          <tileHeight>256</tileHeight>
          <tileWidth>256</tileWidth>
        </gridSet>
      </gridSets>
    
      <!-- ===========================图层(LAYERS)================================= -->
    
      <layers>
        <wmsLayer>
          <!-- 必要:名称用于客户端请求对应图层,和WMS不同的是,它能够包含逗号,成为对图层组联合的请求 -->
          <name>Some Layer</name>
          <!-- 可选:元信息为人描述图层 -->
          <metaInformation>
            <title>A nice title for this layer</title>
            <description>A description of what this data displays</description>
          </metaInformation>
          <!-- 可选:指定图层支持的格式。缺省情况下,支持image/png和image/jpeg。其他可选包括image/png;mode=24bit,image/png24,image/png8,image/tiff,image/gif -->
          <mimeFormats><string>image/png</string><string>image/jpeg</string></mimeFormats>
          <!-- 可选:参考全局设置(global setting)中相同的名称 -->
          <formatModifiers>...</formatModifiers>
          <!-- 可选:缺省情况下,对EPSG:4326和EPSG:900913,图层时可用的。这种行为将被gridSubset指定的所覆盖,同时,这也可以指定一个图层只对一个grid的subset可用 -->
          <gridSubsets>
            <gridSubset>
              <!-- 必要:grid set的名称对图层默认的EPSG4326和EPSG900913可用,但是一下示例演示如何指向一个预先定义的grid set -->
              <gridSetName>The Entire World</gridSetName>
              <!-- 可选:grid subset的bounding box,可以缩小之前指定的范围,如果不指定,则保持最大范围(之前指定)-->
              <extent>
                <coords>
                  <double>-60.0</double>
                  <double>-70.0</double>
                  <double>-20.0</double>
                  <double>-80.0</double>
                </coords>
              </extent>
              <!-- 可选:缩放起始,以0为基点 -->
              <zoomStart>0</zoomStart>
              <zoomStop>25</zoomStop>
            </gridSubset>
          </gridSubsets>
          <!-- 可选:(1.2.2)更新源是数据传输,告诉GeoWebCache何时内容过期 -->
          <updateSources>
            <!-- 一个GeoRSS GML传输,参见http://www.georss.org/gml -->
            <geoRssFeed>
              <!-- 一个参数化的URL获取GeoRSS GML数据源,如果插入${lastUpdate}到URL,${lastUpdate}将替换最近一次从这个源处理过的更新的时间戳 -->
              <feedUrl>http://someserver/georss?layers=somelayer&lastupdate=${lastUpdate}&srs=EPSG:4326</feedUrl>
              <!-- grid set的id,数据源的geometries将以和这个grid set同样的SRS给出 -->
              <gridSetId>EPSG:4326</gridSetId>
              <!-- 查看源的频率,以秒为单位 -->
              <pollInterval>600</pollInterval>
              <!-- 可选:操作表现,默认是截断(删简?truncate)的 -->
              <operation>reseed</operation>
              <!-- 可选:默认格式与layer相同,但可以指定特殊形式 -->
              <format>image/png</format>
              <!-- 可选:如果操作不是截断的(truncate),指定线程数量可以并行处理。多格式就是并行处理。若此处设置线程书伟2,图层有3中格式(且GeoRssFeed没有指定格式),那么总共的线程数将是3*2=6 -->
              <seedingThreads>2</seedingThreads>
              <!-- 可选:GWC渲染geometries到bitmask,然后使用它决定哪个瓦片受到影响。每个像素代表一个瓦片,那么一个这样的bitmask必须对每个缩放界别创建。这个设置控制最大缩放等级的层次书,以及内存使用。10到12是一个较好的折中。二次抽样(subsampling)用于层次(levels),这里不包含。 -->
              <maxMaskLevel>11</maxMaskLevel>
            </geoRssFeed>
          </updateSources>
          <!-- 可选:(TODO, see XSD documentation) -->
          <requestFilters></requestFilters>
          <!-- 可选: (1.2.2) 当瓦片创建以后,提供基于ETags。注意大多数浏览器仅仅只是在由超出expireClients[List]定义的时间之后才调用它。默认这个特性是关闭的 -->
          <useETags>true</useETags>
          <!-- 必要:到WMS服务的一个或多个URL就像在后端一样的方法使用 -->
          <wmsUrl><string>http://yourserver/path/wms-service</string></wmsUrl>
          <!-- 可选:LAYERS=的值将被发送到后端服务器,如果没有指定,此图层元素的名字将被使用 -->
          <wmsLayers>layer1,layer2</wmsLayes>
          <!-- 可选:STYLES=的值将被发送到后端服务器,如果没有指定,将使用一个空字符串 -->
          <wmsStyles></wmsStyles>
          <!-- 可选:“元瓦片”(metatiling)元素用于此图层,如果未指定,3*3的“元瓦片(metatiling)”用于图像格式 -->
          <metaWidthHeight><int>3</int><int>3</int></metaWidthHeight>
          <!-- 可选:“沟(gutter间隔?)”用像素指定间隔,以及代表额外的在图像周边的padding,当瓦片创建完成后他们将被消除。对一些的WMS服务器有边缘效应(edge dffects)的话,那么可以擦除它,但是他同样对剪切的label造成影像。 -->
          <gutter>0</gutter>
          <!-- 可选:EXCEPTION=的值发送到后端服务器,同样可以使用vnd.ogc.se_inimage,但是在这种情况下,GWC将不能分辨来自于可用瓦片的错误。 -->
          <errorMime>application/vnd.ogc.se_xml</errorMime>
          <!-- 可选:VERSION=的值发送到后端服务器,默认版本是1.1.0 -->
          <wmsVersion>1.1.0</wmsVersion>
          <!-- 可选:TILED=的值发送到后端服务器,应该一般地省略 -->
          <tiled>false</tiled>
          <!-- 可选:TRANSPARENT=的值发送到后端服务器,一般设置为true,但是不适用于JPEG格式,但见formatModifiers -->
          <transparent>true</transparent>
          <!-- 可选:背景颜色以16进制表示,注意背景色和透明度是相互独立的 -->
          <bgColor>0xFF00AA</bgColor>
          <!-- 可选:PALETTE=的值,调色板的值发送到后端服务器,这个参数常常省略 -->
          <palette><palette>
          <!-- 可选:任何其他需要随每次请求发送到后端服务器的参数,如果需要,值应该是后缀在URL字符之下,用&amp分隔开。MapServer典型的参数如map= value,参数常常留有空白 -->
          <vendorParameters></vendorParameters>
          <!-- 可选:一个瓦片在服务器保持可用的秒数。后续请求将取回的结果是一个新的瓦片。默认是永久cache。参数列表应该常常以minZoom="0"开头,然后单调递增。特殊值:-1表示从不缓存,-2表示从不过期 -->
          <expireCacheList>
            <expirationRule minZoom="0"  expiration="14400" />
            <expirationRule minZoom="10" expiration="7200" />
          </expireCacheList>
          <!-- 可选:客户端从GWC收到瓦片之后,需要缓存的时间(秒为单位)。默认值使用和WMS服务器提供的过期时间相同。如果值不可用,缓存2小时,参见expireCacheList -->
          <expireClientsList>
            <expirationRule minZoom="0" expiration="7200" />
            <expirationRule minZoom="10" expiration="600" />
          </expireClientsList>
          <!-- 可选:参见全局backendTimeout描述 -->
          <backendTimeout></backendTimeout>
          <!-- 可选:选择是否客户端能够后续&cached=false参数,以及使用GWC为代理或者是作为服务翻译者(service translator) -->
          <cacheBypassAllowed></cacheBypassAllowed>
          <!-- 可选:是否此图层在getcapabilities文档中将可查询(query),以及代理getfeatureinfo请求到后端服务器。默认情况是false -->
          <queryable>false</queryable>
          <!-- 可选: (TODO, see XSD documentation) -->
          <paramaterFilters></parameterFilters>
        <wmsLayer>
      <layers>
    </gwcConfiguration>
    

    相关文章

      网友评论

        本文标题:GeoWebCache的使用和配置

        本文链接:https://www.haomeiwen.com/subject/qsdevttx.html